﻿/* ============================================================
   HOTSPOT STYLES
============================================================ */

/* Common styles for hotspot circles */
.ggskin.ggskin_hotspot .ggskin.ggskin_text > div {
    font-family: 'Arial', sans-serif;
    font-size: 12px;
    font-weight: bold;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease-in-out;
    border: solid 3px;
    cursor: pointer;
    overflow-y: 0 !important;
}

    .ggskin.ggskin_hotspot .ggskin.ggskin_text > div:hover {
        transform: scale(1.3);
    }

/* Temperature Hotspots */
.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureBlue > div {
    background: #1E3A8A;
    color: #E0F2FE;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureGreen > div {
    background: #15803D;
    color: #ECFDF5;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureOrange > div {
    background: #D97706;
    color: #FFF7ED;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureRed > div {
    background: #B91C1C;
    color: #FEE2E2;
}

/* Wind Hotspots */
.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectWind > div {
    background: #ADD8E6;
    color: #115b73;
}

/* Info / Image / URL / POI / Price hotspots */
.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectInfo > div {
    font-family: 'Times New Roman', serif;
    font-size: 30px;
    font-weight: bold;
    font-style: italic;
    background: #000;
    color: #fff;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectImage > div {
    font-family: 'Font Awesome 6 Free', sans-serif;
    font-size: 22px;
    background: #000;
    color: #fff;
}

    .ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectImage > div::before {
        content: "\f03e";
    }

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectUrl > div {
    font-family: 'Font Awesome 6 Free';
    font-size: 27px;
    background: #000;
    color: #fff;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectPrice > div {
    background: #000;
    color: #fff;
    font-size: 12px;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectPOI > div {
    font-family: 'Font Awesome 6 Free';
    background: #000;
    color: #fff;
    font-size: 17px;
}

/* Car Park Hotspot */
.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectCarPark > div {
    background: #005BAC;
    color: #fff;
    font-size: 20px;
    font-family: 'Arial';
    width: 100%;
}


/* ============================================================
   MODAL BACKGROUND
============================================================ */

.infoBg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background-image: url("../images/background.jpg") !important;
    background-repeat: repeat !important;
    background-size: auto !important;
    z-index: 9999;
    overflow: hidden;
}

    .infoBg::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0,0,0,0.55);
        mix-blend-mode: multiply;
        pointer-events: none;
    }

/* ============================================================
   MODAL CONTENT (WHITE BOX)
============================================================ */

.infoContentBg {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
/*    background: #ffffff;*/
    padding: 3rem 3.5rem !important;
    border-radius: 12px;
    box-shadow: 0 4px 18px rgba(0,0,0,0.08);
    overflow-y: hidden;
}

    .infoContentBg,
    .infoContentBg * {
        color: #fff !important;
        fill: #000 !important;
        stroke: #000 !important;
    }


/* ============================================================
   POLAROID IMAGES
============================================================ */

img.ggskin.ggskin_external {
    background: #fff !important;
    padding: 18px;
    border-radius: 3px;
    border: 1px solid #e6e6e6;
    box-shadow: 0 8px 22px rgba(0,0,0,0.45);
    transform: rotate(-2deg);
    box-sizing: border-box;
}


/* ============================================================
   WEATHER TABLE
============================================================ */

.weather-card {
    margin-bottom: -50px !important;
    overflow: hidden !important;
}


.weather-title {
    margin-top: -60px !important;
}

.weather-table {
    width: 90%;
    border-collapse: collapse;
    table-layout: fixed;
    margin: 0 !important;
    margin-top: -40px !important;
}

    .weather-table tr {
        border-bottom: 1px solid rgba(0,0,0,0.12);
    }

        .weather-table tr:last-child {
            border-bottom: none;
        }

    .weather-table th {
        padding: 0.15rem 0.15rem;
        font-size: 0.9rem;
        text-transform: uppercase;
        font-weight: 600;
        color: #fff;
        display: flex;
        gap: 0.45rem;
    }

    .weather-table td {
        padding: 0.15rem 0.15rem !important;
        text-align: right;
        font-size: 1rem;
        font-weight: 700;
        color: #fff;
    }

    .weather-table tr:hover {
        background: rgba(0,0,0,0.05);
    }


/* ============================================================
   VIRTUAL TOUR CONTENT (vt-content)
============================================================ */

#vt-content {
    /*    font-family: 'Cinzel', Georgia, serif;*/
    font-family: 'Arial', sans-serif;
    margin: 0;
    padding: 0;
    color: #333;
}

    /* Tight, consistent spacing */
    #vt-content .vt-section {
        margin: 0 0 2rem 0 !important;
        padding: 0 !important;
    }

    /* Headings */
    #vt-content .vt-heading {
        /*        font-family: 'Cinzel', Georgia, serif;*/
        font-family: 'Arial', sans-serif;
        margin: 0 0 1rem 0 !important;
        padding: 0 !important;
        letter-spacing: 0.5px;
        line-height: 1.25;
        color: #111 !important;
    }

    #vt-content .vt-heading-xl {
        font-size: 2.4rem;
    }

    #vt-content .vt-heading-lg {
        font-size: 2rem;
    }

    #vt-content .vt-heading-md {
        font-size: 1.6rem;
    }

    /* Paragraph spacing */
    #vt-content .vt-paragraph {
        margin: 0 0 1.1rem 0 !important;
        line-height: 1.6;
        font-size: 1.05rem;
        color: #333 !important;
    }

    /* Lists */
    #vt-content ul {
        margin: 0.4rem 0 1.4rem 1.2rem !important;
        padding: 0 !important;
    }

    #vt-content li {
        margin: 0 0 0.55rem 0 !important;
        font-size: 1.05rem;
    }

    /* Emphasis */
    #vt-content .vt-emphasis-bold {
        font-weight: bold;
    }

    #vt-content .vt-emphasis-italic {
        font-style: italic;
    }

    #vt-content .vt-emphasis-highlight {
        background: #ffdd8a;
        border-radius: 4px;
        padding: 0 4px;
    }

    /* Links */
    #vt-content a {
        color: #c04b2b !important;
        text-decoration: underline;
    }

        #vt-content a:hover {
            color: #e06a4a !important;
        }

    /* Images */
    #vt-content .vt-image {
        display: block;
        max-width: 100%;
        height: auto;
        border-radius: 10px;
    }

    #vt-content .vt-image-shadow {
        box-shadow: 0 4px 16px rgba(0,0,0,0.15);
    }

    #vt-content .vt-image-wrapper {
        text-align: center;
        margin: 1rem 0;
    }

    #vt-content .vt-caption {
        margin-top: 0.4rem;
        font-size: 0.9rem;
        opacity: 0.8;
    }

    /* Grids */
    #vt-content .vt-grid {
        display: grid;
        gap: 1rem;
        grid-template-columns: 1fr;
    }

    #vt-content .vt-grid-2 {
        grid-template-columns: repeat(2,1fr);
    }

    #vt-content .vt-grid-3 {
        grid-template-columns: repeat(3,1fr);
    }

    #vt-content .vt-grid-4 {
        grid-template-columns: repeat(4,1fr);
    }

    #vt-content .vt-columns {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

@media (min-width:768px) {
    #vt-content .vt-columns {
        flex-direction: row;
    }

    #vt-content .vt-col {
        flex: 1;
    }
}

/* Utilities */
#vt-content .vt-mb-1 {
    margin-bottom: 0.5rem !important;
}

#vt-content .vt-mb-2 {
    margin-bottom: 1rem !important;
}

#vt-content .vt-mb-3 {
    margin-bottom: 2rem !important;
}

#vt-content .vt-pt-2 {
    padding-top: 1rem !important;
}

#vt-content .vt-pt-3 {
    padding-top: 2rem !important;
}

#vt-content .vt-py-3 {
    padding: 2rem 0 !important;
}





/* ============================================================
   HOTSPOT STYLES
============================================================ */

/* Common styles for hotspot circles */
/*.ggskin.ggskin_hotspot .ggskin.ggskin_text > div {
    font-family: 'Arial', sans-serif;
    font-size: 12px;
    font-weight: bold;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease-in-out;
    border: solid 3px;
    cursor: pointer;
    overflow-y: 0 !important;
}

    .ggskin.ggskin_hotspot .ggskin.ggskin_text > div:hover {
        transform: scale(1.3);
    }*/

/* Temperature Hotspots */
/*.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureBlue > div {
    background: #079eed;
    color: #003366;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureGreen > div {
    background: #B0E57C;
    color: #2F6A3F;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureOrange > div {
    background: #FFB84D;
    color: #FF6F00;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectTemperatureRed > div {
    background: #FF6666;
    color: #B33B3B;
}*/

/* Wind Hotspots */
/*.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectWind > div {
    background: #ADD8E6;
    color: #115b73;
}*/

/* Info / Image / URL / POI / Price hotspots */
/*.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectInfo > div {
    font-family: 'Times New Roman', serif;
    font-size: 30px;
    font-weight: bold;
    font-style: italic;
    background: #000;
    color: #fff;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectImage > div {
    font-family: 'Font Awesome 6 Free', sans-serif;
    font-size: 22px;
    background: #000;
    color: #fff;
}

    .ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectImage > div::before {
        content: "\f03e";
    }

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectUrl > div {
    font-family: 'Font Awesome 6 Free';
    font-size: 27px;
    background: #000;
    color: #fff;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectPrice > div {
    background: #000;
    color: #fff;
    font-size: 12px;
}

.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectPOI > div {
    font-family: 'Font Awesome 6 Free';
    background: #000;
    color: #fff;
    font-size: 17px;
}*/

/* Car Park Hotspot */
/*.ggskin.ggskin_hotspot .ggskin.ggskin_text.vtConnectCarPark > div {
    background: #005BAC;
    color: #fff;
    font-size: 20px;
    font-family: 'Arial';
    width: 100%;
}*/


/* ============================================================
   MODAL BACKGROUND
============================================================ */

/*.infoBg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background-image: url("../images/background.jpg") !important;
    background-repeat: repeat !important;
    background-size: auto !important;
    z-index: 9999;
    overflow: hidden;
}

    .infoBg::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0,0,0,0.25);
        mix-blend-mode: multiply;
        pointer-events: none;
    }*/

/* ============================================================
   MODAL CONTENT (WHITE BOX)
============================================================ */

/*.infoContentBg {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    background: #ffffff;
    padding: 3rem 3.5rem !important;
    border-radius: 12px;
    box-shadow: 0 4px 18px rgba(0,0,0,0.08);
    overflow-y: auto;
}

    .infoContentBg,
    .infoContentBg * {
        color: #000 !important;
        fill: #000 !important;
        stroke: #000 !important;
    }*/


/* ============================================================
   POLAROID IMAGES
============================================================ */

/*img.ggskin.ggskin_external {
    background: #fff !important;
    padding: 18px;
    border-radius: 3px;
    border: 1px solid #e6e6e6;
    box-shadow: 0 8px 22px rgba(0,0,0,0.45);
    transform: rotate(-2deg);
    box-sizing: border-box;
}*/


/* ============================================================
   WEATHER TABLE
============================================================ */

/*.weather-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    margin: 0;
}

    .weather-table tr {
        border-bottom: 1px solid rgba(0,0,0,0.12);
    }

        .weather-table tr:last-child {
            border-bottom: none;
        }

    .weather-table th {
        padding: 0.55rem 0.25rem;
        font-size: 0.9rem;
        text-transform: uppercase;
        font-weight: 600;
        color: #333;
        display: flex;
        gap: 0.45rem;
    }

    .weather-table td {
        padding: 0.35rem 0.25rem;
        text-align: right;
        font-size: 1rem;
        font-weight: 700;
        color: #000;
    }

    .weather-table tr:hover {
        background: rgba(0,0,0,0.05);
    }*/


/* ============================================================
   VIRTUAL TOUR CONTENT (vt-content)
============================================================ */

/*#vt-content {
    font-family: 'Roboto', system-ui, sans-serif;
    margin: 0;
    padding: 0;
    color: #333;
}*/

    /* Tight, consistent spacing */
    /*#vt-content .vt-section {
        margin: 0 0 2rem 0 !important;
        padding: 0 !important;
    }*/

    /* Headings */
    /*#vt-content .vt-heading {
        font-family: 'Cinzel', Georgia, serif;
        margin: 0 0 1rem 0 !important;
        padding: 0 !important;
        letter-spacing: 0.5px;
        line-height: 1.25;
        color: #111 !important;
    }

    #vt-content .vt-heading-xl {
        font-size: 2.4rem;
    }

    #vt-content .vt-heading-lg {
        font-size: 2rem;
    }

    #vt-content .vt-heading-md {
        font-size: 1.6rem;
    }*/

    /* Paragraph spacing */
    /*#vt-content .vt-paragraph {
        margin: 0 0 1.1rem 0 !important;
        line-height: 1.6;
        font-size: 1.05rem;
        color: #333 !important;
    }*/

    /* Lists */
    /*#vt-content ul {
        margin: 0.4rem 0 1.4rem 1.2rem !important;
        padding: 0 !important;
    }

    #vt-content li {
        margin: 0 0 0.55rem 0 !important;
        font-size: 1.05rem;
    }*/

    /* Emphasis */
    /*#vt-content .vt-emphasis-bold {
        font-weight: bold;
    }

    #vt-content .vt-emphasis-italic {
        font-style: italic;
    }

    #vt-content .vt-emphasis-highlight {
        background: #ffdd8a;
        border-radius: 4px;
        padding: 0 4px;
    }*/

    /* Links */
    /*#vt-content a {
        color: #c04b2b !important;
        text-decoration: underline;
    }

        #vt-content a:hover {
            color: #e06a4a !important;
        }*/

    /* Images */
    /*#vt-content .vt-image {
        display: block;
        max-width: 100%;
        height: auto;
        border-radius: 10px;
    }

    #vt-content .vt-image-shadow {
        box-shadow: 0 4px 16px rgba(0,0,0,0.15);
    }

    #vt-content .vt-image-wrapper {
        text-align: center;
        margin: 1rem 0;
    }

    #vt-content .vt-caption {
        margin-top: 0.4rem;
        font-size: 0.9rem;
        opacity: 0.8;
    }*/

    /* Grids */
    /*#vt-content .vt-grid {
        display: grid;
        gap: 1rem;
        grid-template-columns: 1fr;
    }

    #vt-content .vt-grid-2 {
        grid-template-columns: repeat(2,1fr);
    }

    #vt-content .vt-grid-3 {
        grid-template-columns: repeat(3,1fr);
    }

    #vt-content .vt-grid-4 {
        grid-template-columns: repeat(4,1fr);
    }

    #vt-content .vt-columns {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

@media (min-width:768px) {
    #vt-content .vt-columns {
        flex-direction: row;
    }

    #vt-content .vt-col {
        flex: 1;
    }
}*/

/* Utilities */
/*#vt-content .vt-mb-1 {
    margin-bottom: 0.5rem !important;
}

#vt-content .vt-mb-2 {
    margin-bottom: 1rem !important;
}

#vt-content .vt-mb-3 {
    margin-bottom: 2rem !important;
}

#vt-content .vt-pt-2 {
    padding-top: 1rem !important;
}

#vt-content .vt-pt-3 {
    padding-top: 2rem !important;
}

#vt-content .vt-py-3 {
    padding: 2rem 0 !important;
}*/
