/* ============================================================
   CoffeeCat home page — Lisbon Azulejo redesign
   ============================================================ */

:root {
    --azul: #1e4a7b;
    --azul-deep: #0e2a4d;
    --azul-soft: #a8c5e3;
    --tile: #e6f0fa;
    --cream: #faf4ea;
    --paper: #fff;
    --ink: #0e1a2a;
    --terracotta: #c85a3e;
    --ochre: #d9a441;
    --olive: #7a8a4a;
    --rose: #e8a6a0;
}

/* Override global body style from places.css when the home page is rendered */
body:has(.cc-page) {
    background: var(--cream);
}

.cc-page {
    font-family: "DM Sans", system-ui, sans-serif;
    background: var(--cream);
    color: var(--ink);
    overflow-x: hidden;
    width: 100%;
}

.cc-page a {
    color: inherit;
    text-decoration: none;
}

.cc-page .serif { font-family: "Playfair Display", serif; }
.cc-page .mono { font-family: "DM Mono", monospace; }

/* ============ AZULEJO TILE PATTERN ============ */
.tile-bg {
    background-color: var(--tile);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'><g fill='none' stroke='%231e4a7b' stroke-width='1.2' opacity='.35'><path d='M0 40 Q 20 20 40 40 T 80 40'/><path d='M0 40 Q 20 60 40 40 T 80 40'/><path d='M40 0 Q 20 20 40 40 T 40 80'/><path d='M40 0 Q 60 20 40 40 T 40 80'/><circle cx='40' cy='40' r='4' fill='%231e4a7b' opacity='.4'/><circle cx='0' cy='0' r='2' fill='%231e4a7b'/><circle cx='80' cy='0' r='2' fill='%231e4a7b'/><circle cx='0' cy='80' r='2' fill='%231e4a7b'/><circle cx='80' cy='80' r='2' fill='%231e4a7b'/></g></svg>");
    background-size: 80px 80px;
}

/* ============ NAV ============ */
.cc-page nav.top {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 40px;
    background: rgba(250, 244, 234, 0.88);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(14, 26, 42, 0.08);
}

.cc-page .logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--azul-deep);
    line-height: 1;
}

.cc-page .logo-img {
    height: 42px;
    width: auto;
    display: block;
}

.cc-page .logo-wordmark {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.cc-page .logo-name {
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: 22px;
    letter-spacing: -0.01em;
}

.cc-page .logo-tagline {
    font-family: "DM Mono", monospace;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    opacity: 0.65;
}

.cc-page .logo--on-dark {
    color: var(--cream);
}

.cc-page .logo--on-dark .logo-img {
    height: 48px;
}

.cc-page .logo--on-dark .logo-tagline {
    opacity: 0.55;
}

.cc-page nav.top ul {
    display: flex;
    gap: 28px;
    list-style: none;
    margin: 0;
    padding: 0;
    font-weight: 500;
    font-size: 15px;
}

.cc-page .nav-cta {
    background: var(--azul);
    color: var(--cream);
    padding: 11px 20px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    border: 1px solid var(--azul-deep);
    box-shadow: 0 2px 0 var(--azul-deep);
    transition: transform 0.15s;
    cursor: pointer;
}

.cc-page .nav-cta:hover {
    transform: translate(1px, 1px);
    box-shadow: 0 1px 0 var(--azul-deep);
}

/* ============ HERO ============ */
.cc-page .hero {
    position: relative;
    padding: 20px 20px 0;
}

.cc-page .hero-inner {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    min-height: 720px;
    background:
        radial-gradient(ellipse at 80% 10%, rgba(217, 164, 65, 0.45), transparent 50%),
        radial-gradient(ellipse at 15% 90%, rgba(200, 90, 62, 0.3), transparent 55%),
        linear-gradient(180deg, #f9ebd0 0%, #f4d4a8 40%, #e8b488 100%);
}

.cc-page .tile-strip {
    position: absolute;
    width: 100%;
    height: 44px;
}

.cc-page .tile-strip.top { top: 20px; }
.cc-page .tile-strip.bot { bottom: 20px; }

.cc-page .hero-content {
    position: relative;
    z-index: 2;
    padding: 100px 60px 140px;
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.25fr 1fr;
    gap: 60px;
    align-items: center;
}

.cc-page .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: "DM Mono", monospace;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--azul-deep);
    border: 1px solid rgba(14, 42, 77, 0.25);
    background: rgba(255, 255, 255, 0.5);
    padding: 8px 14px;
    border-radius: 999px;
    backdrop-filter: blur(6px);
}

.cc-page .eyebrow::before {
    content: "";
    width: 8px;
    height: 8px;
    background: var(--terracotta);
    border-radius: 50%;
}

.cc-page h1.display {
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: clamp(56px, 8vw, 128px);
    line-height: 0.96;
    letter-spacing: -0.02em;
    margin: 20px 0 22px;
    color: var(--azul-deep);
}

.cc-page h1.display em {
    font-style: italic;
    font-weight: 400;
    color: var(--terracotta);
}

.cc-page h1.display .under {
    position: relative;
    display: inline-block;
}

.cc-page h1.display .under::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 6px;
    height: 14px;
    background: var(--ochre);
    opacity: 0.5;
    z-index: -1;
    border-radius: 3px;
}

.cc-page .sub {
    font-size: 18px;
    line-height: 1.55;
    max-width: 540px;
    color: #2a3546;
}

/* Hero postcard */
.cc-page .postcard {
    aspect-ratio: 3 / 4;
    max-width: 380px;
    margin-left: auto;
    background: var(--paper);
    padding: 18px;
    border-radius: 14px;
    position: relative;
    box-shadow:
        0 30px 70px -25px rgba(14, 42, 77, 0.5),
        0 0 0 1px rgba(14, 42, 77, 0.1);
    transform: rotate(3deg);
    display: flex;
    flex-direction: column;
    color: var(--ink);
}

.cc-page .stamp {
    position: absolute;
    top: 22px;
    right: 22px;
    width: 72px;
    height: 90px;
    background: var(--terracotta);
    color: var(--cream);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: 28px;
    line-height: 1;
    border: 4px double rgba(255, 255, 255, 0.6);
    box-shadow: 0 4px 14px rgba(200, 90, 62, 0.4);
    transform: rotate(-8deg);
}

.cc-page .stamp small {
    font-family: "DM Mono", monospace;
    font-size: 9px;
    font-weight: 500;
    margin-top: 4px;
    letter-spacing: 0.1em;
}

.cc-page .postcard-img {
    aspect-ratio: 5 / 4;
    border-radius: 8px;
    overflow: hidden;
    background: linear-gradient(180deg, #1e4a7b 0%, #5c8cb5 40%, #f4d4a8 70%, #c85a3e 100%);
    position: relative;
}

.cc-page .postcard-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cc-page .postcard-img::before {
    content: "";
    position: absolute;
    bottom: 30%;
    left: 0;
    right: 0;
    height: 2px;
    background: rgba(255, 255, 255, 0.5);
    pointer-events: none;
}

.cc-page .postcard-img svg {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

.cc-page .postcard-stamp-line {
    margin-top: 12px;
    font-family: "DM Mono", monospace;
    font-size: 11px;
    color: #6b7a8a;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 500;
}

.cc-page .postcard h3 {
    font-family: "Playfair Display", serif;
    font-size: 28px;
    margin: 6px 0 2px;
    line-height: 1;
}

.cc-page .postcard h3 em {
    font-style: italic;
    color: var(--terracotta);
}

.cc-page .postcard-sub {
    font-size: 13px;
    color: #6b7a8a;
    margin-top: 2px;
}

.cc-page .postcard-meta {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    font-family: "DM Mono", monospace;
    font-size: 11px;
    color: #2a3546;
    flex-wrap: wrap;
}

.cc-page .postcard-meta span {
    background: var(--tile);
    padding: 4px 8px;
    border-radius: 6px;
}

/* ============ SEARCH BAR ============ */
.cc-page .search-bar {
    margin: -60px 40px 0;
    position: relative;
    z-index: 30;
    background: var(--paper);
    border-radius: 20px;
    box-shadow:
        0 30px 60px -20px rgba(14, 26, 42, 0.25),
        0 0 0 1px rgba(14, 26, 42, 0.06);
    padding: 16px;
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr auto;
    gap: 4px;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.cc-page .sfield {
    padding: 10px 16px;
    border-right: 1px solid rgba(14, 26, 42, 0.08);
}

.cc-page .sfield:last-of-type { border-right: 0; }

.cc-page .sfield label {
    font-family: "DM Mono", monospace;
    display: block;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--azul);
    opacity: 0.8;
    margin: 0;
}

.cc-page .sfield input,
.cc-page .sfield select {
    width: 100%;
    border: 0;
    background: transparent;
    outline: none;
    font-family: inherit;
    font-size: 15px;
    font-weight: 600;
    padding-top: 4px;
    color: var(--ink);
    box-shadow: none;
}

.cc-page .sfield.location-suggest {
    position: relative;
}

.cc-page .location-suggest-menu {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: -1px;
    background: var(--paper);
    border-radius: 14px;
    box-shadow:
        0 20px 40px -12px rgba(14, 26, 42, 0.25),
        0 0 0 1px rgba(14, 26, 42, 0.08);
    padding: 6px;
    z-index: 100;
    max-height: 320px;
    overflow-y: auto;
}

.cc-page .location-suggest-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 8px;
    cursor: pointer;
    color: var(--ink);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.2;
}

.cc-page .location-suggest-item:hover,
.cc-page .location-suggest-item.is-active {
    background: var(--tile);
    color: var(--azul-deep);
}

.cc-page .location-suggest-label {
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cc-page .location-suggest-count {
    font-family: "DM Mono", monospace;
    font-size: 11px;
    color: #6b7a8a;
    background: var(--tile);
    padding: 2px 8px;
    border-radius: 999px;
}

.cc-page .location-suggest-item.is-active .location-suggest-count,
.cc-page .location-suggest-item:hover .location-suggest-count {
    background: var(--paper);
}

.cc-page .s-btn {
    background: var(--azul-deep);
    color: var(--cream);
    border: 0;
    border-radius: 14px;
    padding: 0 28px;
    cursor: pointer;
    font-weight: 700;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.cc-page .s-btn:hover { background: var(--terracotta); }

/* Filter chips */
.cc-page .chips {
    max-width: 1200px;
    margin: 18px auto 0;
    padding: 0 40px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cc-page .chip {
    background: var(--paper);
    border: 1px solid rgba(14, 26, 42, 0.12);
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    display: inline-flex;
    gap: 6px;
    align-items: center;
    transition: all 0.15s;
    user-select: none;
}

.cc-page .chip:hover,
.cc-page .chip.active,
.cc-page .chip.is-active {
    background: var(--azul-deep);
    color: var(--cream);
    border-color: var(--azul-deep);
}

.cc-page .chip svg {
    width: 14px;
    height: 14px;
}

/* ============ PLACES HERO (compact variant) ============ */
.cc-page .places-hero {
    position: relative;
    padding: 20px 20px 0;
}

.cc-page .places-hero-inner {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    min-height: 340px;
    background:
        radial-gradient(ellipse at 80% 10%, rgba(217, 164, 65, 0.45), transparent 50%),
        radial-gradient(ellipse at 15% 90%, rgba(200, 90, 62, 0.3), transparent 55%),
        linear-gradient(180deg, #f9ebd0 0%, #f4d4a8 60%, #e8b488 100%);
}

.cc-page .places-hero-content {
    position: relative;
    z-index: 2;
    padding: 80px 60px 90px;
    max-width: 1280px;
    margin: 0 auto;
    text-align: left;
}

.cc-page .places-hero h1.display {
    font-size: clamp(40px, 5.5vw, 84px);
    margin: 18px 0 16px;
}

/* ============ BREADCRUMBS ============ */
.cc-page .cc-breadcrumbs {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font-family: "DM Mono", monospace;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #6b7a8a;
    margin-bottom: 32px;
}

.cc-page .cc-breadcrumbs a {
    color: var(--azul);
    padding: 4px 10px;
    border-radius: 999px;
    transition: background 0.15s, color 0.15s;
}

.cc-page .cc-breadcrumbs a:hover {
    background: var(--tile);
}

.cc-page .cc-breadcrumbs .is-active,
.cc-page .cc-breadcrumbs a.is-active {
    background: var(--azul-deep);
    color: var(--cream);
}

.cc-page .cc-breadcrumbs .sep {
    opacity: 0.4;
}

/* ============ LOCATION CONTENT ============ */
.cc-page .loc-content {
    background: var(--paper);
    border-radius: 16px;
    border: 1px solid rgba(14, 26, 42, 0.08);
    padding: 28px 32px;
    margin: 40px 0;
    box-shadow: 0 12px 30px -20px rgba(14, 42, 77, 0.25);
}

.cc-page .loc-content h2 {
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: 28px;
    color: var(--azul-deep);
    margin: 0 0 12px;
}

.cc-page .loc-content p {
    color: #4a5a6b;
    line-height: 1.6;
    margin: 0 0 12px;
}

/* ============ VENUE SHOW PAGE ============ */
.cc-page .venue-hero {
    position: relative;
    padding: 0;
    overflow: hidden;
    min-height: 380px;
    display: flex;
}

.cc-page .venue-hero--with-cover { color: var(--cream); }

.cc-page .venue-hero--plain {
    background:
        radial-gradient(ellipse at 80% 10%, rgba(217, 164, 65, 0.45), transparent 50%),
        linear-gradient(180deg, #f9ebd0 0%, #f4d4a8 60%, #e8b488 100%);
}

.cc-page .venue-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: blur(1px);
    transform: scale(1.04);
}

.cc-page .venue-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        rgba(14, 42, 77, 0.35) 0%,
        rgba(14, 26, 42, 0.75) 100%);
}

.cc-page .venue-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px 40px 60px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.cc-page .venue-hero-title {
    font-size: clamp(40px, 6vw, 84px) !important;
    margin: 12px 0 10px !important;
    color: inherit !important;
}

.cc-page .venue-hero--with-cover .venue-hero-title,
.cc-page .venue-hero--with-cover .venue-hero-sub,
.cc-page .venue-hero--with-cover .eyebrow {
    color: var(--cream);
}

.cc-page .venue-hero--with-cover .eyebrow {
    border-color: rgba(250, 244, 234, 0.4);
    background: rgba(14, 26, 42, 0.25);
}

.cc-page .venue-hero-sub {
    font-size: 17px;
    opacity: 0.95;
}

.cc-page .cc-breadcrumbs.on-dark a {
    color: var(--cream);
    background: rgba(255, 255, 255, 0.12);
}

.cc-page .cc-breadcrumbs.on-dark a:hover {
    background: rgba(255, 255, 255, 0.22);
}

.cc-page .cc-breadcrumbs.on-dark .is-active {
    background: var(--ochre);
    color: var(--azul-deep);
}

.cc-page .cc-breadcrumbs.on-dark {
    color: rgba(250, 244, 234, 0.75);
}

.cc-page .cc-breadcrumbs.on-dark .sep {
    color: rgba(250, 244, 234, 0.4);
}

.cc-page .venue-hero-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
}

.cc-page .venue-score-tile {
    background: var(--cream);
    color: var(--azul-deep);
    border: 2px double var(--azul-deep);
    padding: 8px 12px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: 22px;
    min-width: 54px;
}

.cc-page .venue-score-tile small {
    font-family: "DM Mono", monospace;
    font-size: 8px;
    font-weight: 500;
    letter-spacing: 0.12em;
    opacity: 0.7;
    margin-top: 3px;
}

.cc-page .hero-chip {
    background: rgba(255, 255, 255, 0.18);
    color: inherit;
    padding: 8px 12px;
    border-radius: 999px;
    font-family: "DM Mono", monospace;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.04em;
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(4px);
}

.cc-page .venue-hero--plain .hero-chip {
    background: rgba(255, 255, 255, 0.55);
    color: var(--azul-deep);
    border-color: rgba(14, 42, 77, 0.15);
}

.cc-page .hero-chip.good { color: #166534; background: rgba(180, 225, 190, 0.85); border-color: rgba(22, 101, 52, 0.2); }
.cc-page .hero-chip.ok { color: #a16207; background: rgba(247, 228, 180, 0.85); border-color: rgba(161, 98, 7, 0.2); }

.cc-page .venue-body {
    padding-top: 56px;
    padding-bottom: 80px;
}

.cc-page .venue-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 32px;
}

.cc-page .venue-main {
    display: flex;
    flex-direction: column;
    gap: 56px;
}

.cc-page .venue-side {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.cc-page .venue-section {
    display: block;
}

.cc-page .venue-section .tag {
    display: block;
    margin-bottom: 10px;
}

.cc-page .venue-section h2 {
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: 36px;
    color: var(--azul-deep);
    margin: 0 0 24px;
    line-height: 1;
    letter-spacing: -0.01em;
}

.cc-page .venue-card {
    background: var(--paper);
    border-radius: 18px;
    padding: 28px;
    border: 1px solid rgba(14, 26, 42, 0.08);
    box-shadow: 0 12px 30px -20px rgba(14, 42, 77, 0.2);
}

.cc-page .venue-card h2 {
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: 28px;
    color: var(--azul-deep);
    margin: 6px 0 22px;
    line-height: 1.1;
}

.cc-page .venue-card h3 {
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: 20px;
    color: var(--azul-deep);
    margin: 6px 0 16px;
    line-height: 1.15;
}

.cc-page .venue-card .tag {
    margin-bottom: 0;
}

.cc-page .venue-prose {
    color: #2a3546;
    line-height: 1.7;
    font-size: 16px;
}

.cc-page .venue-prose p { margin: 0 0 12px; }

/* Rating bars (compact — sidebar) */
.cc-page .rating-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.cc-page .rating-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cc-page .rating-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
}

.cc-page .rating-label {
    font-family: "DM Sans", sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -0.005em;
}

.cc-page .rating-track {
    height: 8px;
    background: var(--tile);
    border-radius: 999px;
    overflow: hidden;
    position: relative;
    box-shadow: inset 0 1px 2px rgba(14, 42, 77, 0.1);
}

.cc-page .rating-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--ochre), var(--terracotta));
    border-radius: 999px;
    transition: width 0.3s ease;
}

.cc-page .rating-number {
    font-family: "Playfair Display", serif;
    font-size: 18px;
    font-weight: 700;
    color: var(--azul-deep);
    line-height: 1;
}

.cc-page .rating-number::after {
    content: " / 5";
    font-family: "DM Mono", monospace;
    font-size: 10px;
    font-weight: 400;
    color: #6b7a8a;
    letter-spacing: 0.05em;
}

/* Gallery */
.cc-page .venue-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px;
}

.cc-page .venue-gallery-item {
    position: relative;
    height: 200px;
    overflow: hidden;
    border-radius: 10px;
    cursor: pointer;
    background: var(--tile);
}

.cc-page .venue-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cc-page .venue-gallery-tag {
    position: absolute;
    bottom: 8px;
    left: 8px;
    background: rgba(14, 42, 77, 0.75);
    color: var(--cream);
    padding: 4px 10px;
    border-radius: 999px;
    font-family: "DM Mono", monospace;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Lightbox overrides */
.cc-page .lightbox-content {
    max-width: 100%;
    margin: 0 auto;
}

.cc-page .lightbox-figure {
    position: relative;
    margin: 0;
}

.cc-page .lightbox-figure img {
    max-height: 90vh;
    max-width: 95vw;
    margin: 0 auto;
    display: block;
    border-radius: 8px;
}

.cc-page .lightbox-info {
    position: absolute;
    bottom: 16px;
    left: 16px;
    right: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--cream);
    font-family: "DM Mono", monospace;
    font-size: 12px;
}

.cc-page .lightbox-tag {
    background: rgba(14, 42, 77, 0.85);
    padding: 6px 12px;
    border-radius: 999px;
    letter-spacing: 0.06em;
}

.cc-page .lightbox-counter {
    background: rgba(14, 42, 77, 0.85);
    padding: 6px 12px;
    border-radius: 999px;
}

.cc-page .lightbox-nav {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.15);
    border: 0;
    color: var(--cream);
    font-size: 48px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    cursor: pointer;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(6px);
    transition: background 0.15s;
}

.cc-page .lightbox-nav:hover { background: rgba(255, 255, 255, 0.3); }
.cc-page .lightbox-prev { left: 24px; }
.cc-page .lightbox-next { right: 24px; }

/* Sidebar */
.cc-page .venue-side .venue-card { padding: 24px 28px; }

.cc-page .venue-map {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 12px;
    overflow: hidden;
    margin: 4px 0 18px;
    background: var(--tile);
    border: 1px solid rgba(14, 26, 42, 0.08);
}

.cc-page .venue-map iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.cc-page .venue-address {
    font-size: 14px;
    line-height: 1.65;
    color: #2a3546;
    margin: 12px 0 16px;
}

.cc-page .venue-side-link {
    font-family: "DM Mono", monospace;
    font-size: 12px;
    margin: 0 0 16px;
}

.cc-page .venue-side-link a {
    color: var(--azul);
    font-weight: 600;
}

.cc-page .venue-side-link a:hover { color: var(--terracotta); }

.cc-page .venue-maps-btn {
    display: inline-flex;
    width: 100%;
    justify-content: center;
    font-size: 14px;
}

.cc-page .venue-dl {
    display: flex;
    flex-direction: column;
    margin: 0;
    font-size: 14px;
    border-top: 1px dashed rgba(14, 26, 42, 0.15);
}

/* Fact tile grid (main-column Quick facts) */
.cc-page .fact-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-top: 4px;
}

.cc-page .fact {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px 18px;
    background: var(--tile);
    border-radius: 12px;
    border: 1px solid rgba(30, 74, 123, 0.1);
}

.cc-page .fact-label {
    font-family: "DM Mono", monospace;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--azul);
    opacity: 0.85;
}

.cc-page .fact-value {
    font-family: "Playfair Display", serif;
    font-size: 20px;
    font-weight: 700;
    color: var(--azul-deep);
    line-height: 1.1;
}

@media (max-width: 700px) {
    .cc-page .fact-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 420px) {
    .cc-page .fact-grid { grid-template-columns: 1fr; }
}

.cc-page .venue-dl dt,
.cc-page .venue-dl dd {
    padding: 12px 0;
}

.cc-page .venue-dl dt {
    font-family: "DM Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #6b7a8a;
    font-weight: 500;
    border-bottom: 1px dashed rgba(14, 26, 42, 0.15);
    padding-bottom: 4px;
    padding-top: 14px;
}

.cc-page .venue-dl dt:first-of-type {
    padding-top: 14px;
}

.cc-page .venue-dl dd {
    margin: 0;
    font-weight: 600;
    color: var(--ink);
    padding-top: 6px;
    padding-bottom: 14px;
    border-bottom: 1px dashed rgba(14, 26, 42, 0.15);
    font-size: 15px;
}

.cc-page .venue-dl dd:last-of-type {
    border-bottom: 0;
}

.cc-page .venue-back {
    display: inline-block;
    margin-top: 8px;
    font-family: "DM Mono", monospace;
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--azul);
}

.cc-page .venue-back:hover { color: var(--terracotta); }

@media (max-width: 900px) {
    .cc-page .venue-grid { grid-template-columns: 1fr; }
    .cc-page .venue-hero-inner { padding: 32px 24px 48px; }
    .cc-page .venue-card { padding: 22px; }
    .cc-page .venue-main { gap: 44px; }
    .cc-page .venue-section h2 { font-size: 28px; margin-bottom: 18px; }
    .cc-page .rating-number { font-size: 16px; }
    .cc-page .venue-gallery { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
    .cc-page .venue-gallery-item { height: 160px; }
}

/* ============ APP PROMO SIDEBAR CARD ============ */
.cc-page .venue-app-card {
    background: linear-gradient(160deg, var(--azul-deep) 0%, var(--azul) 100%);
    color: var(--cream);
    position: relative;
    overflow: hidden;
    border: 0;
}

.cc-page .venue-app-card::before {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;
    width: 160px;
    height: 160px;
    background: radial-gradient(circle, rgba(217, 164, 65, 0.35), transparent 65%);
    pointer-events: none;
}

.cc-page .venue-app-card .tag {
    color: var(--ochre);
}

.cc-page .venue-app-card .tag::before {
    background: var(--ochre);
}

.cc-page .venue-app-card h3 {
    color: var(--cream);
}

.cc-page .venue-app-copy {
    font-size: 13px;
    line-height: 1.55;
    margin: 0 0 16px;
    opacity: 0.85;
    position: relative;
}

.cc-page .venue-app-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    position: relative;
}

.cc-page .venue-app-btn {
    background: var(--cream);
    color: var(--azul-deep);
    font-size: 13px;
    padding: 10px 14px;
    text-align: center;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.cc-page .venue-app-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.cc-page .venue-app-btn:hover {
    background: var(--ochre);
    color: var(--azul-deep);
}

/* ============ STICKY APP BANNER ============ */
.app-banner {
    position: fixed;
    z-index: 80;
    background: #0e2a4d;
    color: #faf4ea;
    border-radius: 14px;
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    align-items: center;
    gap: 14px;
    box-shadow: 0 16px 40px -12px rgba(14, 42, 77, 0.45);
    font-family: "DM Sans", system-ui, sans-serif;
    /* Desktop: floating badge in bottom-right */
    right: 24px;
    bottom: 24px;
    max-width: 460px;
    padding: 14px 16px;
}

/* Mobile: full-width bar; stack buttons under the copy */
@media (max-width: 700px) {
    .app-banner {
        left: 12px;
        right: 12px;
        bottom: 12px;
        max-width: none;
        padding: 12px 14px 14px;
        grid-template-columns: auto 1fr auto;
        grid-template-areas:
            "icon copy close"
            "btns btns btns";
        column-gap: 12px;
        row-gap: 10px;
    }
    .app-banner-icon { grid-area: icon; }
    .app-banner-copy { grid-area: copy; }
    .app-banner-close { grid-area: close; }
    .app-banner-buttons { grid-area: btns; }
}

.app-banner-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #faf4ea;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.app-banner-icon img {
    width: 28px;
    height: 28px;
    display: block;
}

.app-banner-copy {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
    line-height: 1.2;
}

.app-banner-copy strong {
    font-size: 14px;
    font-weight: 700;
    color: #faf4ea;
}

.app-banner-copy small {
    font-size: 11px;
    color: rgba(250, 244, 234, 0.75);
}

.app-banner-buttons {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

.app-banner-btn {
    background: #faf4ea;
    color: #0e2a4d;
    border: 0;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background 0.15s, color 0.15s;
}

.app-banner-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.app-banner-btn:hover {
    background: #d9a441;
    color: #0e2a4d;
}

.app-banner-close {
    background: rgba(250, 244, 234, 0.12);
    border: 0;
    color: var(--cream, #faf4ea);
    font-size: 20px;
    line-height: 1;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.app-banner-close:hover { background: rgba(250, 244, 234, 0.22); }

/* ============ EMPTY STATE ============ */
.cc-page .cc-notice {
    background: var(--paper);
    border-radius: 16px;
    border: 1px dashed rgba(14, 26, 42, 0.18);
    padding: 60px 32px;
    text-align: center;
    color: #4a5a6b;
    font-size: 16px;
}

.cc-page .cc-notice p {
    margin: 0 0 20px;
}

/* ============ DIVIDER ============ */
.cc-page .divider {
    height: 60px;
    margin-top: 80px;
}

/* ============ SECTIONS ============ */
.cc-page .section {
    padding: 100px 40px;
    max-width: 1280px;
    margin: 0 auto;
}

.cc-page .s-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 30px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}

.cc-page .s-head h2 {
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: clamp(30px, 3.6vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.015em;
    margin: 0;
    max-width: 720px;
    color: var(--azul-deep);
}

.cc-page .s-head h2 em {
    font-style: italic;
    font-weight: 400;
    color: var(--terracotta);
}

.cc-page .s-head p {
    max-width: 420px;
    margin: 0;
    color: #4a5a6b;
    font-size: 16px;
    line-height: 1.5;
}

.cc-page .tag {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: "DM Mono", monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--terracotta);
    margin-bottom: 14px;
    padding: 0;
    background: none;
    border: 0;
    border-radius: 0;
}

.cc-page .tag::before {
    content: "";
    display: block;
    width: 28px;
    height: 2px;
    background: var(--terracotta);
    flex-shrink: 0;
}

/* ============ TRENDING CARDS ============ */
.cc-page .cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.cc-page .card {
    background: var(--paper);
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(14, 26, 42, 0.08);
    display: flex;
    flex-direction: column;
    color: var(--ink);
}

.cc-page .card-top {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    padding: 18px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.cc-page .card-top img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.cc-page .card-top::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.35));
}

.cc-page .card-top > * {
    position: relative;
    z-index: 1;
}

.cc-page .stamp-score {
    background: var(--cream);
    color: var(--azul-deep);
    width: 60px;
    height: 72px;
    border: 2px double var(--azul-deep);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: 24px;
    line-height: 1;
}

.cc-page .stamp-score small {
    font-family: "DM Mono", monospace;
    font-size: 8px;
    font-weight: 500;
    opacity: 0.7;
    margin-top: 3px;
    letter-spacing: 0.1em;
}

.cc-page .pill {
    background: var(--paper);
    color: var(--ink);
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    font-family: "DM Mono", monospace;
    letter-spacing: 0.02em;
}

.cc-page .card-body { padding: 20px 22px 22px; }

.cc-page .card-body h3 {
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: 24px;
    margin: 0 0 4px;
    line-height: 1.1;
}

.cc-page .card-body h3 em {
    font-style: italic;
    color: var(--terracotta);
}

.cc-page .sub2 {
    color: #6b7a8a;
    font-size: 13px;
}

.cc-page .metrics {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px dashed rgba(14, 26, 42, 0.15);
}

.cc-page .metric {
    display: flex;
    flex-direction: column;
    font-size: 10px;
    color: #6b7a8a;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 600;
    border-right: 1px dashed rgba(14, 26, 42, 0.12);
    padding: 0 10px;
}

.cc-page .metric:first-child { padding-left: 0; }
.cc-page .metric:last-child { border-right: 0; }

.cc-page .metric b {
    font-family: "DM Mono", monospace;
    font-size: 13px;
    color: var(--ink);
    letter-spacing: 0;
    text-transform: none;
    font-weight: 500;
    margin-top: 2px;
}

.cc-page .metric b.good { color: #166534; }
.cc-page .metric b.ok   { color: #a16207; }

.cc-page .bg-a { background: linear-gradient(180deg, #1e4a7b, #5c8cb5, #e8b488); }
.cc-page .bg-b { background: linear-gradient(180deg, #c85a3e, #e8a073, #f4d4a8); }
.cc-page .bg-c { background: linear-gradient(180deg, #0e2a4d, #1e4a7b, #a8c5e3); }
.cc-page .bg-d { background: linear-gradient(180deg, #7a8a4a, #b4c086, #f4e8c8); }
.cc-page .bg-e { background: linear-gradient(180deg, #2a3b5c, #5c6b8a, #d9a441); }
.cc-page .bg-f { background: linear-gradient(180deg, #8a3b4d, #c85a6a, #e8a6a0); }

/* ============ CITY TICKETS ============ */
.cc-page .tickets {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.cc-page .ticket {
    background: var(--paper);
    border-radius: 14px;
    padding: 20px;
    border: 1px solid rgba(14, 26, 42, 0.1);
    position: relative;
    cursor: pointer;
    color: var(--ink);
    display: block;
}

.cc-page .ticket::before,
.cc-page .ticket::after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--cream);
    border: 1px solid rgba(14, 26, 42, 0.1);
}

.cc-page .ticket::before { left: -8px; }
.cc-page .ticket::after { right: -8px; }

.cc-page .ticket .code {
    font-family: "DM Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--terracotta);
    font-weight: 500;
}

.cc-page .ticket h4 {
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: 32px;
    margin: 8px 0 4px;
    letter-spacing: -0.01em;
    color: var(--azul-deep);
}

.cc-page .ticket .meta {
    display: flex;
    justify-content: space-between;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px dashed rgba(14, 26, 42, 0.2);
    font-size: 12px;
    color: #6b7a8a;
}

.cc-page .ticket .meta b {
    color: var(--ink);
    font-weight: 600;
}

/* ============ QUOTE BAND ============ */
.cc-page .quote-band {
    padding: 120px 40px;
    background: var(--azul-deep);
    color: var(--cream);
    position: relative;
    overflow: hidden;
}

.cc-page .quote-band .tile-bg {
    position: absolute;
    inset: 0;
    opacity: 0.08;
}

.cc-page .quote-inner {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
    position: relative;
}

.cc-page .quote-inner blockquote {
    font-family: "Playfair Display", serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(28px, 4vw, 56px);
    line-height: 1.2;
    margin: 0;
}

.cc-page .quote-inner blockquote::before {
    content: "\201C";
    font-size: 200px;
    line-height: 0.5;
    color: var(--ochre);
    display: block;
    margin-bottom: 30px;
}

.cc-page .quote-inner cite {
    margin-top: 32px;
    display: block;
    font-family: "DM Mono", monospace;
    font-style: normal;
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    opacity: 0.7;
}

/* ============ CTA ============ */
.cc-page .cta {
    margin: 40px;
    padding: 70px 40px;
    border-radius: 28px;
    text-align: center;
    background: var(--terracotta);
    color: var(--cream);
    position: relative;
    overflow: hidden;
}

.cc-page .cta::before,
.cc-page .cta::after {
    content: "";
    position: absolute;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
}

.cc-page .cta::before { top: -150px; left: -100px; }
.cc-page .cta::after  { bottom: -150px; right: -100px; }

.cc-page .cta h2 {
    font-family: "Playfair Display", serif;
    font-weight: 900;
    font-size: clamp(40px, 6vw, 84px);
    line-height: 0.95;
    margin: 0 0 20px;
    letter-spacing: -0.02em;
    position: relative;
}

.cc-page .cta h2 em {
    font-style: italic;
    font-weight: 400;
}

.cc-page .cta p {
    max-width: 560px;
    margin: 0 auto 28px;
    font-size: 17px;
    opacity: 0.9;
    line-height: 1.5;
    position: relative;
}

.cc-page .dl-row {
    display: inline-flex;
    gap: 12px;
    flex-wrap: wrap;
    position: relative;
    justify-content: center;
}

.cc-page .dl {
    background: var(--azul-deep);
    color: var(--cream);
    padding: 14px 22px;
    border-radius: 12px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    border: 0;
    font-size: 15px;
    font-family: inherit;
    transition: background 0.15s, color 0.15s;
}

.cc-page .dl svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.cc-page .dl:hover {
    background: var(--cream);
    color: var(--azul-deep);
}

/* ============ FOOTER ============ */
.cc-page footer.home-footer {
    background: var(--azul-deep);
    color: var(--cream);
    padding: 70px 40px 32px;
    border-top: 6px solid var(--ochre);
}

.cc-page .foot-grid {
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
}

.cc-page footer.home-footer h4 {
    font-family: "DM Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.6;
    margin: 0 0 14px;
    color: var(--cream);
}

.cc-page footer.home-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 14px;
}

.cc-page .footline {
    font-family: "Playfair Display", serif;
    font-style: italic;
    font-size: 26px;
    line-height: 1.25;
    max-width: 340px;
    margin-top: 18px;
}

.cc-page .copy {
    max-width: 1280px;
    margin: 50px auto 0;
    padding-top: 24px;
    border-top: 1px solid rgba(250, 244, 234, 0.12);
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    opacity: 0.5;
    font-family: "DM Mono", monospace;
    flex-wrap: wrap;
    gap: 8px;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 900px) {
    .cc-page .hero-content {
        grid-template-columns: 1fr;
        padding: 60px 28px 120px;
    }
    .cc-page .postcard { margin: 0 auto; }
    .cc-page .search-bar {
        grid-template-columns: 1fr;
        margin: 20px 20px 0;
    }
    .cc-page .sfield {
        border-right: 0;
        border-bottom: 1px solid rgba(14, 26, 42, 0.08);
    }
    .cc-page .cards { grid-template-columns: 1fr 1fr; }
    .cc-page .tickets { grid-template-columns: 1fr 1fr; }
    .cc-page .foot-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
    .cc-page .cards { grid-template-columns: 1fr; }
    .cc-page .tickets { grid-template-columns: 1fr; }
    .cc-page nav.top ul { display: none; }
    .cc-page .section { padding: 60px 24px; }
    .cc-page nav.top { padding: 14px 20px; }
}

/* ============================================================
   Preview signup modal (kept from previous design — triggered
   by the CTA "Download" buttons and the nav CTA)
   ============================================================ */

.preview-modal-card {
    background: linear-gradient(170deg, white 0%, var(--tile) 100%);
    border-radius: 20px;
    padding: 2.5rem 2rem 2rem;
    max-width: 420px;
    margin: 0 auto;
    text-align: center;
    box-shadow: 0 24px 64px rgba(14, 42, 77, 0.25);
    position: relative;
    animation: modalSlideIn 0.3s ease-out;
    color: var(--ink);
}

@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(24px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.preview-modal-close {
    position: absolute;
    top: 0.75rem;
    right: 1rem;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--azul-soft);
    cursor: pointer;
    line-height: 1;
    padding: 0.25rem;
    transition: color 0.15s;
}

.preview-modal-close:hover { color: var(--azul-deep); }

.preview-modal-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.preview-modal-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.preview-modal-fields .platform-choice {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 4px;
}

.preview-modal-fields .platform-choice .radio {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 14px 10px;
    border: 1.5px solid rgba(14, 26, 42, 0.12);
    border-radius: 12px;
    background: var(--paper, #fff);
    color: var(--azul-deep);
    font-family: "DM Mono", monospace;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    margin: 0;
}

.preview-modal-fields .platform-choice .radio:hover {
    border-color: var(--azul-soft);
    background: var(--tile);
}

.preview-modal-fields .platform-choice .radio input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.preview-modal-fields .platform-choice .radio:has(input:checked) {
    border-color: var(--azul-deep);
    background: var(--azul-deep);
    color: var(--cream);
}

.preview-modal-fields .platform-glyph {
    width: 22px;
    height: 22px;
    color: currentColor;
}

.preview-modal-title {
    font-family: "Playfair Display", serif;
    color: var(--azul-deep);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
}

.preview-modal-subtitle {
    color: #4a5a6b;
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
    line-height: 1.6;
}

.preview-modal-fields { text-align: left; }

.preview-modal-fields .field { margin-bottom: 0.75rem; }

.preview-modal-fields .input,
.preview-modal-fields .textarea {
    border-color: rgba(14, 26, 42, 0.12);
    border-radius: 10px;
    box-shadow: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.preview-modal-fields .input:focus,
.preview-modal-fields .textarea:focus {
    border-color: var(--azul);
    box-shadow: 0 0 0 0.125em rgba(30, 74, 123, 0.25);
}

.preview-modal-fields .textarea {
    resize: none;
    font-size: 0.9rem;
}

.preview-modal-fields .icon svg { color: var(--azul-soft); }

.preview-modal-submit {
    margin-top: 0.25rem;
    border-radius: 10px;
    font-weight: 700;
    font-size: 1rem;
    padding: 1.1rem;
    height: auto;
    background: var(--azul-deep);
    color: var(--cream);
    border: 0;
    width: 100%;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(14, 42, 77, 0.25);
    transition: all 0.2s ease;
}

.preview-modal-submit:hover:not([disabled]) {
    transform: translateY(-1px);
    background: var(--terracotta);
    box-shadow: 0 6px 20px rgba(200, 90, 62, 0.3);
}

.preview-modal-feedback {
    margin-top: 1rem;
    min-height: 1.5rem;
}

.preview-modal-success { animation: successFadeIn 0.4s ease-out; }

.preview-modal-success .success-checkmark {
    width: 56px;
    height: 56px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    background: #48c774;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(72, 199, 116, 0.3);
}

.preview-modal-success .success-checkmark svg {
    width: 28px;
    height: 28px;
    stroke: white;
    stroke-width: 3;
    fill: none;
}

.preview-modal-success p {
    color: var(--azul-deep);
    font-weight: 600;
    font-size: 1.1rem;
    margin-bottom: 0.25rem;
}

.preview-modal-success small {
    color: #6b7a8a;
    font-size: 0.9rem;
}

@keyframes successFadeIn {
    from { opacity: 0; transform: scale(0.9); }
    to   { opacity: 1; transform: scale(1); }
}
