/* ============================================================
   DeTicos.com - interface reset inspired by black/white mobile editorial UI
   Loaded last on purpose: this is the final visual contract.
   ============================================================ */

:root {
    --ah-bg: #f0f0f0;
    --ah-paper: #fbfbfa;
    --ah-card: #ffffff;
    --ah-ink: #121212;
    --ah-ink-2: #2d2d2d;
    --ah-muted: #777;
    --ah-line: #ddd;
    --ah-soft: #eeeeec;
    --ah-mid: #cfcfcd;
    --ah-radius-screen: 34px;
    --ah-radius-panel: 24px;
    --ah-radius-chip: 999px;
    --ah-shadow: 0 30px 80px rgba(0, 0, 0, 0.18);
    --ah-hard-shadow: 8px 8px 0 #121212;
    --ah-ui: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --ah-display: Arial Black, Arial Bold, Gadget, sans-serif;
    --ah-public-shell-max: 980px;
    --ah-public-shell-gutter: clamp(14px, 3vw, 48px);
    --ah-public-shell-gap: clamp(28px, 6vw, 96px);
}

* {
    box-sizing: border-box;
}

html {
    min-height: 100%;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

html,
body {
    background: var(--ah-bg) !important;
    color: var(--ah-ink) !important;
    font-family: var(--ah-ui) !important;
}

body {
    margin: 0;
    min-height: 100dvh;
}

body,
button,
input,
textarea,
select {
    line-height: 1.4;
}

img,
canvas,
video {
    max-width: 100%;
}

body.mobile-app {
    display: block !important;
    height: 100%;
    overflow: hidden !important;
}

body.mobile-app main.app-content {
    position: relative;
    z-index: 1;
    height: calc(100dvh - 72px);
    overflow-y: auto;
    padding: 0 0 calc(92px + env(safe-area-inset-bottom)) !important;
    -webkit-overflow-scrolling: touch;
}

body[data-page="camara"] main.app-content {
    height: 100dvh;
    padding: 0 !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    color: var(--ah-ink) !important;
    font-family: var(--ah-display) !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    line-height: 0.95;
    text-transform: none !important;
}

p,
small,
span,
time,
dt,
dd,
label,
input,
textarea,
select,
button,
a {
    font-family: var(--ah-ui) !important;
}

p {
    margin: 0;
    color: var(--ah-ink-2);
    font-weight: 700;
    line-height: 1.45;
}

a {
    cursor: pointer;
    color: var(--ah-ink) !important;
    text-decoration: none !important;
    border: 0 !important;
}

button,
.btn,
.btn-primary,
.btn-small,
.mini-action,
.gallery-share,
.btn-central {
    min-height: 48px;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-ink) !important;
    color: var(--ah-paper) !important;
    box-shadow: none !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
}

button:hover,
.btn:hover,
.btn-primary:hover,
.btn-small:hover,
.mini-action:hover,
.gallery-share:hover {
    transform: translate(-2px, -2px) !important;
    box-shadow: 5px 5px 0 #fdbe02 !important;
}

.btn-secondary,
.btn-small.btn-secondary,
.mini-action,
.gallery-share[href],
.btn-volver,
.btn-album-postal {
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

button:disabled,
.btn:disabled,
.btn-central:disabled {
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    opacity: 0.72;
}

input,
textarea,
select {
    min-height: 48px;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    box-shadow: none !important;
    font-weight: 800;
}

textarea {
    border-radius: var(--ah-radius-panel) !important;
}

input:focus,
textarea:focus,
select:focus {
    outline: none !important;
    box-shadow: 0 0 0 5px rgba(18, 18, 18, 0.08) !important;
}

img {
    filter: grayscale(1) contrast(1.16) !important;
}

.container-lg,
.postal-page,
.comunidad-shell {
    width: min(var(--ah-public-shell-max), calc(100% - var(--ah-public-shell-gap))) !important;
    max-width: var(--ah-public-shell-max) !important;
    margin: 0 auto !important;
}

.admin-container {
    width: min(1120px, calc(100% - 28px)) !important;
    max-width: 1120px !important;
    margin: 0 auto !important;
}

/* Top navigation: logo center, circular menu like the references */
.navbar-top {
    display: none !important;
}

.app-navbar {
    position: relative !important;
    z-index: 1600 !important;
    width: min(var(--ah-public-shell-max), calc(100% - var(--ah-public-shell-gap))) !important;
    margin: 14px auto 0 !important;
    border: 0 !important;
    background: transparent !important;
    backdrop-filter: none !important;
}

.app-navbar-inner {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 58px !important;
    justify-content: center !important;
}

.app-brand {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    left: 50%;
    transform: translateX(-50%);
    text-decoration: none;
}

.app-brand-logo {
    display: block;
    width: 34px;
    height: 34px;
    flex: 0 0 auto;
    border-radius: 9px;
}

.app-brand-text {
    color: var(--ah-ink) !important;
    font-family: var(--ah-ui) !important;
    font-size: clamp(1.45rem, 7vw, 2rem) !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
}

.app-brand-text span {
    color: #00a28d !important;
}

.nav-toggle {
    position: absolute !important;
    right: 0 !important;
    display: grid !important;
    place-items: center !important;
    width: 46px !important;
    height: 46px !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: var(--ah-ink) !important;
    color: var(--ah-paper) !important;
}

.nav-toggle span {
    width: 18px !important;
    height: 2px !important;
    margin: 2px auto !important;
    background: currentColor !important;
}

.app-nav-menu {
    position: absolute !important;
    top: 54px !important;
    right: 0 !important;
    left: auto !important;
    display: none !important;
    width: 210px !important;
    padding: 10px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 24px !important;
    background: var(--ah-paper) !important;
    box-shadow: var(--ah-hard-shadow) !important;
}

body.nav-open .app-nav-menu {
    display: grid !important;
    gap: 8px !important;
}

.app-nav-menu .nav-link {
    min-height: 44px !important;
    justify-content: center !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    font-weight: 950 !important;
    align-items: center !important;
}

.app-nav-menu .nav-link:hover {
    background: var(--ah-ink) !important;
    color: var(--ah-paper) !important;
}

/* Shared phone-screen panel */
.album-section,
.gallery-section,
.comunidad-shell,
.postal-page,
.admin-container > .admin-header,
.admin-table-wrap,
.tarjeta-form-card,
.community-panel,
.capture-result-card {
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-screen) !important;
    background: var(--ah-paper) !important;
    box-shadow: var(--ah-shadow) !important;
}

.album-section,
.gallery-section,
.comunidad-shell,
.postal-page {
    position: relative;
    padding: 22px 18px 0px !important;
    overflow: hidden;
    margin-bottom: 20px;
}

.album-section > *,
.gallery-section > *,
.comunidad-shell > *,
.postal-page > * {
    position: relative;
    z-index: 1;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    width: max-content;
    min-height: 26px;
    padding: 0 10px;
    border: 2px solid var(--ah-line);
    border-radius: var(--ah-radius-chip);
    background: var(--ah-paper);
    color: var(--ah-ink) !important;
    font-size: 0.68rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.08em !important;
}

.soft-link {
    min-height: 38px !important;
    padding: 0 14px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    font-weight: 950 !important;
}

.page-title {
    margin: 50px auto 20px !important;
    color: var(--ah-accent) !important;
    font-family: var(--ah-display) !important;
    font-size: clamp(2.35rem, 8vw, 4.2rem) !important;
    line-height: 0.96 !important;
    text-align: center;
}

/* Album as a vertical self-care style feed */
.album-header {
    position: relative !important;
    display: grid !important;
    margin: 0 0 18px !important;
    padding: 10px 0 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    text-align: center !important;
}

.album-header h2 {
    max-width: 100%;
    margin: 0 !important;
    font-size: clamp(3.1rem, 16vw, 5.8rem) !important;
    line-height: 0.88 !important;
    text-align: center;
}

.album-intro {
    max-width: 245px;
    margin: 12px 0 0 !important;
    color: var(--ah-ink) !important;
    font-size: 0.98rem !important;
    font-weight: 850 !important;
}

.album-progress {
    width: 100% !important;
    margin: 22px 0 0 !important;
    color: var(--ah-ink) !important;
}

.album-progress div {
    height: 10px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 999px !important;
    background: var(--ah-paper) !important;
}

.album-progress i {
    background: var(--ah-ink) !important;
}

.album-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: none !important;
}

.tarjeta-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
}

.tarjeta-card {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 78px 1fr !important;
    align-items: center !important;
    min-height: 112px !important;
    padding: 10px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 22px !important;
    background: var(--ah-card) !important;
    box-shadow: none !important;
}

.tarjeta-card:hover {
    transform: translate(-2px, -2px) !important;
    box-shadow: var(--ah-hard-shadow) !important;
}

.tarjeta-card .tarjeta-image {
    position: static !important;
    width: 78px !important;
    height: 92px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 18px !important;
    object-fit: cover !important;
    background: var(--ah-soft) !important;
}

.tarjeta-status {
    top: 10px !important;
    left: 10px !important;
    z-index: 3 !important;
    min-height: 22px !important;
    padding: 0 8px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    font-size: 0.66rem !important;
}

.tarjeta-card-copy {
    position: static !important;
    display: grid !important;
    gap: 4px !important;
    padding: 0 0 0 10px !important;
    border: 0 !important;
}

.tarjeta-card-copy p {
    margin: 0 !important;
    color: var(--ah-muted) !important;
    font-size: 0.7rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.tarjeta-card-copy h3 {
    margin: 0 !important;
    color: var(--ah-ink) !important;
    font-size: 1.35rem !important;
    line-height: 1 !important;
}

.tarjeta-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
}

.tarjeta-actions .mini-action {
    min-height: 40px !important;
    font-size: 0.82rem !important;
}

.tarjeta-location-detail {
    padding: 0 4px 8px !important;
}

.tarjeta-location-detail strong {
    display: none !important;
}

.tarjeta-location-detail span {
    color: var(--ah-muted) !important;
    font-size: 0.82rem !important;
    font-weight: 900 !important;
}

/* Gallery as compact social cards */
.gallery-header,
.community-header {
    display: grid !important;
    align-content: end !important;
    min-height: 252px !important;
    margin: 0 0 18px !important;
    padding: 84px 0 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    text-align: left !important;
}


.gallery-header h2,
.community-header h2 {
    max-width: 270px;
    font-size: clamp(3rem, 15vw, 5rem) !important;
}

.gallery-intro,
.community-intro {
    max-width: 260px;
    margin: 10px 0 0 !important;
    color: var(--ah-ink) !important;
    font-size: 0.95rem !important;
    font-weight: 850 !important;
}

.gallery-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
}

.gallery-item {
    position: relative !important;
    overflow: hidden !important;
    min-height: 380px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 28px !important;
    background: var(--ah-card) !important;
    box-shadow: none !important;
    aspect-ratio: auto !important;
}

.gallery-item:hover {
    transform: translate(-2px, -2px) !important;
    box-shadow: var(--ah-hard-shadow) !important;
}

.gallery-image {
    width: calc(100% - 24px) !important;
    height: calc(100% - 118px) !important;
    margin: 12px !important;
    padding: 0 !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 22px !important;
    object-fit: cover !important;
}

.gallery-overlay {
    position: absolute !important;
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    display: grid !important;
    grid-template-columns: 1fr auto auto !important;
    gap: 8px !important;
    align-items: center !important;
    padding: 10px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 20px !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

.gallery-overlay h3 {
    grid-column: 1 / -1;
    color: var(--ah-ink) !important;
    font-size: 1.25rem !important;
}

.gallery-autor,
.gallery-fecha {
    display: none !important;
}

.gallery-share {
    min-height: 36px !important;
    padding: 0 12px !important;
    font-size: 0.74rem !important;
}

/* Postal and capture pages */
.postal-hero-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.postal-main-image {
    position: relative !important;
    overflow: hidden !important;
    aspect-ratio: 4 / 5 !important;
    width: 100% !important;
    margin: 0 !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 28px !important;
    background: var(--ah-soft) !important;
    box-shadow: none !important;
}

.postal-main-image img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.postal-main-image figcaption {
    position: absolute !important;
    left: 14px !important;
    bottom: 14px !important;
    z-index: 2 !important;
    padding: 6px 10px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-chip) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    font-weight: 950 !important;
}

.postal-copy {
    display: grid !important;
    gap: 14px !important;
    padding: 0 !important;
}

.postal-copy h1 {
    font-size: clamp(2.6rem, 15vw, 4.8rem) !important;
}

.lead {
    color: var(--ah-ink) !important;
    font-size: 1rem !important;
    font-weight: 850 !important;
}

.postal-meta {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
}

.postal-meta div,
.community-stats article,
.wallet-panel,
.achievement-card,
.premium-plan {
    border: 2px solid var(--ah-line) !important;
    border-radius: 20px !important;
    background: var(--ah-paper) !important;
    margin-bottom: 8px !important;
}

.postal-meta div {
    padding: 12px !important;
}

.postal-meta dt {
    color: var(--ah-muted) !important;
    font-size: 0.68rem !important;
    font-weight: 950 !important;
}

.postal-meta dd {
    margin: 4px 0 0 !important;
    color: var(--ah-ink) !important;
    font-weight: 950 !important;
}

.postal-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
}

.postal-community {
    margin-top: 16px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.section-heading h2 {
    font-size: 2rem !important;
}

.postal-photo-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
}

.postal-photo img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 4 / 5 !important;
    object-fit: cover !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 22px !important;
    box-shadow: none !important;
}

/* Community dashboard */
.community-header {
    margin-bottom: 12px !important;
}

.wallet-panel {
    position: absolute !important;
    right: 0 !important;
    top: 18px !important;
    min-width: 104px !important;
    padding: 10px !important;
    text-align: center !important;
}

.wallet-panel span {
    color: var(--ah-muted) !important;
    font-size: 0.68rem !important;
    font-weight: 950 !important;
}

.wallet-panel strong,
.community-stats span {
    color: var(--ah-ink) !important;
    font-family: var(--ah-display) !important;
}

.community-stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 0 0 12px !important;
}

.leaderboard-list,
.achievement-grid,
.premium-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.community-stats article {
    padding: 12px !important;
    text-align: center !important;
}

.community-stats p {
    margin: 0 !important;
    color: var(--ah-muted) !important;
    font-size: 0.75rem !important;
}

.community-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
}

.community-panel {
    padding: 14px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 26px !important;
    background: var(--ah-card) !important;
    box-shadow: none !important;
    margin-bottom: 12px !important;
}

.panel-heading {
    display: grid !important;
    gap: 4px !important;
    margin-bottom: 20px !important;
}

.panel-heading h3 {
    font-size: 1.7rem !important;
}

.leaderboard-list li {
    display: grid !important;
    align-items: center !important;
    gap: 10px !important;
    grid-template-columns: 36px 1fr auto !important;
    border-bottom: 2px solid var(--ah-line) !important;
}

.rank,
.achievement-card span {
    display: inline-grid !important;
    place-items: center !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    border: 2px solid var(--ah-line) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

.achievement-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
}

.achievement-card {
    min-height: 138px !important;
    padding: 12px !important;
    opacity: 1 !important;
}

.achievement-card.is-unlocked {
    box-shadow: var(--ah-hard-shadow) !important;
}

.premium-list {
    display: grid !important;
    gap: 10px !important;
}

.premium-plan {
    display: grid !important;
    gap: 10px !important;
    padding: 12px !important;
}

/* Admin as wide monochrome control surface */
.admin-container {
    padding: 0 0 90px !important;
}

.admin-table-wrap {
    overflow-x: auto !important;
}

.admin-table,
.mini-table {
    width: 100% !important;
    border-collapse: collapse !important;
    background: var(--ah-paper) !important;
}

.admin-table th,
.admin-table td,
.mini-table th,
.mini-table td {
    padding: 12px !important;
    text-align: left !important;
    color: var(--ah-ink) !important;
}

.admin-table thead th,
.mini-table thead th {
    color: var(--ah-paper) !important;
}

.admin-actions,
.tarjetas-toolbar,
.admin-actions-cell,
.map-actions,
.map-search-row,
.modal-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    align-items: center !important;
}

.tarjeta-form-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 1.1fr) !important;
}

.tarjeta-form-card {
    display: grid !important;
    gap: 12px !important;
    padding: 18px !important;
}

.coordinate-grid,
.tarjetas-summary,
.metrics-grid,
.admin-nav {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    gap: 12px !important;
}

.tarjeta-map {
    min-height: 320px !important;
    border-radius: 26px !important;
    background: var(--ah-soft) !important;
}

.admin-postal-cell {
    display: grid !important;
    grid-template-columns: 66px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
}

.admin-postal-cell img,
.admin-image-preview {
    width: 66px !important;
    aspect-ratio: 4 / 3 !important;
    object-fit: cover !important;
    border-radius: 16px !important;
}

.admin-container > .admin-header {
    margin: 0 0 14px !important;
    padding: 22px !important;
}

.admin-header h1 {
    font-size: clamp(3rem, 8vw, 6rem) !important;
}

.admin-subtitle {
    color: var(--ah-ink) !important;
    font-weight: 850 !important;
}

.tarjetas-summary,
.metrics-grid,
.admin-nav,
.tarjeta-form-layout {
    gap: 12px !important;
}

.tarjetas-summary article,
.metric-card,
.admin-nav-link,
.tarjeta-form-card,
.admin-table-wrap {
    border: 2px solid var(--ah-line) !important;
    border-radius: 26px !important;
    background: var(--ah-paper) !important;
    box-shadow: none !important;
}

.admin-table thead {
    background: var(--ah-ink) !important;
    color: var(--ah-paper) !important;
}

.admin-table th,
.admin-table td {
    border-bottom: 2px solid var(--ah-line) !important;
}

.admin-table tbody tr:nth-child(even),
.admin-table tbody tr:hover {
    background: var(--ah-soft) !important;
}

.admin-postal-cell img,
.admin-image-preview,
.tarjeta-map {
    border: 2px solid var(--ah-line) !important;
    filter: grayscale(1) contrast(1.1) !important;
}

/* Camera */
body[data-page="camara"] {
    background: var(--ah-bg) !important;
}

.camera-container {
    position: fixed !important;
    z-index: 2000 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    inset: 0 !important;
    background: var(--ah-bg) !important;
    padding: max(16px, env(safe-area-inset-top)) 14px max(16px, env(safe-area-inset-bottom)) !important;
}

.camera-video {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
    pointer-events: none !important;
}


.camera-canvas {
    width: min(92vw, 430px) !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-screen) !important;
    background: var(--ah-paper) !important;
    box-shadow: var(--ah-shadow) !important;
}

.camera-controls {
    display: grid !important;
    gap: 10px !important;
    width: min(92vw, 430px) !important;
    grid-template-columns: 1fr 1fr !important;
}

#btn-capturar {
    grid-column: 1 / -1 !important;
    min-height: 62px !important;
}

#btn-cambiar-camara,
#btn-volver {
    min-height: 54px !important;
    padding: 0 14px !important;
    font-size: clamp(0.9rem, 3.8vw, 1rem) !important;
    line-height: 1.08 !important;
}

.spinner,
.capture-result {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2600 !important;
    display: grid !important;
    place-items: center !important;
    padding: 18px !important;
    background: rgba(217, 217, 215, 0.86) !important;
}

.spinner[style*="display: none"] {
    display: none !important;
}

.capture-result[hidden] {
    display: none !important;
}

.capture-result-card {
    display: grid !important;
    grid-template-columns: minmax(180px, 320px) minmax(180px, 1fr) !important;
    gap: 16px !important;
    width: min(92vw, 720px) !important;
    padding: 16px !important;
}

.capture-result-card img {
    width: 100% !important;
    aspect-ratio: 4 / 5 !important;
    object-fit: cover !important;
    border-radius: 24px !important;
}

.capture-result-actions {
    display: grid !important;
    align-content: center !important;
    gap: 10px !important;
}

.camera-toast {
    position: fixed !important;
    left: 50% !important;
    bottom: calc(20px + env(safe-area-inset-bottom)) !important;
    z-index: 3000 !important;
    max-width: min(92vw, 430px) !important;
    padding: 10px 14px !important;
    border-radius: var(--ah-radius-chip) !important;
    transform: translateX(-50%) !important;
}

.capture-result-card {
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-screen) !important;
    background: var(--ah-paper) !important;
}

.capture-result-card img {
    border: 2px solid var(--ah-line) !important;
}

.camera-toast {
    border: 2px solid var(--ah-line) !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

.navbar-bottom {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    bottom: calc(14px + env(safe-area-inset-bottom)) !important;
    z-index: 1500 !important;
    width: min(430px, calc(100% - 26px)) !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    transform: translateX(-50%) !important;
    box-shadow: none !important;
}

.btn-central {
    width: 100% !important;
    min-height: 58px !important;
    box-shadow: var(--ah-shadow) !important;
}

.empty-state {
    border: 2px dashed var(--ah-line) !important;
    border-radius: 22px !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

.modal-overlay,
.modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2600 !important;
    display: grid !important;
    place-items: center !important;
    padding: 18px !important;
    background: rgba(18, 18, 18, 0.42) !important;
}

.modal-container,
.modal-content {
    width: min(92vw, 520px) !important;
    padding: 20px !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: var(--ah-radius-screen) !important;
    background: var(--ah-paper) !important;
    box-shadow: var(--ah-shadow) !important;
}

@media (min-width: 900px) {
    body:not([data-page="admin"]) .container-lg,
    body:not([data-page="admin"]) .postal-page,
    body:not([data-page="admin"]) .comunidad-shell,
    body:not([data-page="admin"]) .app-navbar,
    body:not([data-page="admin"]) .navbar-bottom {
        max-width: 430px !important;
    }
}

@media (max-width: 520px) {
    .app-navbar,
    .container-lg,
    .postal-page,
    .comunidad-shell,
    .navbar-bottom {
        width: calc(100% - 22px) !important;
    }

    .album-section,
    .gallery-section,
    .comunidad-shell,
    .postal-page {
        border-radius: 30px !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .postal-meta,
    .community-stats,
    .achievement-grid,
    .postal-photo-grid,
    .tarjeta-form-layout,
    .capture-result-card {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   Polish pass: stable controls, clean modal behavior and tighter mobile layout.
   ============================================================ */

button,
.btn,
.btn-primary,
.btn-secondary,
.btn-small,
.mini-action,
.gallery-share,
.btn-central,
.btn-registrar,
.btn-saltarluego,
.modal-close,
.modal-close-button {
    position: relative !important;
    gap: 8px !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    min-height: 50px !important;
    padding: 0 18px !important;
    line-height: 1.08 !important;
    text-align: center !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    transition:
        transform 180ms ease,
        box-shadow 180ms ease,
        background-color 180ms ease,
        color 180ms ease,
        border-color 180ms ease !important;
}

button:hover:not(:disabled),
.btn:hover:not(:disabled),
.btn-primary:hover:not(:disabled),
.btn-secondary:hover:not(:disabled),
.btn-small:hover:not(:disabled),
.mini-action:hover,
.gallery-share:hover,
.btn-registrar:hover:not(:disabled),
.btn-saltarluego:hover:not(:disabled) {
    transform: translate(-3px, -3px) !important;
    box-shadow: 6px 6px 0 var(--ah-line) !important;
}

button:active:not(:disabled),
.btn:active:not(:disabled),
.btn-primary:active:not(:disabled),
.btn-secondary:active:not(:disabled),
.btn-small:active:not(:disabled),
.mini-action:active,
.gallery-share:active,
.btn-registrar:active:not(:disabled),
.btn-saltarluego:active:not(:disabled) {
    transform: translate(0, 0) !important;
    box-shadow: none !important;
}

button:disabled,
.btn:disabled,
.btn-central:disabled,
.is-muted {
    cursor: not-allowed !important;
}

button:disabled:hover,
.btn:disabled:hover,
.btn-central:disabled:hover,
.is-muted:hover {
    transform: none !important;
    box-shadow: none !important;
}

input,
textarea,
select {
    width: 100% !important;
    padding: 0 18px !important;
    line-height: 1.2 !important;
}

textarea {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
}

.nav-toggle {
    top: 6px !important;
    right: 2px !important;
    width: 52px !important;
    height: 52px !important;
    min-height: 52px !important;
    padding: 0 !important;
    overflow: hidden !important;
    box-shadow: none !important;
    display: inline-grid !important;
    place-content: center !important;
    gap: 5px !important;
    border: 2px solid var(--ah-line) !important;
    background: var(--ah-ink) !important;
}

.nav-toggle:hover:not(:disabled) {
    transform: translate(-2px, -2px) !important;
    box-shadow: 5px 5px 0 var(--ah-line) !important;
}

.nav-toggle span {
    display: block !important;
    width: 24px !important;
    height: 2px !important;
    margin: 0 !important;
    border-radius: 999px !important;
    background: currentColor !important;
    transform-origin: center !important;
    transition: width 160ms ease, transform 160ms ease, opacity 120ms ease !important;
}

.nav-toggle span:nth-child(1) {
    width: 20px !important;
    justify-self: start !important;
}

.nav-toggle span:nth-child(2) {
    width: 26px !important;
}

.nav-toggle span:nth-child(3) {
    width: 20px !important;
    justify-self: end !important;
}

body.nav-open .nav-toggle {
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

body.nav-open .nav-toggle span:nth-child(1) {
    width: 25px !important;
    transform: translateY(7px) rotate(45deg) !important;
}

body.nav-open .nav-toggle span:nth-child(2) {
    opacity: 0 !important;
    transform: scaleX(0.45) !important;
}

body.nav-open .nav-toggle span:nth-child(3) {
    width: 25px !important;
    transform: translateY(-7px) rotate(-45deg) !important;
}

.app-navbar {
    z-index: 3100 !important;
    margin-top: 10px !important;
}

.app-navbar-inner {
    min-height: 64px !important;
}

.app-brand-text {
    font-size: clamp(1.85rem, 7vw, 2.55rem) !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.app-nav-menu {
    top: 70px !important;
    right: 0 !important;
    z-index: 3200 !important;
    width: min(292px, calc(100vw - 34px)) !important;
    max-width: calc(100vw - 34px) !important;
    padding: 14px !important;
    border-width: 3px !important;
    border-radius: 28px !important;
    box-shadow: 10px 10px 0 var(--ah-line) !important;
}

body.nav-open .app-nav-menu {
    gap: 10px !important;
}

.app-nav-menu .nav-link {
    display: flex !important;
    min-height: 58px !important;
    padding: 0 20px !important;
    font-size: clamp(1.05rem, 5vw, 1.35rem) !important;
    line-height: 1.05 !important;
    text-align: center !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.app-nav-menu .nav-link:hover,
.app-nav-menu .nav-link:focus-visible {
    transform: translate(-2px, -2px) !important;
    box-shadow: 5px 5px 0 var(--ah-line) !important;
}

.album-section,
.gallery-section,
.comunidad-shell,
.postal-page {
    padding-top: 18px !important;
}

.album-header {
    min-height: 304px !important;
    padding-top: 84px !important;
    margin-bottom: 20px !important;
}

.album-header h2 {
    font-size: clamp(2.55rem, 12.8vw, 4.35rem) !important;
    line-height: 0.92 !important;
}

.album-intro {
    max-width: min(254px, 74vw) !important;
    margin-top: 14px !important;
    font-size: 0.96rem !important;
    line-height: 1.36 !important;
}

.album-progress {
    margin-top: 18px !important;
}

.album-grid {
    gap: 16px !important;
}

.tarjeta-container {
    gap: 10px !important;
}

.tarjeta-card {
    grid-template-columns: 112px minmax(0, 1fr) !important;
    grid-template-rows: auto 1fr !important;
    align-items: start !important;
    min-height: 214px !important;
    padding: 16px !important;
    gap: 12px 14px !important;
    border-width: 3px !important;
    border-radius: 24px !important;
}

.tarjeta-card .tarjeta-image {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    width: 112px !important;
    height: 134px !important;
    border-width: 3px !important;
    border-radius: 22px !important;
}

.tarjeta-status {
    position: static !important;
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: stretch !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    min-height: 38px !important;
    padding: 0 14px !important;
    font-size: clamp(0.76rem, 3.1vw, 0.9rem) !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.tarjeta-card-copy {
    grid-column: 2 !important;
    grid-row: 2 !important;
    align-self: start !important;
    gap: 8px !important;
    min-width: 0 !important;
    padding: 4px 0 0 !important;
}

.tarjeta-card-copy p {
    font-size: clamp(0.72rem, 3vw, 0.88rem) !important;
    line-height: 1.15 !important;
}

.tarjeta-card-copy h3 {
    max-width: 100% !important;
    font-size: clamp(1.75rem, 8.4vw, 2.55rem) !important;
    line-height: 0.96 !important;
    overflow-wrap: anywhere !important;
}

.tarjeta-actions {
    gap: 10px !important;
}

.tarjeta-actions .mini-action {
    min-height: 54px !important;
    padding: 0 14px !important;
    border-width: 3px !important;
    font-size: clamp(0.9rem, 3.7vw, 1rem) !important;
    line-height: 1.05 !important;
}

.tarjeta-actions .mini-action-map {
    border-color: var(--ah-accent-dark) !important;
    background: var(--ah-accent) !important;
    color: var(--ah-paper) !important;
}

.tarjeta-location-detail {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    min-height: 34px !important;
    padding: 0 8px 8px !important;
}

.tarjeta-location-detail strong,
.tarjeta-location-detail span {
    min-width: 0 !important;
    line-height: 1.12 !important;
}

.tarjeta-location-detail span {
    text-align: right !important;
}

.navbar-bottom {
    z-index: 2200 !important;
    width: min(430px, calc(100% - 28px)) !important;
}

.btn-central {
    min-height: 64px !important;
    padding: 0 24px !important;
    border-width: 3px !important;
    border-radius: 34px !important;
    font-size: clamp(0.96rem, 4.2vw, 1.15rem) !important;
    line-height: 1.08 !important;
}

.modal-overlay[style*="display: none"],
.modal-overlay[style*="display:none"],
.modal[style*="display: none"],
.modal[style*="display:none"] {
    display: none !important;
}

.modal-overlay,
.modal {
    place-items: center !important;
    padding: 18px !important;
}

.modal-container,
.modal-content {
    position: relative !important;
    display: grid !important;
    gap: 18px !important;
    width: min(92vw, 430px) !important;
    max-height: min(86dvh, 720px) !important;
    padding: clamp(22px, 6vw, 30px) !important;
    overflow: auto !important;
    border-width: 3px !important;
    border-radius: 32px !important;
}

.modal-header,
.modal-title-row {
    display: grid !important;
    gap: 8px !important;
    padding-right: 44px !important;
}

.modal-header h2,
.modal-title-row h2 {
    font-size: clamp(2rem, 9vw, 3.05rem) !important;
    line-height: 0.96 !important;
}

.modal-header p,
.modal-title-row p {
    max-width: 30rem !important;
    font-size: clamp(0.95rem, 3.8vw, 1.08rem) !important;
    line-height: 1.35 !important;
}

.modal-close,
.modal-close-button {
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    border-width: 2px !important;
    border-radius: 50% !important;
    font-size: 0 !important;
}

.modal-close::before,
.modal-close-button::before {
    content: "x";
    font-size: 1.05rem;
    line-height: 1;
}

.form-registro,
.modal form {
    display: grid !important;
    gap: 14px !important;
    margin: 0 !important;
}

.form-group {
    display: grid !important;
    gap: 8px !important;
    margin: 0 !important;
}

.form-group label {
    display: block !important;
    padding: 0 4px !important;
    color: var(--ah-ink) !important;
    font-size: 0.92rem !important;
    font-weight: 950 !important;
    line-height: 1.1 !important;
}

.form-registro input {
    min-height: 58px !important;
    font-size: 1rem !important;
}

.form-registro .btn-registrar,
.form-registro .btn-saltarluego {
    width: 100% !important;
    min-height: 58px !important;
    border-width: 3px !important;
    font-size: clamp(0.96rem, 4vw, 1.08rem) !important;
}

.form-registro .btn-saltarluego {
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
}

.modal-actions {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
    gap: 10px !important;
}

@media (min-width: 390px) {
    .form-registro {
        grid-template-columns: 1fr 1fr !important;
    }

    .form-registro .form-group {
        grid-column: 1 / -1 !important;
    }
}

@media (max-width: 420px) {
    .app-nav-menu {
        right: 0 !important;
        width: min(272px, calc(100vw - 28px)) !important;
        padding: 12px !important;
    }

    .tarjeta-card {
        grid-template-columns: 104px minmax(0, 1fr) !important;
        min-height: 202px !important;
        padding: 14px !important;
    }

    .tarjeta-card .tarjeta-image {
        width: 104px !important;
        height: 126px !important;
    }

    .album-header h2 {
        max-width: 230px !important;
    }
}

@media (max-width: 360px) {
    .tarjeta-actions {
        grid-template-columns: 1fr !important;
    }

    .tarjeta-card {
        grid-template-columns: 92px minmax(0, 1fr) !important;
    }

    .tarjeta-card .tarjeta-image {
        width: 92px !important;
        height: 116px !important;
    }
}

body[data-page="galeria"] .gallery-section {
    padding-top: 22px !important;
}

body[data-page="galeria"] .gallery-header {
    min-height: auto !important;
    align-content: start !important;
    gap: 14px !important;
    margin: 0 0 22px !important;
    padding: 74px 0 0 !important;
}

body[data-page="galeria"] .gallery-header h2 {
    max-width: 100% !important;
    font-size: clamp(2.65rem, 12.4vw, 4.55rem) !important;
    line-height: 0.94 !important;
}

body[data-page="galeria"] .gallery-intro {
    max-width: 330px !important;
    margin: 0 !important;
    font-size: clamp(0.98rem, 4.2vw, 1.18rem) !important;
    line-height: 1.35 !important;
}

body[data-page="galeria"] .gallery-grid {
    gap: 22px !important;
}

body[data-page="galeria"] .gallery-item {
    display: grid !important;
    grid-template-rows: auto auto !important;
    min-height: 0 !important;
    padding: 14px !important;
    overflow: visible !important;
    border-width: 3px !important;
    border-radius: 28px !important;
}

body[data-page="galeria"] .gallery-image {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 5 !important;
    margin: 0 !important;
    border-width: 3px !important;
    border-radius: 24px !important;
    object-fit: cover !important;
}

body[data-page="galeria"] .gallery-overlay {
    position: static !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 9px 10px !important;
    align-items: center !important;
    margin: 12px 0 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
}

body[data-page="galeria"] .gallery-overlay h3 {
    grid-column: 1 / -1 !important;
    margin: 0 !important;
    font-size: clamp(1.65rem, 7.4vw, 2.35rem) !important;
    line-height: 0.98 !important;
    overflow-wrap: anywhere !important;
}

body[data-page="galeria"] .gallery-autor,
body[data-page="galeria"] .gallery-fecha {
    display: block !important;
    min-width: 0 !important;
    color: var(--ah-muted) !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
    line-height: 1.15 !important;
}

body[data-page="galeria"] .gallery-fecha {
    text-align: right !important;
}

body[data-page="galeria"] .gallery-share {
    min-height: 54px !important;
    padding: 0 14px !important;
    border-width: 3px !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    line-height: 1.06 !important;
}

.gallery-loader {
    display: grid !important;
    place-items: center !important;
    gap: 10px !important;
    min-height: 82px !important;
    margin: 22px 0 0 !important;
    padding: 18px !important;
    border: 3px dashed var(--ah-line) !important;
    border-radius: 24px !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    text-align: center !important;
    font-weight: 950 !important;
}

.gallery-loader[hidden] {
    display: none !important;
}

.gallery-loader .spinner-small {
    width: 28px !important;
    height: 28px !important;
    background: transparent !important;
    border: 3px solid var(--ah-mid) !important;
    border-top-color: var(--ah-line) !important;
    border-radius: 50% !important;
    animation: spin 780ms linear infinite !important;
}

.gallery-loader[data-state="idle"] .spinner-small,
.gallery-loader[data-state="done"] .spinner-small,
.gallery-loader[data-state="error"] .spinner-small {
    display: none !important;
}

.gallery-loader[data-state="error"] {
    cursor: pointer !important;
    border-style: solid !important;
}

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

@media (max-width: 380px) {
    body[data-page="galeria"] .gallery-overlay,
    body[data-page="galeria"] .gallery-share {
        grid-column: 1 / -1 !important;
    }

    body[data-page="galeria"] .gallery-fecha {
        text-align: left !important;
    }
}

/* Red accent layer and refined postal detail page. */
:root {
    --ah-accent: #ad4039;
    --ah-accent-dark: #7f2d28;
    --ah-accent-soft: #f4dedb;
    --ah-accent-wash: rgba(173, 64, 57, 0.12);
}

.app-brand-text span,
.eyebrow,
.gallery-intro strong,
.community-stats span,
.postal-meta dd,
.tarjeta-location-detail span[data-distance-label] {
    color: var(--ah-accent) !important;
}

.eyebrow {
    border-color: var(--ah-accent-dark) !important;
    background: var(--ah-accent-soft) !important;
}

.btn:hover:not(:disabled),
.btn-primary:hover:not(:disabled),
.btn-small:hover:not(:disabled),
.mini-action:hover,
.gallery-share:hover {
    border-color: var(--ah-accent-dark) !important;
    box-shadow: 6px 6px 0 var(--ah-accent-dark) !important;
}

input:focus,
textarea:focus,
select:focus {
    box-shadow: 0 0 0 5px var(--ah-accent-wash) !important;
}

.album-progress i,
.gallery-loader .spinner-small,
.postal-photo-loader .spinner-small {
    background: var(--ah-accent) !important;
}

body[data-page="postal"] .postal-page {
    padding-top: 22px !important;
}

body[data-page="postal"] .postal-hero {
    padding-bottom: 34px !important;
}

body[data-page="postal"] .postal-hero-grid {
    gap: 22px !important;
}

body[data-page="postal"] .postal-main-image {
    border-width: 3px !important;
    border-radius: 30px !important;
}

body[data-page="postal"] .postal-main-image figcaption {
    border-color: var(--ah-accent-dark) !important;
    background: var(--ah-accent-soft) !important;
}

body[data-page="postal"] .postal-copy {
    gap: 18px !important;
}

body[data-page="postal"] .postal-copy h1 {
    font-size: clamp(2.7rem, 13vw, 4.5rem) !important;
    line-height: 0.94 !important;
}

body[data-page="postal"] .postal-copy .lead {
    max-width: 34rem !important;
    font-size: clamp(1.02rem, 4vw, 1.2rem) !important;
    line-height: 1.42 !important;
}

body[data-page="postal"] .postal-meta {
    gap: 10px !important;
}

body[data-page="postal"] .postal-meta div {
    border-width: 3px !important;
    background:
        linear-gradient(135deg, rgba(244, 222, 219, 0.72), transparent 42%),
        var(--ah-paper) !important;
}

body[data-page="postal"] .postal-actions {
    gap: 10px !important;
}

body[data-page="postal"] .btn-map {
    border-color: var(--ah-accent-dark) !important;
    background: var(--ah-accent) !important;
    color: var(--ah-paper) !important;
}

body[data-page="postal"] .postal-community {
    position: relative !important;
    margin-top: 10px !important;
    padding-top: 54px !important;
}

body[data-page="postal"] .section-heading {
    display: grid !important;
    gap: 12px !important;
    margin-bottom: 22px !important;
}

body[data-page="postal"] .section-heading h2 {
    max-width: 360px !important;
    font-size: clamp(2.1rem, 9vw, 3.15rem) !important;
    line-height: 0.96 !important;
}

body[data-page="postal"] .postal-photo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
}

body[data-page="postal"] .postal-photo {
    display: grid !important;
    gap: 8px !important;
    min-width: 0 !important;
}

body[data-page="postal"] .postal-photo a {
    display: block !important;
    min-width: 0 !important;
}

body[data-page="postal"] .postal-photo img {
    border-width: 3px !important;
    border-radius: 22px !important;
}

body[data-page="postal"] .postal-photo div {
    display: grid !important;
    gap: 2px !important;
    min-width: 0 !important;
    padding: 0 4px !important;
}

body[data-page="postal"] .postal-photo strong,
body[data-page="postal"] .postal-photo time {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-page="postal"] .postal-photo strong {
    color: var(--ah-ink) !important;
    font-size: 0.86rem !important;
    font-weight: 950 !important;
}

body[data-page="postal"] .postal-photo time {
    color: var(--ah-accent) !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
}

.postal-photo-loader {
    display: grid !important;
    place-items: center !important;
    gap: 10px !important;
    min-height: 78px !important;
    margin: 24px 0 0 !important;
    padding: 16px !important;
    border: 3px dashed var(--ah-accent-dark) !important;
    border-radius: 24px !important;
    background: var(--ah-accent-soft) !important;
    color: var(--ah-ink) !important;
    text-align: center !important;
    font-weight: 950 !important;
}

.postal-photo-loader .spinner-small {
    width: 26px !important;
    height: 26px !important;
    background: transparent !important;
    border: 3px solid rgba(173, 64, 57, 0.28) !important;
    border-top-color: var(--ah-accent-dark) !important;
    border-radius: 50% !important;
    animation: spin 780ms linear infinite !important;
}

.postal-photo-loader[data-state="idle"] .spinner-small,
.postal-photo-loader[data-state="done"] .spinner-small,
.postal-photo-loader[data-state="error"] .spinner-small {
    display: none !important;
}

.postal-photo-loader[data-state="error"] {
    cursor: pointer !important;
    border-style: solid !important;
}

@media (max-width: 360px) {
    body[data-page="postal"] .postal-photo-grid {
        gap: 10px !important;
    }

    body[data-page="postal"] .postal-photo strong {
        font-size: 0.78rem !important;
    }
}

/* Album split: captured first, pending ordered by proximity. */
.album-list-section {
    display: grid !important;
    gap: 14px !important;
}

.album-list-section + .album-list-section {
    margin: 14px auto !important;
    padding: 8px 0px !important;
    border-top: 3px solid var(--ah-line) !important;
}

.album-section-heading {
    display: flex !important;
    align-items: end !important;
    justify-content: space-between !important;
    gap: 14px !important;
}

.album-section-heading > div {
    display: grid !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.album-section-heading h3 {
    font-size: clamp(1.75rem, 8vw, 2.7rem) !important;
    line-height: 0.96 !important;
}

.album-section-heading > span {
    display: inline-grid !important;
    place-items: center !important;
    min-width: 48px !important;
    height: 48px !important;
    padding: 0 12px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 50% !important;
    background: var(--ah-paper) !important;
    color: var(--ah-accent) !important;
    font-weight: 950 !important;
}

.album-section-note {
    margin: -6px 0 0 !important;
    color: var(--ah-muted) !important;
    font-size: 0.86rem !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
}

.album-list-captured .tarjeta-status {
    border-color: var(--ah-accent-dark) !important;
    background: var(--ah-accent-soft) !important;
}

.album-list-pending .tarjeta-slot {
    transition: transform 220ms ease, opacity 220ms ease !important;
}

/* Admin protection and layout polish. */
body[data-page="admin-login"] main.app-content {
    min-height: 100dvh !important;
    height: auto !important;
    display: grid !important;
    place-items: center !important;
    padding: 22px !important;
}

.admin-login-shell {
    width: min(440px, 100%) !important;
}

.admin-login-card {
    display: grid !important;
    gap: 18px !important;
    padding: clamp(24px, 7vw, 34px) !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 32px !important;
    background: var(--ah-paper) !important;
    box-shadow: var(--ah-shadow) !important;
}

.admin-login-card h1 {
    font-size: clamp(2.6rem, 13vw, 4.4rem) !important;
    line-height: 0.94 !important;
}

.admin-login-card p {
    color: var(--ah-ink) !important;
    font-weight: 850 !important;
}

.admin-login-form {
    display: grid !important;
    gap: 14px !important;
}

body[data-page="admin"] main.app-content {
    height: auto !important;
    min-height: calc(100dvh - 82px) !important;
    overflow: visible !important;
    padding-bottom: 56px !important;
}

body[data-page="admin"] .admin-container {
    display: grid !important;
    gap: 24px !important;
    width: min(1160px, calc(100% - 28px)) !important;
    max-width: 1160px !important;
    padding: 12px 0 80px !important;
}

body[data-page="admin"] .admin-container > .admin-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin: 0 !important;
    padding: 24px !important;
    border-width: 3px !important;
    background:
        linear-gradient(135deg, var(--ah-accent-wash), transparent 42%),
        var(--ah-paper) !important;
}

body[data-page="admin"] .admin-header h1 {
    max-width: 780px !important;
    font-size: clamp(2.35rem, 6vw, 4.9rem) !important;
    line-height: 0.94 !important;
}

body[data-page="admin"] .admin-subtitle {
    max-width: 680px !important;
    margin-top: 10px !important;
    color: var(--ah-muted) !important;
    font-size: 1rem !important;
    line-height: 1.35 !important;
}

.admin-logout-form {
    flex: 0 0 auto !important;
}

.admin-sections,
.recent-activity,
.system-logs,
.metrics-grid,
.tarjetas-summary {
    margin: 0 !important;
}

body[data-page="admin"] .metrics-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
    gap: 16px !important;
}

body[data-page="admin"] .metric-card {
    display: grid !important;
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    min-height: 158px !important;
    padding: 20px !important;
    border-width: 3px !important;
    border-radius: 24px !important;
}

body[data-page="admin"] .metric-icon,
body[data-page="admin"] .nav-icon {
    display: grid !important;
    place-items: center !important;
    width: 48px !important;
    height: 48px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 50% !important;
    background: var(--ah-accent-soft) !important;
    color: var(--ah-accent-dark) !important;
    font-size: 0 !important;
}

body[data-page="admin"] .metric-content,
body[data-page="admin"] .metric-card,
body[data-page="admin"] .admin-nav-link {
    min-width: 0 !important;
}

body[data-page="admin"] .metric-content h3 {
    margin: 0 !important;
    font-family: var(--ah-ui) !important;
    font-size: 0.88rem !important;
    font-weight: 950 !important;
    line-height: 1.1 !important;
    text-transform: uppercase !important;
}

body[data-page="admin"] .metric-value {
    margin: 10px 0 4px !important;
    color: var(--ah-ink) !important;
    font-family: var(--ah-display) !important;
    font-size: clamp(2.2rem, 5vw, 3.2rem) !important;
    font-weight: 900 !important;
    line-height: 0.9 !important;
}

body[data-page="admin"] .metric-detail {
    color: var(--ah-muted) !important;
    font-size: 0.9rem !important;
    line-height: 1.3 !important;
}

body[data-page="admin"] .admin-nav {
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
    gap: 16px !important;
}

body[data-page="admin"] .admin-nav-link {
    display: grid !important;
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: center !important;
    min-height: 96px !important;
    padding: 18px !important;
    border-width: 3px !important;
    border-radius: 24px !important;
}

body[data-page="admin"] .nav-label {
    color: var(--ah-ink) !important;
    font-weight: 950 !important;
    line-height: 1.12 !important;
}

.recent-activity,
.system-logs {
    display: grid !important;
    gap: 14px !important;
    padding: 20px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 26px !important;
    background: var(--ah-paper) !important;
}

.recent-activity h2,
.system-logs h2 {
    font-size: clamp(1.55rem, 4vw, 2.25rem) !important;
    line-height: 1 !important;
}

.activity-table,
.logs-table,
body[data-page="admin"] .admin-table {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    overflow: hidden !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 20px !important;
    background: var(--ah-paper) !important;
}

.activity-table th,
.activity-table td,
.logs-table th,
.logs-table td,
body[data-page="admin"] .admin-table th,
body[data-page="admin"] .admin-table td {
    padding: 14px 16px !important;
    border-bottom: 2px solid rgba(18, 18, 18, 0.12) !important;
    vertical-align: top !important;
}

.activity-table thead th,
.logs-table thead th,
body[data-page="admin"] .admin-table thead th {
    background: var(--ah-ink) !important;
    color: var(--ah-paper) !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
}

.activity-table tbody tr:last-child td,
.logs-table tbody tr:last-child td,
body[data-page="admin"] .admin-table tbody tr:last-child td {
    border-bottom: 0 !important;
}

body[data-page="admin"] .admin-table-wrap {
    padding: 14px !important;
    border-width: 3px !important;
    border-radius: 26px !important;
}

.admin-alert {
    padding: 14px 16px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 20px !important;
    background: var(--ah-accent-soft) !important;
    color: var(--ah-ink) !important;
    font-weight: 900 !important;
}

.admin-alert-error {
    border-color: var(--ah-accent-dark) !important;
}

@media (max-width: 720px) {
    body[data-page="admin"] .admin-container > .admin-header {
        display: grid !important;
        align-items: start !important;
    }

    .admin-logout-form,
    .admin-logout-form .btn {
        width: 100% !important;
    }
}

/* Postal medium screens: avoid the narrow phone column and keep content balanced. */
@media (min-width: 680px) {
    body[data-page="postal"] .app-navbar,
    body[data-page="postal"] .postal-page {
        width: min(920px, calc(100% - 48px)) !important;
        max-width: 920px !important;
    }

    body[data-page="postal"] .postal-page {
        overflow: visible !important;
        padding: 26px 28px 90px !important;
    }

    body[data-page="postal"] .postal-hero-grid {
        grid-template-columns: minmax(280px, 0.92fr) minmax(320px, 1.08fr) !important;
        gap: clamp(24px, 4vw, 42px) !important;
        align-items: start !important;
    }

    body[data-page="postal"] .postal-main-image {
        position: sticky !important;
        top: 92px !important;
        max-height: min(720px, calc(100dvh - 130px)) !important;
    }

    body[data-page="postal"] .postal-copy {
        min-width: 0 !important;
        align-content: start !important;
        padding-top: 4px !important;
    }

    body[data-page="postal"] .postal-copy h1 {
        max-width: 100% !important;
        font-size: clamp(3rem, 5.6vw, 5rem) !important;
        overflow-wrap: anywhere !important;
    }

    body[data-page="postal"] .postal-copy p {
        max-width: 100% !important;
        overflow-wrap: anywhere !important;
    }

    body[data-page="postal"] .postal-meta {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body[data-page="postal"] .postal-meta div {
        min-width: 0 !important;
    }

    body[data-page="postal"] .postal-meta dd {
        overflow-wrap: anywhere !important;
        font-size: clamp(1rem, 2.2vw, 1.25rem) !important;
        line-height: 1.08 !important;
    }

    body[data-page="postal"] .postal-actions {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    }

    body[data-page="postal"] .postal-community {
        margin-top: 14px !important;
        padding-top: 14px !important;
    }

    body[data-page="postal"] .postal-photo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 18px !important;
    }
}

@media (min-width: 680px) and (max-width: 860px) {
    body[data-page="postal"] .postal-page {
        width: min(760px, calc(100% - 36px)) !important;
        max-width: 760px !important;
    }

    body[data-page="postal"] .postal-hero-grid {
        grid-template-columns: minmax(240px, 0.86fr) minmax(300px, 1.14fr) !important;
        gap: 24px !important;
    }

    body[data-page="postal"] .postal-copy h1 {
        font-size: clamp(2.6rem, 5.7vw, 4rem) !important;
    }

    body[data-page="postal"] .postal-copy .lead {
        font-size: clamp(0.96rem, 2.4vw, 1.1rem) !important;
    }
}

@media (min-width: 1080px) {
    body[data-page="postal"] .app-navbar,
    body[data-page="postal"] .postal-page {
        width: min(1040px, calc(100% - 72px)) !important;
        max-width: 1040px !important;
    }
}

/* Public responsive layout: one width system for album, postal, capture, gallery and community. */
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .app-navbar,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .container-lg,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .postal-page,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .comunidad-shell {
    width: min(var(--ah-public-shell-max), calc(100% - var(--ah-public-shell-gap))) !important;
    max-width: var(--ah-public-shell-max) !important;
}

.album-section,
.gallery-section,
.comunidad-shell,
.postal-page {
    padding: clamp(18px, 3vw, 34px) !important;
    overflow: visible !important;
}

body[data-page="album"] .album-section {
    padding-bottom: 10px !important;
}

body[data-page="postal"] .postal-page,
body[data-page="captura"] .postal-page,
body[data-page="galeria"] .gallery-section,
body[data-page="comunidad"] .comunidad-shell {
    min-height: calc(100dvh - 116px) !important;
}

body[data-page="captura"] .postal-page,
body[data-page="captura"] .postal-hero,
body[data-page="captura"] .postal-copy {
    display: grid !important;
    gap: clamp(16px, 2.4vw, 28px) !important;
}

body[data-page="captura"] .postal-main-image {
    border-width: 3px !important;
    border-radius: 30px !important;
}

body[data-page="comunidad"] .comunidad-shell {
    display: grid !important;
    gap: clamp(16px, 2.6vw, 28px) !important;
}

body[data-page="comunidad"] .comunidad-shell > br {
    display: none !important;
}

body[data-page="comunidad"] .community-header {
    position: relative !important;
    min-height: auto !important;
    align-content: start !important;
    gap: 16px !important;
    margin: 0 !important;
    padding: 74px 0 0 !important;
}

body[data-page="comunidad"] .wallet-panel {
    top: 0 !important;
}

body[data-page="comunidad"] .community-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin: 0 !important;
}

body[data-page="comunidad"] .community-grid {
    gap: clamp(14px, 2vw, 22px) !important;
}

body[data-page="comunidad"] .achievement-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), 1fr)) !important;
}

body[data-page="comunidad"] .premium-plan {
    align-items: center !important;
}

@media (min-width: 680px) {
    .album-section,
    .gallery-section,
    .comunidad-shell,
    .postal-page {
        border-width: 3px !important;
    }

    body[data-page="album"] .album-grid {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
        gap: 18px !important;
    }

    body[data-page="album"] .album-header,
    body[data-page="galeria"] .gallery-header,
    body[data-page="comunidad"] .community-header {
        min-height: auto !important;
        padding-top: 28px !important;
    }

    body[data-page="album"] .album-header h2,
    body[data-page="galeria"] .gallery-header h2,
    body[data-page="comunidad"] .community-header h2 {
        max-width: min(720px, 74%) !important;
        font-size: clamp(3.8rem, 7.2vw, 6.4rem) !important;
    }

    body[data-page="album"] .album-intro,
    body[data-page="galeria"] .gallery-intro,
    body[data-page="comunidad"] .community-intro {
        max-width: 42rem !important;
        font-size: clamp(1rem, 1.8vw, 1.22rem) !important;
    }

    body[data-page="galeria"] .gallery-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
        gap: 22px !important;
    }

    body[data-page="postal"] .postal-hero-grid,
    body[data-page="captura"] .postal-hero-grid {
        grid-template-columns: minmax(280px, 0.94fr) minmax(320px, 1.06fr) !important;
        gap: clamp(24px, 4vw, 48px) !important;
        align-items: start !important;
    }

    body[data-page="postal"] .postal-main-image,
    body[data-page="captura"] .postal-main-image {
        position: sticky !important;
        top: 92px !important;
        max-height: min(720px, calc(100dvh - 130px)) !important;
    }

    body[data-page="postal"] .postal-actions,
    body[data-page="captura"] .postal-actions {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    }

    body[data-page="postal"] .postal-photo-grid {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
        gap: 18px !important;
    }

    body[data-page="comunidad"] .community-header {
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: start !important;
        padding-top: 28px !important;
    }

    body[data-page="comunidad"] .wallet-panel {
        position: static !important;
        justify-self: end !important;
        min-width: 150px !important;
    }

    body[data-page="comunidad"] .community-stats {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }

    body[data-page="comunidad"] .community-grid {
        grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr) !important;
    }

    body[data-page="comunidad"] .premium-plan {
        grid-template-columns: minmax(0, 1fr) auto !important;
    }
}

@media (min-width: 1080px) {
    body[data-page="postal"] .postal-hero-grid,
    body[data-page="captura"] .postal-hero-grid {
        grid-template-columns: minmax(340px, 0.9fr) minmax(420px, 1.1fr) !important;
    }
}

/* Admin pages need normal document scrolling, unlike the app-like mobile views. */
body[data-page="admin"],
body[data-page="admin-login"] {
    height: auto !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    scrollbar-gutter: stable !important;
}

body[data-page="admin"] main.app-content {
    height: auto !important;
    min-height: calc(100dvh - 82px) !important;
    overflow: visible !important;
    padding-bottom: 96px !important;
}

body[data-page="admin"] .admin-container {
    padding-bottom: 120px !important;
}

/* Album capture action: exclusive red zone, separated from page content. */
body[data-page="album"] .album-section {
    margin-bottom: 20px !important;
}

body[data-page="album"] .navbar-bottom.capture-zone {
    display: grid !important;
    justify-items: center !important;
    width: 100% !important;
    min-width: 320px;
    padding: 12px var(--ah-public-shell-gutter) calc(12px + env(safe-area-inset-bottom)) !important;
    bottom: 0 !important;
    background-color: rgba(255, 255, 255, 1) !important;
    border-top: 3px solid #c33f36 !important;
}

body[data-page="album"] .btn-central {
    position: relative !important;
    z-index: 1 !important;
    width: min(var(--ah-public-shell-max), calc(100vw - var(--ah-public-shell-gap))) !important;
    min-height: 70px !important;
    padding: 0 24px !important;
    border: 4px solid #c33f36 !important;
    border-radius: 24px !important;
    background: var(--ah-accent) !important;
    color: var(--ah-paper) !important;
    box-shadow: 6px 6px 0 var(--ah-line) !important;
    font-size: clamp(1.03rem, 4.4vw, 1.22rem) !important;
    font-weight: 950 !important;
}

body[data-page="album"] .btn-central.is-ready,
body[data-page="album"] .btn-central:not(:disabled) {
    background: #c33f36 !important;
    color: var(--ah-paper) !important;
    cursor: pointer !important;
}

body[data-page="album"] .btn-central.is-waiting,
body[data-page="album"] .btn-central:disabled {
    background: var(--ah-accent-soft) !important;
    color: var(--ah-accent-dark) !important;
    border: 4px solid var(--ah-accent-dark) !important;
    opacity: 1 !important;
    box-shadow: none !important;
}

body[data-page="album"] .btn-central.is-ready:hover,
body[data-page="album"] .btn-central:not(:disabled):hover {
    transform: translate(-3px, -3px) !important;
    box-shadow: 10px 10px 0 var(--ah-line) !important;
}

/* Public spacing polish: album reference, calmer scale and readable cards. */
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .app-navbar,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .container-lg,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .postal-page,
body:not([data-page="admin"]):not([data-page="admin-login"]):not([data-page="camara"]) .comunidad-shell {
    width: min(var(--ah-public-shell-max), calc(100% - var(--ah-public-shell-gap))) !important;
    max-width: var(--ah-public-shell-max) !important;
}

.album-section,
.gallery-section,
.comunidad-shell,
.postal-page {
    padding: clamp(24px, 4.2vw, 48px) !important;
    border-radius: clamp(22px, 3vw, 34px) !important;
}

body[data-page="album"] .album-section {
    padding-bottom: clamp(20px, 12vw, 20px) !important;
}

.album-header,
body[data-page="galeria"] .gallery-header,
body[data-page="comunidad"] .community-header {
    min-height: auto !important;
    margin-bottom: clamp(28px, 4vw, 44px) !important;
    padding-top: clamp(18px, 3vw, 34px) !important;
}

.album-header h2,
body[data-page="galeria"] .gallery-header h2,
body[data-page="comunidad"] .community-header h2 {
    max-width: min(620px, 78%) !important;
    font-size: clamp(2.55rem, 7vw, 4.7rem) !important;
    line-height: 0.94 !important;
}

.album-intro,
body[data-page="galeria"] .gallery-intro,
body[data-page="comunidad"] .community-intro {
    max-width: 40rem !important;
    font-size: clamp(0.98rem, 1.75vw, 1.14rem) !important;
    line-height: 1.48 !important;
}

.album-progress {
    margin-top: clamp(18px, 3vw, 28px) !important;
}

.album-list-section,
body[data-page="postal"] .postal-community {
    gap: clamp(16px, 2.4vw, 24px) !important;
}

.album-list-section + .album-list-section {
    margin-top: clamp(38px, 5vw, 58px) !important;
    padding-top: clamp(30px, 4vw, 44px) !important;
}

.album-section-heading h3,
body[data-page="postal"] .section-heading h2,
.panel-heading h3 {
    font-size: clamp(1.65rem, 4.2vw, 2.55rem) !important;
    line-height: 1.02 !important;
}

.album-grid {
    grid-template-columns: 1fr !important;
    gap: clamp(18px, 2.6vw, 26px) !important;
}

.tarjeta-card {
    grid-template-columns: clamp(92px, 26vw, 118px) minmax(0, 1fr) !important;
    min-height: 0 !important;
    padding: clamp(14px, 2.6vw, 20px) !important;
    gap: 12px clamp(14px, 2.4vw, 20px) !important;
}

.tarjeta-card .tarjeta-image {
    width: clamp(92px, 26vw, 118px) !important;
    height: clamp(112px, 31vw, 140px) !important;
}

.tarjeta-status {
    min-height: 34px !important;
    font-size: clamp(0.72rem, 1.8vw, 0.84rem) !important;
}

.tarjeta-card-copy h3,
body[data-page="galeria"] .gallery-overlay h3,
body[data-page="postal"] .postal-copy h1,
body[data-page="captura"] .postal-copy h1 {
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: auto !important;
}

.tarjeta-card-copy h3 {
    font-size: clamp(1.35rem, 4.4vw, 1.95rem) !important;
    line-height: 1.04 !important;
}

.tarjeta-card-copy p {
    font-size: clamp(0.72rem, 1.8vw, 0.84rem) !important;
}

.tarjeta-actions {
    gap: 10px !important;
}

.tarjeta-actions .mini-action,
body[data-page="galeria"] .gallery-share,
.postal-actions .btn,
.premium-plan button,
.share-panel .btn {
    min-height: 48px !important;
    font-size: clamp(0.86rem, 1.8vw, 0.98rem) !important;
    line-height: 1.1 !important;
}

body[data-page="galeria"] .gallery-grid,
body[data-page="postal"] .postal-photo-grid {
    gap: clamp(18px, 2.6vw, 28px) !important;
}

body[data-page="galeria"] .gallery-item,
.community-panel,
.premium-plan,
.achievement-card,
.postal-meta div,
body[data-page="postal"] .postal-photo img {
    border-radius: 22px !important;
}

body[data-page="postal"] .postal-copy h1,
body[data-page="captura"] .postal-copy h1 {
    font-size: clamp(2.35rem, 6vw, 4.2rem) !important;
    line-height: 0.98 !important;
}

body[data-page="postal"] .postal-copy .lead,
body[data-page="captura"] .postal-copy .lead {
    font-size: clamp(1rem, 1.8vw, 1.16rem) !important;
    line-height: 1.5 !important;
}

body[data-page="comunidad"] .community-stats,
body[data-page="comunidad"] .community-grid,
body[data-page="comunidad"] .premium-list {
    gap: clamp(14px, 2.2vw, 24px) !important;
}

body[data-page="album"] .navbar-bottom.capture-zone {
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    padding: 14px var(--ah-public-shell-gutter) calc(14px + env(safe-area-inset-bottom)) !important;
    max-width: none !important;
    background-color: rgba(255, 255, 255, 1) !important;
    border-top: 0 !important;
}

body[data-page="album"] .btn-central {
    width: min(100%, var(--ah-public-shell-max)) !important;
    min-height: 58px !important;
    border-radius: 18px !important;
    font-size: clamp(0.9rem, 2vw, 1.04rem) !important;
}

@media (min-width: 680px) {
    body[data-page="album"] .album-grid,
    body[data-page="galeria"] .gallery-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)) !important;
    }

    body[data-page="postal"] .postal-hero-grid,
    body[data-page="captura"] .postal-hero-grid {
        grid-template-columns: minmax(260px, 0.9fr) minmax(320px, 1.1fr) !important;
        gap: clamp(28px, 4vw, 46px) !important;
    }

    body[data-page="postal"] .postal-photo-grid {
        grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
    }
}

@media (min-width: 900px) {
    body[data-page="album"] .album-grid {
        grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)) !important;
    }

    body[data-page="comunidad"] .community-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    }
}

@media (max-width: 520px) {
    .album-section,
    .gallery-section,
    .comunidad-shell,
    .postal-page {
        padding: 22px 16px !important;
    }

    body[data-page="album"] .album-section {
        padding-bottom: 20px !important;
    }

    .album-header h2,
    body[data-page="galeria"] .gallery-header h2,
    body[data-page="comunidad"] .community-header h2 {
        max-width: min(270px, 78vw) !important;
    }
}

/* Community rewards: simple earn, redeem and apply flow. */
body[data-page="comunidad"] .comunidad-shell {
    gap: clamp(18px, 3vw, 30px) !important;
}

body[data-page="comunidad"] .community-header {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 18px !important;
    padding-top: 24px !important;
}

body[data-page="comunidad"] .community-header h2 {
    max-width: 100% !important;
    font-size: clamp(2.65rem, 8vw, 5rem) !important;
}

body[data-page="comunidad"] .wallet-panel {
    position: static !important;
    justify-self: stretch !important;
    display: grid !important;
    gap: 6px !important;
    min-width: 0 !important;
    padding: 16px !important;
    border-width: 3px !important;
    text-align: left !important;
}

body[data-page="comunidad"] .wallet-panel strong {
    font-size: clamp(2.4rem, 8vw, 4rem) !important;
    line-height: 0.95 !important;
}

body[data-page="comunidad"] .wallet-panel p,
.reward-summary-card p,
.reward-steps p,
.premium-plan small,
.achievement-card small,
.leaderboard-list small {
    color: var(--ah-muted) !important;
    font-size: 0.86rem !important;
    font-weight: 850 !important;
    line-height: 1.32 !important;
}

.reward-summary,
.reward-steps {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
}

.reward-summary-card,
.reward-steps article {
    display: grid !important;
    gap: 8px !important;
    padding: 16px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 22px !important;
    background: var(--ah-paper) !important;
}

.reward-summary-card > span {
    color: var(--ah-accent) !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
}

.reward-summary-card strong,
.reward-steps strong,
.premium-plan h4,
.achievement-card h4 {
    color: var(--ah-ink) !important;
    font-family: var(--ah-display) !important;
    font-size: clamp(1.45rem, 4vw, 2.1rem) !important;
    line-height: 1.02 !important;
}

.reward-summary-card.is-main {
    background:
        linear-gradient(135deg, var(--ah-accent-soft), transparent 52%),
        var(--ah-paper) !important;
}

body[data-page="comunidad"] .community-panel {
    display: grid !important;
    gap: 16px !important;
    padding: clamp(16px, 3vw, 24px) !important;
    border-width: 3px !important;
}

body[data-page="comunidad"] .panel-heading {
    gap: 8px !important;
    margin: 10px auto 20px !important;
}

body[data-page="comunidad"] .panel-heading h3 {
    font-size: clamp(1.9rem, 5vw, 3rem) !important;
}

.reward-steps .soft-link {
    width: 100% !important;
    min-height: 46px !important;
    padding: 0 14px !important;
    font-size: 0.9rem !important;
}

.premium-list {
    gap: 12px !important;
}

body[data-page="comunidad"] .premium-plan {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 16px !important;
    border-width: 3px !important;
}

body[data-page="comunidad"] .premium-plan div {
    display: grid !important;
    gap: 7px !important;
}

body[data-page="comunidad"] .premium-plan button {
    width: 100% !important;
    min-height: 52px !important;
    border-width: 3px !important;
}

body[data-page="comunidad"] .premium-plan button:disabled {
    background: var(--ah-accent-soft) !important;
    color: var(--ah-accent-dark) !important;
    opacity: 1 !important;
}

body[data-page="comunidad"] .achievement-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
}

body[data-page="comunidad"] .achievement-card {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 10px 12px !important;
    min-height: 0 !important;
    padding: 14px !important;
    border-width: 3px !important;
}

body[data-page="comunidad"] .achievement-card > strong {
    justify-self: end !important;
    color: var(--ah-accent) !important;
    font-size: 0.9rem !important;
    white-space: nowrap !important;
}

.achievement-progress {
    grid-column: 2 / -1 !important;
    height: 10px !important;
    overflow: hidden !important;
    border: 2px solid var(--ah-line) !important;
    border-radius: 999px !important;
    background: var(--ah-paper) !important;
}

.achievement-progress i {
    display: block !important;
    height: 100% !important;
    background: var(--ah-accent) !important;
}

body[data-page="comunidad"] .achievement-card small {
    grid-column: 2 / -1 !important;
}

body[data-page="comunidad"] .leaderboard-list li {
    grid-template-columns: 40px minmax(0, 1fr) auto !important;
    gap: 12px !important;
    padding: 12px 0 !important;
}

.leaderboard-list strong {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    align-items: center !important;
}

.leaderboard-list b {
    display: inline-flex !important;
    min-height: 22px !important;
    align-items: center !important;
    padding: 0 8px !important;
    border: 2px solid var(--ah-accent-dark) !important;
    border-radius: 999px !important;
    background: var(--ah-accent-soft) !important;
    color: var(--ah-accent-dark) !important;
    font-family: var(--ah-ui) !important;
    font-size: 0.7rem !important;
    font-weight: 950 !important;
}

.leaderboard-list li.has-benefit {
    background: linear-gradient(90deg, var(--ah-accent-wash), transparent 70%) !important;
}

body[data-page="comunidad"] .community-stats {
    margin: 0 !important;
}

.community-toast {
    position: fixed !important;
    left: 50% !important;
    bottom: calc(22px + env(safe-area-inset-bottom)) !important;
    z-index: 4200 !important;
    width: min(420px, calc(100vw - 28px)) !important;
    min-height: 52px !important;
    display: grid !important;
    place-items: center !important;
    padding: 12px 16px !important;
    border: 3px solid var(--ah-line) !important;
    border-radius: 18px !important;
    background: var(--ah-paper) !important;
    color: var(--ah-ink) !important;
    box-shadow: 8px 8px 0 var(--ah-line) !important;
    transform: translateX(-50%) !important;
    text-align: center !important;
    font-weight: 950 !important;
}

.community-toast.is-error {
    border-color: var(--ah-accent-dark) !important;
    color: var(--ah-accent-dark) !important;
}

@media (min-width: 680px) {
    body[data-page="comunidad"] .community-header {
        grid-template-columns: minmax(0, 1fr) minmax(240px, 0.38fr) !important;
        align-items: end !important;
    }

    .reward-summary,
    .reward-steps {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    body[data-page="comunidad"] .premium-plan {
        grid-template-columns: minmax(0, 1fr) minmax(210px, auto) !important;
        align-items: center !important;
    }

    body[data-page="comunidad"] .achievement-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 520px) {
    body[data-page="comunidad"] .achievement-card {
        grid-template-columns: 38px minmax(0, 1fr) !important;
    }

    body[data-page="comunidad"] .achievement-card > strong {
        grid-column: 2 !important;
        justify-self: start !important;
    }

    body[data-page="comunidad"] .leaderboard-list li {
        grid-template-columns: 36px minmax(0, 1fr) !important;
    }

    body[data-page="comunidad"] .leaderboard-list em {
        grid-column: 2 !important;
        justify-self: start !important;
    }
}
