:root {
    color-scheme: light;
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--bg);
    color: var(--text);
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.site-shell {
    display: grid;
    grid-template-columns: var(--sidebar-width, 320px) minmax(0, 1fr);
    min-height: 100vh;
}

.sidebar {
    background: linear-gradient(180deg, var(--primary), var(--secondary));
    color: #fff;
    padding: 28px 22px;
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.brand-card,
.sidebar-contact {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 18px;
    padding: 18px;
}

.brand-kicker,
.section-kicker,
.hero-badge {
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .75rem;
    opacity: .85;
}

.brand-name {
    font-size: 1.8rem;
    font-weight: 700;
    margin: 8px 0;
}

.brand-copy,
.sidebar-contact span {
    color: rgba(255,255,255,.9);
    display: block;
    line-height: 1.5;
}

.sidebar-nav {
    display: grid;
    gap: 10px;
}

.sidebar-nav a {
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,.05);
    transition: .2s ease;
}

.sidebar-nav a.active,
.sidebar-nav a:hover {
    background: rgba(255,255,255,.15);
    transform: translateX(3px);
}

.content-area {
    padding: 24px;
}

.hero {
    position: relative;
    min-height: var(--hero-height, 320px);
    border-radius: calc(var(--panel-radius, 24px) + 4px);
    overflow: hidden;
    background: var(--primary);
    margin-bottom: 24px;
}

.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--hero-image);
    background-size: cover;
    background-position: center;
    filter: saturate(1.05);
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(130deg, rgba(8,23,52,.9), rgba(8,23,52,.38));
}

.hero-content {
    position: relative;
    z-index: 1;
    color: #fff;
    padding: 38px;
    max-width: 760px;
}

.hero-content h1 {
    font-size: clamp(2rem, 4vw, 3.8rem);
    margin: 10px 0 14px;
}

.hero-content p { line-height: 1.6; font-size: 1.05rem; }

.panel {
    background: #fff;
    border-radius: var(--panel-radius, 24px);
    padding: 24px;
    box-shadow: 0 10px 30px rgba(15,59,120,.08);
    margin-bottom: 24px;
}

.intro-panel {
    display: grid;
    grid-template-columns: 1.8fr 1fr;
    gap: 20px;
}

.info-stack { display: grid; gap: 16px; }
.info-box {
    background: linear-gradient(180deg, rgba(15,59,120,.08), rgba(15,59,120,.03));
    border-radius: 18px;
    padding: 18px;
}

.section-grid,
.room-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.room-grid--full { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.panel-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}

.panel-head a,
.btn-link {
    color: var(--primary);
    font-weight: 700;
}

.card-list,
.news-list {
    display: grid;
    gap: 14px;
}

.event-card,
.news-card,
.room-card {
    border: 1px solid rgba(15,59,120,.12);
    border-radius: 18px;
    padding: 16px;
    background: #fff;
}

.event-card {
    display: grid;
    grid-template-columns: 98px 1fr;
    gap: 16px;
    align-items: start;
}

.event-date {
    background: var(--accent);
    color: #222;
    font-weight: 700;
    border-radius: 16px;
    padding: 14px 12px;
    text-align: center;
}

.room-card img {
    border-radius: 16px;
    margin-bottom: 14px;
    height: 180px;
    width: 100%;
    object-fit: cover;
}

.single-panel { max-width: 1100px; }
.rich-text { line-height: 1.7; }
.lead { font-size: 1.1rem; opacity: .85; }
.cta-wrap { margin-top: 10px; }
.site-footer {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 20px 6px 40px;
    color: #4a5566;
}
.footer-meta { color: #4a5566; }
.footer-links { display: flex; gap: 18px; flex-wrap: wrap; margin-left: auto; justify-content: flex-end; text-align: right; }
.long-list { gap: 18px; }

@media (max-width: 1080px) {
    .site-shell {
        grid-template-columns: 1fr;
    }
    .sidebar {
        position: static;
        height: auto;
    }
    .intro-panel,
    .section-grid,
    .room-grid,
    .room-grid--full {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .content-area { padding: 16px; }
    .hero-content { padding: 24px; }
    .event-card { grid-template-columns: 1fr; }
    .site-footer { flex-direction: column; }
    .footer-links { margin-left: 0; justify-content: flex-start; text-align: left; }
}


.brand-logo-image {
    width: 100%;
    max-height: 86px;
    object-fit: contain;
    margin-bottom: 10px;
    background: rgba(255,255,255,.96);
    border-radius: 14px;
    padding: 10px;
}

.hero-slider-card {
    border-radius: 22px;
    overflow: hidden;
    background: #0f1725;
}
.hero-slider-image {
    width: 100%;
    min-height: var(--hero-height, 320px);
    max-height: 560px;
    object-fit: cover;
    display: block;
    transition: opacity .35s ease;
}
.hero-slider-image.is-fading { opacity: .25; }

.ad-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 16px;
}
.ad-card {
    display: block;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(15,59,120,.12);
    background: #fff;
}
.ad-card img {
    width: 100%;
    height: 230px;
    object-fit: cover;
}

.tap-popup {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.tap-popup__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 16, 28, .72);
}
.tap-popup__card {
    position: relative;
    z-index: 1;
    width: min(92vw, 880px);
    max-height: 90vh;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(0,0,0,.35);
}
.tap-popup__card img {
    width: 100%;
    max-height: 90vh;
    object-fit: contain;
    background: #fff;
}
.tap-popup__close {
    position: absolute;
    top: 10px;
    right: 12px;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 999px;
    background: rgba(0,0,0,.68);
    color: #fff;
    font-size: 1.8rem;
    cursor: pointer;
}
.tap-popup.is-hidden { display: none; }

@media (max-width: 720px) {
    .ad-grid {
        grid-template-columns: 1fr;
    }
    .hero-slider-image {
        min-height: 220px;
    }
}


.single-panel { max-width: 1100px; }

.contact-layout {
    display: grid;
    gap: 24px;
}
.contact-form {
    display: grid;
    gap: 16px;
}
.form-grid {
    display: grid;
    gap: 16px;
}
.form-grid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.contact-form label {
    display: block;
    margin-bottom: 6px;
    font-weight: 700;
}
.contact-form input,
.contact-form textarea {
    width: 100%;
    border: 1px solid rgba(15,59,120,.18);
    border-radius: 14px;
    padding: 12px 14px;
    background: rgba(255,255,255,.96);
    color: var(--text);
    font: inherit;
}
.contact-form textarea {
    resize: vertical;
    min-height: 180px;
}
.checkbox-row {
    display: flex !important;
    align-items: flex-start;
    gap: 10px;
    font-weight: 500 !important;
}
.checkbox-row input {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    flex: 0 0 auto;
}
.front-flash {
    border-radius: 14px;
    padding: 12px 14px;
    margin-bottom: 16px;
    font-weight: 700;
}
.front-flash--success {
    background: rgba(24, 160, 88, .12);
    border: 1px solid rgba(24, 160, 88, .24);
    color: #18633f;
}
.front-flash--error {
    background: rgba(184, 44, 44, .1);
    border: 1px solid rgba(184, 44, 44, .2);
    color: #842323;
}
.form-note {
    margin: 0;
    font-size: .92rem;
    opacity: .78;
}
.hp-field {
    position: absolute;
    left: -9999px;
    opacity: 0;
    pointer-events: none;
}
.muted-note {
    margin-top: -4px;
    color: rgba(28, 36, 48, .72);
}
@media (max-width: 1080px) {
    .contact-layout,
    .form-grid.two {
        grid-template-columns: 1fr;
    }
}


.calendar-head {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 22px;
}

.calendar-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.calendar-nav {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    border-radius: 14px;
    background: var(--primary);
    color: #fff;
    font-weight: 700;
}

.calendar-nav--ghost {
    background: rgba(15,59,120,.08);
    color: var(--primary);
}

.calendar-board {
    border: 1px solid rgba(15,59,120,.12);
    border-radius: 22px;
    overflow: hidden;
    background: #fff;
}

.calendar-weekdays,
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.calendar-weekdays div {
    background: rgba(15,59,120,.08);
    padding: 14px 10px;
    text-align: center;
    font-weight: 700;
    border-right: 1px solid rgba(15,59,120,.08);
}

.calendar-weekdays div:last-child {
    border-right: 0;
}

.calendar-day {
    min-height: 158px;
    padding: 12px;
    border-right: 1px solid rgba(15,59,120,.08);
    border-top: 1px solid rgba(15,59,120,.08);
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.calendar-day:nth-child(7n) {
    border-right: 0;
}

.calendar-day.is-muted {
    background: rgba(15,59,120,.03);
    color: rgba(28,36,48,.55);
}

.calendar-day.is-today {
    background: rgba(242,193,78,.18);
}

.calendar-day-top {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}

.calendar-day-count {
    font-size: .78rem;
    color: var(--primary);
    font-weight: 700;
}

.calendar-day-events {
    display: grid;
    gap: 8px;
}

.calendar-empty {
    color: rgba(28,36,48,.38);
}

.calendar-pill {
    display: grid;
    gap: 2px;
    background: rgba(15,59,120,.08);
    border: 1px solid rgba(15,59,120,.1);
    border-radius: 14px;
    padding: 8px 10px;
}

.calendar-pill:hover {
    background: rgba(15,59,120,.14);
}

.calendar-pill-time {
    font-size: .78rem;
    color: var(--primary);
    font-weight: 700;
}

.calendar-pill-title {
    font-size: .9rem;
    line-height: 1.35;
}

.month-agenda {
    display: grid;
    gap: 18px;
}

.agenda-day {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.agenda-date-box {
    background: rgba(15,59,120,.08);
    border-radius: 18px;
    padding: 18px;
    display: grid;
    gap: 6px;
}

.agenda-date-box strong {
    font-size: 1.1rem;
}

.agenda-items {
    display: grid;
    gap: 14px;
}

.event-card--full {
    grid-template-columns: 120px 1fr;
}

@media (max-width: 1080px) {
    .calendar-head,
    .agenda-day {
        grid-template-columns: 1fr;
        display: grid;
    }

    .calendar-actions {
        justify-content: flex-start;
    }

    .calendar-grid,
    .calendar-weekdays {
        grid-template-columns: repeat(7, minmax(120px, 1fr));
    }

    .calendar-board {
        overflow-x: auto;
    }
}

@media (max-width: 720px) {
    .calendar-grid,
    .calendar-weekdays {
        min-width: 840px;
    }

    .event-card--full {
        grid-template-columns: 1fr;
    }
}


.layout-stack {
    display: grid;
    gap: 24px;
}

.layout-width-narrow { max-width: 780px; }
.layout-width-normal { max-width: 1100px; }
.layout-width-wide { max-width: 1380px; }
.layout-width-full { max-width: none; }

.dynamic-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(var(--grid-columns, 1), minmax(0, 1fr));
}

.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr);
    gap: 24px;
}

.contact-layout--reverse > :first-child {
    order: 2;
}

.contact-layout--reverse > :last-child {
    order: 1;
}

.events-month-list {
    align-items: start;
}

.events-day-group {
    display: grid;
    gap: 12px;
}

.calendar-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 18px;
}

.calendar-toolbar__actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.calendar-month-head {
    margin-bottom: 12px;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 10px;
}

.calendar-weekday,
.calendar-day {
    border: 1px solid rgba(15,59,120,.12);
    border-radius: 16px;
    background: #fff;
}

.calendar-weekday {
    padding: 12px;
    font-weight: 700;
    text-align: center;
    background: rgba(15,59,120,.06);
}

.calendar-day {
    min-height: 140px;
    padding: 10px;
}

.calendar-day.is-muted {
    opacity: .45;
}

.calendar-day.is-today {
    outline: 2px solid var(--accent);
}

.calendar-day__header {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 8px;
    font-weight: 700;
}

.calendar-day__events {
    display: grid;
    gap: 8px;
}

.calendar-event-pill {
    display: block;
    padding: 8px 10px;
    border-radius: 12px;
    background: rgba(15,59,120,.08);
    font-size: .92rem;
}

.front-flash {
    padding: 14px 16px;
    border-radius: 14px;
    margin: 0 0 16px;
}

.front-flash--success { background: #dff7e7; color: #115c2c; }
.front-flash--error { background: #ffe5e5; color: #8a1f1f; }

.contact-form .form-grid.two {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-form label,
.checkbox-row {
    display: block;
    margin: 14px 0 8px;
}

.contact-form input,
.contact-form textarea,
.contact-form button {
    width: 100%;
    border-radius: 12px;
    border: 1px solid #cfd8e3;
    padding: 12px 14px;
    font: inherit;
}

.checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.checkbox-row input {
    width: auto;
    margin-top: 4px;
}

.hp-field {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

.form-note {
    margin: 12px 0 0;
    color: #5f6d7e;
}

@media (max-width: 1080px) {
    .contact-layout,
    .dynamic-grid,
    .calendar-grid,
    .contact-form .form-grid.two {
        grid-template-columns: 1fr;
    }

    .calendar-toolbar {
        flex-direction: column;
    }
}


.dynamic-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns, 2), minmax(0, 1fr));
    gap: 20px;
}

.ad-card {
    position: relative;
}

.ad-card__caption {
    position: absolute;
    inset: auto 0 0 0;
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    color: #fff;
    background: linear-gradient(180deg, rgba(7, 22, 48, 0), rgba(7, 22, 48, .85));
}

.ad-card__caption strong {
    font-size: 1rem;
}

.tap-top-grid {
    margin-top: 20px;
}

.tap-top-card {
    overflow: hidden;
    border: 1px solid rgba(15,59,120,.12);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15,59,120,.05);
}

.tap-top-card__image {
    width: 100%;
    height: 240px;
    object-fit: cover;
}

.tap-top-card__body {
    padding: 18px;
}

.tap-top-card__body h3 {
    margin: 8px 0 10px;
}

.tap-top-meta,
.tap-top-detail__meta {
    display: grid;
    gap: 8px;
    margin: 14px 0 16px;
    color: #425062;
}

.tap-top-detail__image {
    width: 100%;
    max-height: 520px;
    object-fit: cover;
    border-radius: 18px;
    margin: 18px 0 20px;
}

.tap-tops-intro-copy {
    margin-top: 8px;
}

@media (max-width: 1080px) {
    .dynamic-grid {
        grid-template-columns: 1fr;
    }

    .ad-grid {
        grid-template-columns: 1fr;
    }
}

.rich-text img,
.hero-text img {
    max-width: 100%;
    height: auto;
    border-radius: 16px;
}

.rich-text p:last-child,
.hero-text p:last-child {
    margin-bottom: 0;
}

.hero-text {
    max-width: 760px;
}

.gallery-section {
    margin-top: 28px;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 14px;
    margin-top: 14px;
}

.gallery-grid--compact {
    margin-top: 18px;
}

.gallery-thumb {
    display: block;
    border: 1px solid rgba(15,59,120,.12);
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    padding: 0;
    text-align: left;
    cursor: pointer;
}

.gallery-thumb--hero {
    width: 100%;
    margin-bottom: 16px;
}

.gallery-thumb img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
}

.gallery-thumb--hero img {
    height: 260px;
}

.gallery-thumb__caption {
    display: block;
    padding: 10px 12px;
    font-size: .92rem;
    color: #425062;
}

.gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
}

.gallery-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(7, 16, 31, .82);
}

.gallery-lightbox__dialog {
    position: relative;
    z-index: 2;
    width: min(1000px, calc(100vw - 32px));
    max-height: calc(100vh - 32px);
    margin: 16px auto;
    background: #fff;
    border-radius: 22px;
    padding: 20px 72px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .28);
}

.gallery-lightbox__figure {
    margin: 0;
}

.gallery-lightbox__image {
    display: block;
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
    border-radius: 18px;
    background: #edf3fb;
}

.gallery-lightbox__caption {
    margin-top: 14px;
    color: #24364b;
}

.gallery-lightbox__close,
.gallery-lightbox__nav {
    position: absolute;
    border: none;
    background: rgba(15, 59, 120, .12);
    color: #123a72;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    cursor: pointer;
}

.gallery-lightbox__close {
    top: 18px;
    right: 18px;
    font-size: 1.9rem;
    line-height: 1;
}

.gallery-lightbox__nav {
    top: 50%;
    transform: translateY(-50%);
    font-size: 2rem;
    line-height: 1;
}

.gallery-lightbox__nav--prev {
    left: 16px;
}

.gallery-lightbox__nav--next {
    right: 16px;
}

body.gallery-open {
    overflow: hidden;
}

@media (max-width: 720px) {
    .gallery-lightbox__dialog {
        padding: 16px 52px;
        width: calc(100vw - 20px);
        margin: 10px auto;
    }

    .gallery-thumb img,
    .gallery-thumb--hero img {
        height: 190px;
    }
}

.gallery-collection-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns, 3), minmax(0, 1fr));
    gap: 1.25rem;
}

.gallery-collection-card {
    position: relative;
}

.gallery-collection-card__link {
    display: block;
    position: relative;
    background: #fff;
    border-radius: 1.25rem;
    overflow: hidden;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 18px 42px rgba(15, 34, 64, 0.12);
    border: 1px solid rgba(15, 59, 120, 0.08);
}

.gallery-collection-card__tab {
    position: absolute;
    top: -1px;
    left: 1.25rem;
    width: 5.5rem;
    height: 1.2rem;
    background: linear-gradient(135deg, var(--accent), #f8d87e);
    border-radius: 1rem 1rem 0 0;
    z-index: 2;
}

.gallery-collection-card__cover {
    background: linear-gradient(135deg, rgba(15, 59, 120, 0.09), rgba(23, 75, 150, 0.15));
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-collection-card__cover img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}

.gallery-collection-card__placeholder {
    font-size: 4rem;
    opacity: 0.8;
}

.gallery-collection-card__body {
    padding: 1.1rem 1.2rem 1.25rem;
}

.gallery-collection-card__body h3 {
    margin: 0 0 0.5rem;
}

.gallery-collection-card__intro {
    color: rgba(28, 36, 48, 0.85);
}

.gallery-collection-card__count {
    display: inline-flex;
    margin-top: 0.85rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(15, 59, 120, 0.08);
    color: var(--primary);
    font-weight: 700;
    font-size: 0.9rem;
}

.gallery-page-grid {
    margin-top: 1rem;
}

@media (max-width: 980px) {
    .gallery-collection-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .gallery-collection-grid {
        grid-template-columns: 1fr;
    }
}

/* Room image frame removal fix */
.room-card img,
.room-card-image img,
.room-card a img,
.rooms-grid img,
.room-grid img {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    background: transparent !important;
}

.room-card-image,
.room-card figure,
.room-card a {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    background: transparent !important;
}
