:root {
    /* Colors */
    --primary: #111111;       /* Jet Black */
    --primary-light: #333333; /* Dark Gray */
    --primary-dark: #000000;  /* Pure Black */
    --secondary: #E0E0E0;     /* Metallic Silver */
    --tertiary: #D4AF37;      /* Luxury Gold Accent */
    --tertiary-light: #ddc062;
    --tertiary-dark: #af8f25;
    --quaternary: #d70000;    /* Vivid Red Accent */
    --quaternary-light: #ff0202;
    --quaternary-dark: #ac0000;
    --text-clr: #000000;
    --dark-gray: #333333;
    --gray: #B0B0B0;
    --light-gray: #F2F2F2;
/* Font */
    --ff:'Figtree', sans-serif;
    --h1: bold 4rem/1em var(--ff);
    --h2: bold 3rem/1.2em var(--ff);
    --h3: bold 2.25rem/1.2em var(--ff);
    --h4: bold 1.5rem/1.6em var(--ff);
    --big: 1.25rem/1.6em var(--ff);
    --p: 1rem/1.6em var(--ff);
    --small: 0.75rem/2em var(--ff);

    /* Spacing */
    font-size: 16px;
    --margin-xxs: .25rem;
    --margin-xs: .5rem;
    --margin-s: .75rem;
    --margin-m: 1rem;
    --margin-l: 1.25rem;
    --margin-xl: 1.75rem;
    --margin-xxl: 2.5rem;
}
body, html {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}
main {
    padding-top: 0;
}
body {
    font-family: var(--ff);
    background-color: var(--primary);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
}
/* Basic Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
main { 
    flex: 1;
}
.front-intro {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--secondary);
    background-color: var(--primary-light);
    padding: 3rem 0 3rem 0;
    margin-top: 5rem;
}
.front-intro h1 {
    font-size: 2.5rem;
}
.front-intro p {
    font-size: 1.25rem;
}
.contact-section {
    max-width: 1100px;
    margin: 3rem auto 4rem;
    padding: 3rem 2rem 3.5rem;
    background: linear-gradient(145deg,#161616 0%,#0d0d0d 70%);
    border: 1px solid #242424;
    border-radius: 24px;
    box-shadow: 0 18px 40px -18px rgba(0,0,0,.7);
    position: relative;
    overflow: hidden;
}
.contact-section:before {
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 18% 20%, rgba(212,175,55,.18), transparent 60%),
        radial-gradient(circle at 82% 80%, rgba(215,0,0,.18), transparent 65%);
    pointer-events:none;
    opacity:.9;
}
.contact-section h2 {
    font-size: 2.4rem;
    margin: 0 0 1rem;
    text-align: center;
    color: var(--secondary);
    letter-spacing: .5px;
}
.contact-intro {
    text-align: center;
    max-width: 780px;
    margin: 0 auto 2.2rem;
    font-size: 1.05rem;
    line-height: 1.55;
    color: var(--secondary);
    opacity: .85;
}
.contact-form {
    width: 100%;
}
.form-row {
    display: flex;
    flex-direction: column;
    gap: 1.75rem;
    margin-bottom: 1.75rem;
}
.two-col {
    flex-direction: row;
    gap: 2rem;
}
.form-field {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.form-field label {
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--secondary);
    margin-bottom: .55rem;
}
.form-field input,
.form-field textarea {
    background: #1d1d1d;
    border: 1px solid #2b2b2b;
    border-radius: 10px;
    padding: .9rem 1rem;
    font: var(--p);
    font-family: var(--ff);
    color: var(--secondary);
    resize: vertical;
    transition: border-color .28s ease, box-shadow .28s ease, background .28s ease;
}
.form-field textarea {
    line-height: 1.5;
}
.form-field input::placeholder,
.form-field textarea::placeholder {
    color: #8b8b8b;
}
.form-field input:focus,
.form-field textarea:focus {
    outline: none;
    border-color: var(--tertiary);
    box-shadow: 0 0 0 3px rgba(212,175,55,.18);
    background: #212121;
}
.contact-submit {
    display: inline-block;
    align-self: flex-start;
    background: var(--tertiary);
    color: var(--primary-dark);
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: .5px;
    padding: .95rem 2.6rem;
    border: 1px solid var(--tertiary-dark);
    border-radius: 40px;
    cursor: pointer;
    box-shadow: 0 10px 26px -10px rgba(0,0,0,.65);
    transition: background .35s ease, transform .35s ease, box-shadow .35s ease;
}
.contact-submit:hover {
    background: var(--quaternary);
    transform: translateY(-4px);
    box-shadow: 0 16px 36px -12px rgba(0,0,0,.75);
}
.contact-submit:active {
    transform: translateY(-1px);
}
.form-note {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--secondary);
    opacity: .5;
    margin: .25rem 0 0;
}
.form-status {
    margin-top: 1rem;
    font-size: .9rem;
    color: var(--secondary);
    min-height: 1.2rem;
}
@media (max-width: 880px) {
    .two-col {
        flex-direction: column;
        gap: 1.75rem;
    }
    .contact-section {
        padding: 2.6rem 1.4rem 3rem;
        border-radius: 20px;
    }
    .contact-section h2 { font-size: 2.05rem; }
    .contact-intro { font-size: 1rem; }
    .contact-submit { width: 100%; text-align: center; }
}
@media (max-width: 640px){
    .front-intro {
        margin-top: 4.2rem;
        padding: 2.4rem 1.1rem 2.2rem;
    }
    .front-intro h1 { font-size: 2.1rem; }
    .front-intro p { font-size: 1rem; }

    .contact-section {
        margin: 2.4rem 1rem 3.2rem;
        padding: 2.3rem 1.15rem 2.6rem;
        border-radius: 18px;
    }
    .contact-section h2 {
        font-size: 1.85rem;
        margin-bottom: .85rem;
    }
    .contact-intro {
        font-size: .95rem;
        line-height: 1.5;
        margin-bottom: 1.8rem;
        padding: 0 .2rem;
    }

    /* Stack all rows; override any horizontal layout */
    .form-row,
    .form-row.two-col {
        flex-direction: column;
        gap: 1.25rem;
        margin-bottom: 1.4rem;
    }

    .form-field label {
        font-size: .75rem;
        letter-spacing: .6px;
        margin-bottom: .45rem;
    }
    .form-field input,
    .form-field textarea {
        padding: .78rem .85rem;
        font-size: .9rem;
        border-radius: 8px;
    }
    .form-field textarea { min-height: 170px; }

    /* Full-width CTA */
    .contact-submit {
        width: 100%;
        text-align: center;
        padding: .9rem 1.4rem;
        font-size: .95rem;
        border-radius: 34px;
    }

    .form-note {
        font-size: .6rem;
        letter-spacing: .9px;
    }

    /* Tighten shadow on mobile for performance */
    .contact-section,
    .contact-submit { box-shadow: 0 10px 26px -14px rgba(0,0,0,.6); }

    /* Reduce radial highlight intensity */
    .contact-section:before { opacity: .65; }
}

@media (max-width: 420px){
    .front-intro { padding: 2rem .9rem 2rem; }
    .contact-section { margin: 2rem .75rem 2.8rem; padding: 2rem .9rem 2.3rem; }
    .contact-section h2 { font-size: 1.65rem; }
    .contact-intro { font-size: .9rem; }
    .form-field input,
    .form-field textarea { font-size: .85rem; }
    .contact-submit { font-size: .9rem; }
}

@media (prefers-reduced-motion: reduce){
    .contact-submit { transition: none !important; }
}

/* Mobile-only Book button */
.mobile-book-btn {
    display:none;
}

@media (max-width:640px){
    .mobile-book-btn {
        display:inline-flex;
        justify-content:center;
        align-items:center;
        width:calc(100% - 2rem);
        margin:1rem 1rem 2.4rem;
        padding:0.75rem 1rem;
        font-size:1rem;
        font-weight:700;
        letter-spacing:.5px;
        text-decoration:none;
        border-radius:42px;
        background:linear-gradient(135deg,var(--tertiary) 0%,var(--tertiary-dark) 55%,#7a6015 100%);
        color:var(--primary-dark);
        border:1px solid var(--tertiary-dark);
        box-shadow:0 12px 34px -16px rgba(0,0,0,.65);
        position:relative;
        overflow:hidden;
        background-size:140% 140%;
        background-position:0 50%;
        transition:background-position .6s ease,transform .35s ease,box-shadow .45s ease;
    }
    .mobile-book-btn:hover {
        background-position:100% 50%;
        transform:translateY(-4px);
        box-shadow:0 18px 46px -18px rgba(0,0,0,.75);
        color:var(--secondary);
    }
    .mobile-book-btn::after {
        content:"";
        position:absolute;
        inset:0;
        background:linear-gradient(120deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.18) 35%,rgba(255,255,255,0) 70%);
        mix-blend-mode:overlay;
        opacity:0;
        transition:opacity .45s ease;
    }
    .mobile-book-btn:hover::after { opacity:.7; }
}
.form-field input[type=file] {
    padding:.55rem .65rem;
    background:#111;
    border:1px dashed #2a2a2a;
    border-radius:8px;
    color:var(--secondary);
    font-size:.8rem;
    cursor:pointer;
}
.field-hint {
    display:block;
    margin-top:.4rem;
    margin-left: 0.4rem;
    font-size:.6rem;
    letter-spacing:.8px;
    text-transform:uppercase;
    opacity:.5;
    color: var(--secondary);
}
.image-previews {
    display:flex;
    flex-wrap:wrap;
    gap:.6rem;
    margin-top:.8rem;
}
.img-thumb {
    width:78px;
    aspect-ratio:1/1;
    margin:0;
    background:#141414;
    border:1px solid #222;
    border-radius:8px;
    overflow:hidden;
    position:relative;
}
.img-thumb img {
    width:100%; height:100%; object-fit:cover; display:block;
}
.img-thumb figcaption {
    position:absolute;
    inset:auto 0 0 0;
    background:linear-gradient(180deg,transparent,rgba(0,0,0,.75));
    font-size:.45rem;
    padding:.25rem .3rem .3rem;
    color:#fff;
    line-height:1.1;
    text-overflow:ellipsis;
    white-space:nowrap;
    overflow:hidden;
}
.img-errors {
    flex-basis:100%;
    background:#3a1111;
    color:#f6d3d3;
    padding:.45rem .6rem;
    border:1px solid #612222;
    border-radius:6px;
    font-size:.55rem;
    letter-spacing:.5px;
}
/* Mobile tweak */
@media (max-width:640px){
    .img-thumb { width:64px; }
}