﻿:root {
    --ld-contact-bg-1: #ece8e2;
    --ld-contact-bg-2: #ddd6ce;
    --ld-contact-bg-3: #c9c0b7;
    --ld-contact-ink: #111214;
    --ld-contact-ink-soft: rgba(17,18,20,.72);
    --ld-contact-ink-muted: rgba(17,18,20,.52);
    --ld-contact-line: rgba(17,18,20,.12);
    --ld-contact-line-strong: rgba(17,18,20,.20);
    --ld-contact-white: rgba(255,255,255,.92);
    --ld-contact-white-soft: rgba(255,255,255,.74);
    --ld-contact-white-strong: rgba(255,255,255,.98);
    --ld-contact-card: rgba(255,255,255,.76);
    --ld-contact-card-strong: rgba(255,255,255,.90);
    --ld-contact-red: #b40716;
    --ld-contact-red-dark: #7d0710;
    --ld-contact-red-soft: rgba(180,7,22,.13);
    --ld-contact-red-line: rgba(180,7,22,.30);
    --ld-contact-shadow-sm: 0 14px 34px rgba(17,18,20,.10);
    --ld-contact-shadow-md: 0 24px 70px rgba(17,18,20,.15);
    --ld-contact-shadow-lg: 0 34px 105px rgba(17,18,20,.22);
    --ld-contact-radius-xl: 32px;
    --ld-contact-radius-lg: 26px;
    --ld-contact-radius-md: 18px;
}

body {
    margin-top: 0 !important;
    background: radial-gradient(980px 540px at 72% 14%, rgba(180,7,22,.085), transparent 64%), radial-gradient(900px 560px at 26% -8%, rgba(255,255,255,.78), transparent 68%), linear-gradient(180deg, var(--ld-contact-bg-1) 0%, var(--ld-contact-bg-2) 48%, var(--ld-contact-bg-3) 100%);
    color: var(--ld-contact-ink);
}

.contact-page {
    position: relative;
    min-height: calc(100vh - 120px);
    padding: clamp(120px, 15vh, 185px) 0 clamp(70px, 8vw, 120px);
    overflow: hidden;
}

    .contact-page::before {
        content: "";
        position: absolute;
        width: 760px;
        height: 760px;
        right: -260px;
        top: 80px;
        border-radius: 999px;
        background: radial-gradient(circle at 38% 38%, rgba(180,7,22,.13), transparent 34%), radial-gradient(circle at 50% 50%, rgba(255,255,255,.42), transparent 58%);
        filter: blur(2px);
        opacity: .82;
        pointer-events: none;
    }

    .contact-page::after {
        content: "";
        position: absolute;
        width: 640px;
        height: 420px;
        left: -170px;
        bottom: -160px;
        border-radius: 999px;
        background: radial-gradient(circle, rgba(17,18,20,.08), transparent 66%);
        pointer-events: none;
    }

.contact-wrap {
    position: relative;
    z-index: 1;
    width: min(1040px, calc(100% - 36px));
    margin: 0 auto;
    padding: 0;
}

.contact-hero {
    position: relative;
    isolation: isolate;
    padding: clamp(30px, 4vw, 48px);
    border-radius: var(--ld-contact-radius-xl);
    background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(255,255,255,.72) 54%, rgba(246,242,237,.82)), linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.54));
    border: 1px solid rgba(255,255,255,.66);
    box-shadow: var(--ld-contact-shadow-md);
    backdrop-filter: blur(18px) saturate(1.12);
    -webkit-backdrop-filter: blur(18px) saturate(1.12);
    overflow: hidden;
}

    .contact-hero::before {
        content: "";
        position: absolute;
        inset: auto -120px -170px auto;
        width: 520px;
        height: 420px;
        border-radius: 999px;
        background: radial-gradient(circle, rgba(180,7,22,.17), rgba(180,7,22,.07) 42%, transparent 72%);
        pointer-events: none;
        z-index: -1;
    }

    .contact-hero::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, rgba(17,18,20,.045), transparent 34%), radial-gradient(620px 180px at 10% 0%, rgba(255,255,255,.70), transparent 72%);
        pointer-events: none;
        z-index: -1;
    }

.contact-title {
    position: relative;
    margin: 0 0 14px;
    color: var(--ld-contact-ink);
    font-size: clamp(2.45rem, 4.2vw, 4rem);
    line-height: .96;
    font-weight: 950;
    letter-spacing: -.06em;
}

    .contact-title::after {
        content: "";
        display: block;
        width: 58px;
        height: 3px;
        margin-top: 18px;
        border-radius: 999px;
        background: linear-gradient(90deg, var(--ld-contact-red), rgba(180,7,22,0));
    }

.contact-lead {
    margin: 0;
    max-width: 680px;
    color: var(--ld-contact-ink-soft);
    font-size: clamp(1rem, 1.25vw, 1.12rem);
    line-height: 1.82;
    font-weight: 500;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(18px, 2vw, 26px);
    margin-top: clamp(20px, 2.5vw, 30px);
}

.contact-card {
    position: relative;
    isolation: isolate;
    min-height: 100%;
    border-radius: var(--ld-contact-radius-lg);
    background: linear-gradient(145deg, rgba(255,255,255,.88), rgba(255,255,255,.66) 54%, rgba(245,242,238,.78)), linear-gradient(180deg, var(--ld-contact-card-strong), var(--ld-contact-card));
    border: 1px solid rgba(255,255,255,.68);
    box-shadow: var(--ld-contact-shadow-sm);
    overflow: hidden;
    transform: translateZ(0);
    transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
    backdrop-filter: blur(16px) saturate(1.10);
    -webkit-backdrop-filter: blur(16px) saturate(1.10);
}

    .contact-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--ld-contact-shadow-md);
        border-color: rgba(255,255,255,.84);
    }

    .contact-card::before {
        content: "";
        position: absolute;
        inset: -150px auto auto -180px;
        width: 460px;
        height: 380px;
        border-radius: 999px;
        background: radial-gradient(circle, rgba(17,18,20,.08), transparent 68%);
        pointer-events: none;
        z-index: -1;
    }

    .contact-card::after {
        content: "";
        position: absolute;
        inset: auto -170px -180px auto;
        width: 420px;
        height: 340px;
        border-radius: 999px;
        background: radial-gradient(circle, rgba(180,7,22,.09), transparent 70%);
        pointer-events: none;
        z-index: -1;
    }

.contact-card-inner {
    position: relative;
    z-index: 1;
    padding: clamp(22px, 2.6vw, 34px);
}

.contact-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    color: var(--ld-contact-ink-muted);
    font-size: .76rem;
    font-weight: 950;
    line-height: 1;
    letter-spacing: .18em;
    text-transform: uppercase;
}

    .contact-label::before {
        content: "";
        width: 8px;
        height: 8px;
        border-radius: 999px;
        background: var(--ld-contact-red);
        box-shadow: 0 0 0 6px rgba(180,7,22,.10);
    }

.contact-address {
    color: var(--ld-contact-ink-soft);
    font-size: clamp(1rem, 1.05vw, 1.06rem);
    line-height: 1.78;
    font-weight: 550;
}

    .contact-address strong {
        display: block;
        margin-bottom: 7px;
        color: var(--ld-contact-ink);
        font-size: 1.08rem;
        font-weight: 950;
        letter-spacing: -.025em;
    }

.contact-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 11px;
    margin-top: 22px;
}

.contact-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 17px;
    border-radius: 999px;
    color: rgba(17,18,20,.86);
    text-decoration: none;
    font-size: .93rem;
    font-weight: 900;
    letter-spacing: -.015em;
    background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.62)), rgba(17,18,20,.04);
    border: 1px solid rgba(17,18,20,.10);
    box-shadow: 0 10px 22px rgba(17,18,20,.07);
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}

    .contact-action:hover {
        transform: translateY(-2px);
        color: var(--ld-contact-ink);
        background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.74)), rgba(180,7,22,.035);
        border-color: rgba(180,7,22,.22);
        box-shadow: 0 16px 34px rgba(17,18,20,.11);
    }

    .contact-action:active {
        transform: translateY(0);
        box-shadow: 0 9px 18px rgba(17,18,20,.08);
    }

.contact-form-shell .contact-card-inner {
    padding-bottom: clamp(24px, 2.8vw, 36px);
}

.contact-form-shell form {
    display: grid;
    gap: 16px;
    margin: 0;
}

.contact-form-shell .mb-3 {
    margin-bottom: 0 !important;
}

.contact-form-shell .form-label {
    display: block;
    margin: 0 0 8px;
    color: rgba(17,18,20,.82);
    font-size: .88rem;
    font-weight: 900;
    letter-spacing: -.012em;
}

.contact-form-shell :is(input, textarea, select),
.contact-form-shell .form-control {
    width: 100%;
    min-height: 46px;
    padding: 12px 15px;
    border-radius: 17px !important;
    border: 1px solid rgba(17,18,20,.12) !important;
    background: rgba(255,255,255,.82) !important;
    color: var(--ld-contact-ink);
    font-size: 1rem;
    font-weight: 600;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.80), 0 12px 26px rgba(17,18,20,.055);
    outline: none;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .18s ease;
}

    .contact-form-shell :is(input, textarea, select):hover,
    .contact-form-shell .form-control:hover {
        border-color: rgba(17,18,20,.18) !important;
        background: rgba(255,255,255,.94) !important;
    }

    .contact-form-shell :is(input, textarea, select):focus,
    .contact-form-shell .form-control:focus {
        border-color: rgba(180,7,22,.45) !important;
        background: rgba(255,255,255,.98) !important;
        box-shadow: 0 0 0 4px rgba(180,7,22,.10), 0 16px 36px rgba(17,18,20,.10);
        transform: translateY(-1px);
        outline: none;
    }

.contact-form-shell textarea,
.contact-form-shell textarea.form-control {
    min-height: 150px;
    resize: vertical;
}

.contact-form-shell .btn,
.contact-form-shell button[type="submit"],
.contact-form-shell .btn-primary {
    display: inline-flex;
    max-width: 50%;
    align-items: center;
    justify-content: center;
    min-width: 142px;
    min-height: 46px;
    margin-top: 2px;
    padding: 12px 24px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.38) !important;
    background: linear-gradient(180deg, rgba(200,12,28,1), rgba(125,7,16,1)) !important;
    color: #fff !important;
    font-size: .96rem;
    font-weight: 950;
    letter-spacing: -.015em;
    box-shadow: 0 18px 38px rgba(180,7,22,.24), 0 12px 26px rgba(17,18,20,.12);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

    .contact-form-shell .btn:hover,
    .contact-form-shell button[type="submit"]:hover,
    .contact-form-shell .btn-primary:hover {
        transform: translateY(-2px);
        filter: brightness(1.04);
        box-shadow: 0 23px 50px rgba(180,7,22,.30), 0 17px 36px rgba(17,18,20,.15);
    }

    .contact-form-shell .btn:active,
    .contact-form-shell button[type="submit"]:active,
    .contact-form-shell .btn-primary:active {
        transform: translateY(0);
        box-shadow: 0 13px 30px rgba(180,7,22,.23), 0 9px 20px rgba(17,18,20,.12);
    }

    .contact-form-shell :is(input, textarea, select):focus-visible,
    .contact-form-shell .btn:focus-visible,
    .contact-action:focus-visible {
        outline: 3px solid rgba(180,7,22,.22);
        outline-offset: 3px;
    }

@media (min-width: 992px) {
    .contact-grid {
        grid-template-columns: .95fr 1.1fr;
        align-items: stretch;
    }

    .contact-card-inner {
        min-height: 100%;
    }
}

@media (min-width: 1200px) {
    .contact-wrap {
        width: min(1080px, calc(100% - 40px));
    }
}

@media (max-width: 991px) {
    .contact-page {
        padding-top: clamp(110px, 13vh, 150px);
    }

    .contact-hero {
        border-radius: 28px;
    }

    .contact-card {
        border-radius: 24px;
    }
}

@media (max-width: 767px) {
    .contact-page {
        padding: 104px 0 64px;
    }

    .contact-wrap {
        width: min(100% - 28px, 1040px);
    }

    .contact-hero {
        padding: 25px 22px;
    }

    .contact-title {
        font-size: clamp(2.05rem, 11vw, 2.7rem);
    }

    .contact-lead {
        font-size: 1rem;
        line-height: 1.72;
    }

    .contact-card-inner {
        padding: 21px 19px;
    }

    .contact-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .contact-action {
        width: 100%;
    }

    .contact-form-shell form {
        gap: 14px;
    }

    .contact-form-shell :is(input, textarea, select),
    .contact-form-shell .form-control {
        min-height: 48px;
        font-size: 16px;
    }

    .contact-form-shell textarea,
    .contact-form-shell textarea.form-control {
        min-height: 132px;
    }

    .contact-form-shell .btn,
    .contact-form-shell button[type="submit"],
    .contact-form-shell .btn-primary {
        width: 50%;
    }
}

@media (max-width: 480px) {
    .contact-page {
        padding-top: 96px;
    }

    .contact-wrap {
        width: min(100% - 22px, 1040px);
    }

    .contact-hero {
        border-radius: 24px;
        padding: 23px 19px;
    }

    .contact-card {
        border-radius: 22px;
    }

    .contact-card-inner {
        padding: 19px 16px;
    }

    .contact-label {
        font-size: .7rem;
        letter-spacing: .15em;
    }
}

@media (prefers-reduced-motion: reduce) {
    .contact-card,
    .contact-action,
    .contact-form-shell :is(input, textarea, select),
    .contact-form-shell .btn,
    .contact-form-shell button[type="submit"] {
        transition: none;
    }

        .contact-card:hover,
        .contact-action:hover,
        .contact-form-shell :is(input, textarea, select):focus,
        .contact-form-shell .btn:hover,
        .contact-form-shell button[type="submit"]:hover {
            transform: none;
        }
}
