/* gx-profile-public.css */
/* Generated by audit-css-phase3-generate.mjs from public-css-rule-ownership.canary.json */
/* DO NOT HAND-EDIT — regenerate via 'node audit-css-phase3-generate.mjs' */
/* Generated: 2026-05-02T17:36:26.981Z */
/* Source files: gx-shared-ui.css, gx-public.css */
/* Rule count: 59 */


/* ─── from gx-shared-ui.css ─── */
.tour-poster-glow {
    animation: tour-poster-glow-breathe 3s ease-in-out infinite;
}
.avail-heat-strip {
    margin-bottom: var(--sb-space-xl);
    min-width: 0;
}
.avail-heat-viewport {
    overflow: hidden;
    padding-top: 2px;
    margin-top: -2px;
}
.avail-heat-track {
    display: flex;
    transition: transform 0.35s ease;
}
.avail-heat-week {
    min-width: 100%;
    flex-shrink: 0;
    display: flex;
    gap: 4px;
}
.avail-heat-day {
    flex: 1;
    text-align: center;
    padding: var(--sb-space-sm) 0;
    border-radius: var(--sb-radius);
    background: rgba(148,163,184,0.1);
    border: 1px solid rgba(148,163,184,0.2);
    opacity: 0.5;
    transition: opacity var(--sb-transition), background var(--sb-transition);
}
.avail-heat-label {
    font-size: var(--sb-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.avail-heat-date {
    font-size: 10px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}
.avail-heat-day[style*="fuchsia"] .avail-heat-date,
.avail-heat-day[style*="fuchsia"] .avail-heat-label {
    color: inherit;
}
.avail-heat-status {
    font-size: 9px;
    margin-top: 2px;
    font-weight: 600;
    letter-spacing: 0.03em;
    min-height: 14px;
}
.avail-heat-day.bookable,
.avail-heat-day[data-action] {
    cursor: pointer;
}
.avail-heat-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--sb-space-sm);
}
.avail-heat-nav button {
    background: none;
    border: 1px solid var(--sb-border);
    color: var(--sb-text-muted);
    width: 28px;
    height: 28px;
    border-radius: var(--sb-radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    transition: border-color 0.2s, color 0.2s;
}
.avail-heat-nav button:hover {
    border-color: var(--sb-ice);
    color: var(--sb-ice);
}
.avail-heat-nav button:disabled {
    opacity: 0.3;
    cursor: default;
}
.avail-heat-nav button:disabled:hover {
    border-color: var(--sb-border);
    color: var(--sb-text-muted);
}
.avail-heat-nav-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    letter-spacing: 0.03em;
    min-width: 100px;
    text-align: center;
}
.detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: var(--sb-space-lg); align-items: stretch; }
.detail-grid > div { display: flex; flex-direction: column; }
.detail-section {
    background: rgba(14, 20, 33, 0.7);
    border: none;
    border-radius: var(--sb-radius);
    padding: var(--sb-space-lg);
    margin-bottom: var(--sb-space-lg);
    position: relative;
    overflow: visible;
}
.detail-section::before {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    padding: 1px;
    background: var(--sb-gradient);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}
.detail-section h3 {
    font-size: var(--sb-text-lg);
    margin-bottom: var(--sb-space-md);
    padding-bottom: var(--sb-space-sm);
    border-bottom: 1px solid var(--sb-border);
}
.detail-field { display: flex; justify-content: space-between; padding: var(--sb-space-sm) 0; border-bottom: 1px solid rgba(148,163,184,0.08); font-size: var(--sb-text-sm); }
.detail-field:last-of-type { border-bottom: none; }
.detail-field-label { color: var(--sb-text-muted); font-size: var(--sb-text-xs); text-transform: uppercase; letter-spacing: 0.05em; }
.detail-field-value { color: var(--sb-text); font-weight: 600; }
.gc-close {
    position: absolute;
    top: var(--sb-space-md);
    right: var(--sb-space-md);
    background: transparent;
    border: 1px solid var(--sb-border-light);
    color: var(--sb-text-muted);
    font-size: 1.35rem;
    cursor: pointer;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--sb-radius-sm);
    transition: color var(--sb-transition), box-shadow var(--sb-transition), border-color var(--sb-transition);
    z-index: 2;
    padding: 0; line-height: 1;
}
.gc-close:hover {
    color: var(--sb-ice-light);
    border-color: var(--sb-ice);
    box-shadow: 0 0 8px rgba(56,189,248,0.2), 0 0 16px rgba(14,165,233,0.1);
}
.gc-body { padding: var(--sb-space-lg) var(--sb-space-xl) var(--sb-space-xs); }
.gc-field { margin-bottom: var(--sb-space-md); }
.gc-field label {
    display: block; font-size: var(--sb-text-xs); font-weight: 600;
    color: var(--sb-text-secondary); margin-bottom: var(--sb-space-xs);
    text-transform: uppercase; letter-spacing: 0.05em;
}
.gc-field input {
    width: 100%; height: 44px;
    background: var(--sb-bg-body); border: 1px solid var(--sb-border);
    border-radius: var(--sb-radius); color: var(--sb-text);
    font-family: var(--sb-font); font-size: var(--sb-text-sm);
    padding: 0 var(--sb-space-md);
    transition: border-color var(--sb-transition);
    appearance: none;
}
.gc-field input:focus {
    outline: none; border-color: var(--sb-ice);
    box-shadow: 0 0 0 3px rgba(var(--sb-ice-rgb), 0.15);
}
.gc-field input.gc-error { border-color: var(--sb-fuchsia); }
.gc-field .gc-error-msg {
    font-size: var(--sb-text-xs); color: var(--sb-fuchsia);
    margin-top: 4px; display: none;
}
.gc-signin-hint a:hover { text-decoration: underline; }
.gc-success-icon {
    width: 64px; height: 64px; margin: 0 auto var(--sb-space-md);
    background: rgba(var(--sb-ice-rgb), 0.1);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    color: var(--sb-ice);
}
@media (max-width: 768px) {
.detail-grid { grid-template-columns: 1fr; }
}

/* ─── from gx-public.css ─── */
.gc-overlay {
    position: fixed; inset: 0; z-index: 9999;
    background: transparent;
    display: flex; align-items: center; justify-content: center;
    padding: var(--sb-space-md);
    overflow-y: auto;
    opacity: 0; pointer-events: none;
    transition: opacity 0.25s ease;
}
.gc-overlay::after {
    content: '';
    position: fixed; inset: 0;
    background: rgba(4, 6, 14, 0.75);
    /* No backdrop-filter — Cloudflare Turnstile hangs (spinning loader)
       when rendered inside an ancestor with backdrop-filter applied. */
    z-index: -1;
    pointer-events: none;
}
.gc-overlay.active { opacity: 1; pointer-events: auto; }
.gc-modal {
    width: 100%; max-width: 420px;
    background: rgba(12, 17, 32, 0.80);
    border: none;
    border-radius: var(--sb-radius-lg);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
    overflow: visible;
    position: relative;
    animation: sb-modal-breathe 3s ease-in-out infinite;
}
.gc-modal::before {
    content: '';
    position: absolute; inset: 0;
    border-radius: var(--sb-radius-lg);
    padding: 1px;
    background: var(--sb-gradient);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    z-index: 1;
}
.gc-header {
    padding: var(--sb-space-lg) var(--sb-space-xl) var(--sb-space-md);
    border-bottom: 1px solid rgba(56,189,248,0.15);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}
.gc-logo {
    font-family: 'Rajdhani', var(--sb-font);
    font-size: 1.45rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sb-text);
    line-height: 1;
    margin-bottom: var(--sb-space-sm);
}
.gc-logo-x {
    background: var(--sb-gradient-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.gc-title {
    font-size: var(--sb-text-lg);
    font-weight: 700;
    background: var(--sb-gradient-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.gc-field .gc-error-msg.visible { display: block; }
.gc-field-optional {
    font-size: var(--sb-text-xs); color: var(--sb-text-muted);
    font-weight: 400; text-transform: none; letter-spacing: 0;
    margin-left: var(--sb-space-xs);
}
.gc-field-help {
    font-size: var(--sb-text-xs);
    color: var(--sb-text-muted);
    margin-top: 6px;
    line-height: 1.4;
}
.gc-footer {
    padding: var(--sb-space-md) var(--sb-space-xl) var(--sb-space-lg);
    display: flex; flex-direction: column; gap: var(--sb-space-sm);
}
.gc-footer-actions { display: flex; gap: var(--sb-space-sm); }
.gc-amount {
    text-align: center; padding: var(--sb-space-md) 0 var(--sb-space-sm);
    font-size: var(--sb-text-xl); font-weight: 700; color: var(--sb-ice);
}
.gc-stripe-mount {
    min-height: 80px; padding: var(--sb-space-md);
    background: var(--sb-bg-body); border: 1px solid var(--sb-border);
    border-radius: var(--sb-radius);
}
.gc-stripe-errors {
    font-size: var(--sb-text-xs); color: var(--sb-fuchsia);
    min-height: 20px; padding-top: var(--sb-space-xs);
}
.gc-refund-notice {
    margin-top: var(--sb-space-sm);
    line-height: 1.5;
}
.gc-success {
    text-align: center; padding: var(--sb-space-xl) var(--sb-space-lg);
}
.gc-success h3 {
    font-size: var(--sb-text-lg); font-weight: 700; color: var(--sb-text);
    margin-bottom: var(--sb-space-xs);
}
.gc-success p {
    font-size: var(--sb-text-sm); color: var(--sb-text-secondary); line-height: 1.5;
}

/* ─── dependency closure: @keyframes referenced by emitted rules ─── */
@keyframes sb-modal-breathe {
    0%, 100% {
        box-shadow:
            0 0 6px 1px rgba(var(--sb-ice-rgb), 0.18),
            0 0 20px 3px rgba(var(--sb-ice-rgb), 0.12),
            0 0 40px 4px rgba(var(--sb-sky-rgb), 0.08),
            0 0 60px 6px rgba(var(--sb-violet-rgb), 0.05);
    }
    50% {
        box-shadow:
            0 0 8px 2px rgba(var(--sb-ice-rgb), 0.40),
            0 0 24px 6px rgba(var(--sb-ice-rgb), 0.30),
            0 0 48px 8px rgba(var(--sb-sky-rgb), 0.20),
            0 0 80px 10px rgba(var(--sb-violet-rgb), 0.12);
    }
}
