﻿:root {
    --contact-accent: #a50012;
    --contact-accent-2: #d51c2f;
    --contact-ink: #0d1117;
    --contact-soft: rgba(13,17,23,.68);
    --contact-muted: rgba(13,17,23,.48);
    --contact-line: rgba(13,17,23,.12);
    --contact-line-strong: rgba(165,0,18,.22);
    --contact-white: rgba(255,255,255,.92);
    --contact-white-strong: rgba(255,255,255,.98);
    --contact-glass: rgba(247,247,247,.82);
    --contact-radius: 28px;
    --contact-radius-sm: 16px;
    --contact-shadow: 0 34px 90px rgba(0,0,0,.28), 0 12px 32px rgba(0,0,0,.18);
    --contact-shadow-soft: 0 18px 42px rgba(0,0,0,.12);
}

.modal-site-contact {
    --bs-modal-width: 560px;
}

    .modal-site-contact .modal-dialog {
        width: min(560px, calc(100vw - 28px));
        max-width: min(560px, calc(100vw - 28px));
        margin-left: auto;
        margin-right: auto;
    }

    .modal-site-contact .modal-content {
        position: relative;
        overflow: hidden;
        border: 1px solid rgba(255,255,255,.62);
        border-radius: var(--contact-radius);
        background: radial-gradient(720px 220px at 12% -8%, rgba(165,0,18,.14), transparent 58%), radial-gradient(520px 220px at 100% 0%, rgba(255,255,255,.72), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.94), rgba(238,236,233,.86));
        box-shadow: var(--contact-shadow);
        backdrop-filter: blur(22px) saturate(1.18);
        -webkit-backdrop-filter: blur(22px) saturate(1.18);
    }

        .modal-site-contact .modal-content::before {
            content: "";
            position: absolute;
            inset: 0;
            pointer-events: none;
            background: linear-gradient(90deg, rgba(255,255,255,.45), transparent 28%, rgba(255,255,255,.22)), radial-gradient(520px 160px at 50% 0%, rgba(255,255,255,.74), transparent 70%);
            opacity: .95;
        }

        .modal-site-contact .modal-content::after {
            content: "";
            position: absolute;
            left: 22px;
            right: 22px;
            top: 58px;
            height: 1px;
            background: linear-gradient(90deg, rgba(165,0,18,.35), rgba(13,17,23,.10), transparent);
            pointer-events: none;
        }

    .modal-site-contact .modal-header,
    .modal-site-contact .modal-body {
        position: relative;
        z-index: 1;
    }

    .modal-site-contact .modal-header {
        min-height: 70px;
        padding: 22px 24px 16px;
        border-bottom: 1px solid rgba(13,17,23,.08);
        background: rgba(255,255,255,.18);
    }

    .modal-site-contact .modal-title {
        position: relative;
        margin: 0;
        color: var(--contact-ink);
        font-size: clamp(1.25rem, 2.2vw, 1.55rem);
        line-height: 1.1;
        font-weight: 950;
        letter-spacing: -.035em;
    }

        .modal-site-contact .modal-title::after {
            content: "";
            display: block;
            width: 46px;
            height: 2px;
            margin-top: 12px;
            border-radius: 999px;
            background: linear-gradient(90deg, var(--contact-accent), rgba(165,0,18,.12));
        }

    .modal-site-contact .btn-close {
        width: 42px;
        height: 42px;
        margin: 0;
        padding: 0;
        border-radius: 999px;
        background-color: rgba(255,255,255,.78);
        border: 1px solid rgba(13,17,23,.08);
        box-shadow: 0 12px 26px rgba(0,0,0,.10);
        opacity: 1;
        transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
    }

        .modal-site-contact .btn-close:hover {
            transform: translateY(-1px);
            background-color: rgba(255,255,255,.96);
            box-shadow: 0 16px 34px rgba(0,0,0,.14);
        }

        .modal-site-contact .btn-close:active {
            transform: translateY(0);
            box-shadow: 0 8px 18px rgba(0,0,0,.10);
        }

    .modal-site-contact .modal-body {
        padding: 22px 24px 24px;
    }

    .modal-site-contact form {
        display: grid;
        gap: 16px;
        margin: 0;
    }

    .modal-site-contact .mb-3 {
        margin: 0 !important;
    }

    .modal-site-contact .form-label {
        display: block;
        margin: 0 0 7px;
        color: rgba(13,17,23,.88);
        font-size: .82rem;
        line-height: 1.2;
        font-weight: 900;
        letter-spacing: -.01em;
    }

    .modal-site-contact .form-control {
        width: 100%;
        min-height: 48px;
        padding: 13px 15px;
        border: 1px solid rgba(13,17,23,.10);
        border-radius: var(--contact-radius-sm);
        background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.88));
        color: var(--contact-ink);
        font-size: 1rem;
        font-weight: 650;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.84), 0 12px 28px rgba(0,0,0,.055);
        outline: none;
        transition: border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .18s ease;
    }

    .modal-site-contact textarea.form-control {
        min-height: 138px;
        resize: vertical;
    }

    .modal-site-contact .form-control:hover {
        border-color: rgba(13,17,23,.17);
        background: linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,.92));
    }

    .modal-site-contact .form-control:focus {
        border-color: rgba(165,0,18,.42);
        background: rgba(255,255,255,.98);
        box-shadow: 0 0 0 4px rgba(165,0,18,.12), 0 16px 36px rgba(0,0,0,.10);
        transform: translateY(-1px);
    }

    .modal-site-contact .form-control::placeholder {
        color: rgba(13,17,23,.36);
    }

    .modal-site-contact .btn-primary {
        justify-self: start;
        min-width: 136px;
        height: 46px;
        padding: 0 24px;
        border: 0;
        border-radius: 999px;
        background: linear-gradient(180deg, rgba(213,28,47,1), rgba(165,0,18,1));
        color: #fff;
        font-size: .96rem;
        font-weight: 950;
        letter-spacing: -.015em;
        box-shadow: 0 18px 36px rgba(165,0,18,.28), inset 0 1px 0 rgba(255,255,255,.28);
        transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
    }

        .modal-site-contact .btn-primary:hover {
            transform: translateY(-2px);
            filter: saturate(1.05) brightness(1.02);
            box-shadow: 0 24px 46px rgba(165,0,18,.34), inset 0 1px 0 rgba(255,255,255,.32);
        }

        .modal-site-contact .btn-primary:active {
            transform: translateY(0);
            box-shadow: 0 12px 26px rgba(165,0,18,.24), inset 0 1px 0 rgba(255,255,255,.22);
        }

        .modal-site-contact .btn-primary:focus-visible {
            outline: none;
            box-shadow: 0 0 0 4px rgba(165,0,18,.18), 0 18px 36px rgba(165,0,18,.28);
        }

.contact-page {
    padding: clamp(28px, 5vw, 70px) 0 clamp(48px, 6vw, 86px);
}

.contact-wrap {
    max-width: 1040px;
    margin: 0 auto;
    padding: 0 16px;
}

.contact-hero {
    position: relative;
    padding: clamp(22px, 3.5vw, 36px);
    border-radius: 30px;
    background: radial-gradient(760px 280px at 12% 0%, rgba(165,0,18,.12), transparent 58%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,246,248,.86));
    box-shadow: 0 26px 72px rgba(15,23,42,.18);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.58);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.contact-title {
    margin: 0 0 10px;
    font-weight: 950;
    letter-spacing: -.035em;
    font-size: clamp(2.25rem, 3.2vw, 3.1rem);
    color: var(--contact-ink);
}

.contact-lead {
    margin: 0;
    max-width: 72ch;
    font-size: 1.06rem;
    line-height: 1.75;
    color: var(--contact-soft);
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 18px;
}

.contact-card {
    position: relative;
    border-radius: 24px;
    background: radial-gradient(620px 240px at 0% 0%, rgba(255,255,255,.72), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,246,248,.86));
    box-shadow: 0 18px 44px rgba(15,23,42,.14);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.58);
    transform: translateZ(0);
    transition: transform .2s ease, box-shadow .2s ease;
}

    .contact-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 24px 62px rgba(15,23,42,.18);
    }

.contact-card-inner {
    position: relative;
    padding: 22px;
    z-index: 1;
}

.contact-label {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .16em;
    color: var(--contact-muted);
    margin-bottom: 12px;
    font-weight: 900;
}

.contact-address {
    color: rgba(15,23,42,.86);
    line-height: 1.72;
    font-size: 1.02rem;
}

    .contact-address strong {
        display: block;
        font-weight: 950;
        margin-bottom: 6px;
        letter-spacing: -.01em;
    }

.contact-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

.contact-action {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(15,23,42,.06);
    color: rgba(15,23,42,.86);
    text-decoration: none;
    font-weight: 900;
    border: 1px solid rgba(15,23,42,.08);
    transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

    .contact-action:hover {
        transform: translateY(-1px);
        background: rgba(15,23,42,.085);
        box-shadow: 0 10px 24px rgba(15,23,42,.10);
    }

.contact-form-shell :is(input, textarea, select) {
    border-radius: 16px !important;
    border: 1px solid rgba(15,23,42,.12) !important;
    background: rgba(255,255,255,.92) !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.06);
    transition: box-shadow .18s ease, border-color .18s ease, transform .18s ease;
}

    .contact-form-shell :is(input, textarea, select):focus {
        border-color: rgba(165,0,18,.42) !important;
        box-shadow: 0 0 0 4px rgba(165,0,18,.12), 0 16px 34px rgba(15,23,42,.10);
        outline: none;
    }

.contact-form-shell textarea {
    min-height: 150px;
    resize: vertical;
}

.contact-form-shell .btn,
.contact-form-shell button[type="submit"] {
    border: 0 !important;
    border-radius: 999px !important;
    padding: 11px 20px !important;
    background: linear-gradient(180deg, rgba(213,28,47,1), rgba(165,0,18,1)) !important;
    color: #fff !important;
    font-weight: 950;
    letter-spacing: -.01em;
    box-shadow: 0 16px 32px rgba(165,0,18,.26);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

    .contact-form-shell .btn:hover,
    .contact-form-shell button[type="submit"]:hover {
        transform: translateY(-1px);
        box-shadow: 0 20px 40px rgba(165,0,18,.32);
    }

@media (min-width: 768px) {
    .modal-site-contact .modal-dialog {
        margin-top: 16vh;
        margin-bottom: 7vh;
    }
}

@media (min-width: 992px) {
    .contact-grid {
        grid-template-columns: 1fr 1.15fr;
        gap: 24px;
        margin-top: 24px;
    }
}

@media (max-width: 767px) {
    .modal-site-contact {
        --bs-modal-margin: 10px;
    }

        .modal-site-contact .modal-dialog {
            width: calc(100vw - 20px);
            max-width: calc(100vw - 20px);
            margin: 10px auto;
        }

        .modal-site-contact .modal-content {
            border-radius: 22px;
        }

        .modal-site-contact .modal-header {
            min-height: 64px;
            padding: 18px 18px 14px;
        }

        .modal-site-contact .modal-body {
            padding: 18px;
        }

        .modal-site-contact form {
            gap: 14px;
        }

        .modal-site-contact .form-control {
            min-height: 46px;
            padding: 12px 14px;
            border-radius: 14px;
            font-size: .98rem;
        }

        .modal-site-contact textarea.form-control {
            min-height: 130px;
        }

        .modal-site-contact .btn-primary {
            width: 100%;
            justify-self: stretch;
        }
}

@media (max-width: 480px) {
    .modal-site-contact .modal-dialog {
        width: calc(100vw - 14px);
        max-width: calc(100vw - 14px);
        margin: 7px auto;
    }

    .modal-site-contact .modal-header {
        padding: 16px 16px 12px;
    }

    .modal-site-contact .modal-body {
        padding: 16px;
    }

    .modal-site-contact .modal-title {
        font-size: 1.22rem;
    }

    .modal-site-contact .btn-close {
        width: 38px;
        height: 38px;
    }

    .modal-site-contact .form-label {
        font-size: .8rem;
    }

    .modal-site-contact .form-control {
        min-height: 44px;
    }

    .modal-site-contact textarea.form-control {
        min-height: 118px;
    }
}

@media (max-height: 720px) and (min-width: 768px) {
    .modal-site-contact .modal-dialog {
        margin-top: 16vh!important;
        margin-bottom: 4vh;
    }

    .modal-site-contact .modal-header {
        min-height: 62px;
        padding-top: 16px;
        padding-bottom: 12px;
    }

    .modal-site-contact .modal-body {
        padding-top: 16px;
    }

    .modal-site-contact form {
        gap: 12px;
    }

    .modal-site-contact textarea.form-control {
        min-height: 104px;
    }
}
@media (max-width: 580px) {
    .modal-site-contact .modal-dialog {
        width: calc(100vw - 20px) !important;
        max-width: calc(100vw - 20px) !important;
        margin-top: 72px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        margin-bottom: 24px !important;
    }
}

@media (max-width: 480px) {
    .modal-site-contact .modal-dialog {
        width: calc(100vw - 14px) !important;
        max-width: calc(100vw - 14px) !important;
        margin-top: 64px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        margin-bottom: 18px !important;
    }
}

@media (max-height: 680px) and (max-width: 580px) {
    .modal-site-contact .modal-dialog {
        margin-top: 38px !important;
        margin-bottom: 14px !important;
    }

    .modal-site-contact .modal-header {
        min-height: 58px;
        padding-top: 14px;
        padding-bottom: 10px;
    }

    .modal-site-contact .modal-body {
        padding-top: 14px;
        padding-bottom: 16px;
    }

    .modal-site-contact form {
        gap: 11px;
    }

    .modal-site-contact textarea.form-control {
        min-height: 92px;
    }
}