/* ═══════════════════════════════════════════════════════════════════
 VAAVIYO HOTELS, contact.css
 Page-specific styles for /contact.html
 Reuses brand tokens from main.css. Adds:
 - .contact-hero slim banner header for the page
 - .brand-contact-card Vaaviyo HQ "card" at top with corporate info
 - .property-contact-grid 2-up grid of property contact cards below
 - .property-contact-card individual property card (logo strip, address,
 phone, email, socials, "Visit website" link)
 - .contact-form-wrap simple two-column form section at the bottom
═══════════════════════════════════════════════════════════════════ */
/* ─── PAGE HERO (slim) ───────────────────────────────────────── */
.contact-hero {
 position: relative; min-height: 360px;
 background: var(--v-maroon);
 display: flex; align-items: center; justify-content: center;
 padding: 80px var(--gutter);
 overflow: hidden;
}
.contact-hero .contact-hero-bg {
 position: absolute; inset: 0;
 width: 100%; height: 100%;
 object-fit: cover; object-position: center;
 z-index: 0;
}
.contact-hero .contact-hero-overlay {
 position: absolute; inset: 0; z-index: 1;
 background: linear-gradient(180deg, rgba(90, 26, 31, .58) 0%, rgba(90, 26, 31, .8) 100%);
}
.contact-hero::before {
 content: ""; position: absolute; inset: 0; z-index: 2;
 pointer-events: none;
 background:
 radial-gradient(circle at 20% 30%, rgba(217, 196, 163, .12) 0%, transparent 45%),
 radial-gradient(circle at 80% 70%, rgba(184, 51, 58, .22) 0%, transparent 50%);
}
.contact-hero-inner {
 position: relative; z-index: 3; text-align: center;
 max-width: 720px; color: var(--v-cream);
}
.contact-hero .eyebrow {
 display: inline-block; padding: 6px 14px;
 border: 1px solid rgba(247, 241, 230, .35);
 color: var(--v-sand); margin-bottom: 22px;
}
.contact-hero h1 {
 font-size: clamp(38px, 5.6vw, 64px); line-height: 1.08;
 color: var(--v-cream); margin-bottom: 14px;
}
.contact-hero h1 em { font-style: italic; color: var(--v-sand); }
.contact-hero p {
 font-size: 16px; line-height: 1.7; opacity: .88;
 max-width: 540px; margin: 0 auto;
}
.contact-hero .arch-divider::before { border-color: var(--v-sand); }
.contact-hero .arch-divider::after { background: var(--v-maroon); color: var(--v-sand); }
/* ─── BREADCRUMB ─────────────────────────────────────────────── */
.breadcrumb {
 background: var(--v-cream);
 padding: 14px var(--gutter);
 font-size: 13px; color: var(--v-mist);
 border-bottom: 1px solid var(--v-stone);
}
.breadcrumb .crumb-inner {
 max-width: var(--container); margin: 0 auto;
 display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
.breadcrumb a { color: var(--v-red); transition: color .2s ease; }
.breadcrumb a:hover { color: var(--v-red-d); }
.breadcrumb i { font-size: 9px; color: var(--v-mist); }
/* ─── BRAND CONTACT CARD (top) ──────────────────────────────── */
.sec-brand-contact {
 background: var(--v-cream);
 padding: clamp(60px, 8vw, 100px) var(--gutter);
}
.brand-contact-card {
 max-width: 1100px; margin: 0 auto;
 background: var(--v-white);
 border: 1px solid var(--v-stone);
 border-top: 4px solid var(--v-red);
 border-radius: 4px;
 box-shadow: var(--shadow-md);
 padding: clamp(36px, 4vw, 56px);
 display: grid; grid-template-columns: 1.1fr 1.4fr; gap: 50px;
 align-items: start;
 position: relative;
}
.brand-contact-card::before {
 content: ""; position: absolute; top: -1px; left: 0; right: 0;
 height: 3px;
 background: linear-gradient(to right,
 transparent 0%, var(--v-red) 25%, var(--v-sand) 50%, var(--v-red) 75%, transparent 100%);
}
.brand-contact-card .brand-side .eyebrow { display: block; margin-bottom: 12px; }
.brand-contact-card .brand-logo { margin-bottom: 18px; }
.brand-contact-card .brand-logo img { height: 70px; width: auto; }
.brand-contact-card .brand-tag {
 font-family: var(--font-display); font-style: italic;
 font-size: 15px; color: var(--v-red); margin-bottom: 18px;
 letter-spacing: .5px;
}
.brand-contact-card .brand-desc {
 font-size: 15px; line-height: 1.7; color: var(--v-mist);
 margin: 0;
}
/* Right side, details grid */
.brand-contact-card .brand-details h2 {
 font-size: clamp(26px, 3vw, 34px); line-height: 1.15;
 margin-bottom: 8px;
}
.brand-contact-card .brand-details h2 em { font-style: italic; color: var(--v-red); }
.brand-contact-card .brand-details .arch-divider { margin: 12px 0 24px; }
.brand-contact-card .brand-details .arch-divider::before { left: 0; transform: none; }
.brand-contact-card .brand-details .arch-divider::after { left: 30px; transform: translateY(-50%); }
/* Override centred arch styling for the brand-card variant, keep it left-aligned */
.brand-contact-card .brand-details .arch-divider { position: relative; width: 84px; height: 22px; }
.contact-row {
 display: flex; gap: 16px; align-items: flex-start;
 padding: 16px 0; border-bottom: 1px dashed var(--v-stone);
}
.contact-row:last-child { border-bottom: 0; }
.contact-row .ico {
 flex: 0 0 44px; width: 44px; height: 44px;
 background: var(--v-red-15); color: var(--v-red);
 display: grid; place-items: center; border-radius: 50%;
 font-size: 16px;
}
.contact-row .label {
 font-size: 11px; font-weight: 700; letter-spacing: 2px;
 text-transform: uppercase; color: var(--v-ink);
 margin-bottom: 4px; display: block;
}
.contact-row .val {
 font-size: 15px; line-height: 1.6; color: var(--v-ink);
}
.contact-row .val a { color: var(--v-ink); transition: color .2s ease; }
.contact-row .val a:hover { color: var(--v-red); }
/* ─── PROPERTY CONTACT GRID (below brand) ──────────────────── */
.sec-property-contacts {
 background: var(--v-white);
 padding: clamp(60px, 8vw, 100px) var(--gutter);
}
.sec-property-contacts .section-head { margin-bottom: 50px; }
.property-contact-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
}
.property-contact-card {
 background: var(--v-cream);
 border: 1px solid var(--v-stone);
 border-radius: 4px;
 overflow: hidden;
 display: flex; flex-direction: column;
 transition: transform .25s ease, box-shadow .25s ease;
}
.property-contact-card:hover {
 transform: translateY(-4px); box-shadow: var(--shadow-md);
}
.property-contact-card .pc-header {
 position: relative;
 aspect-ratio: 16/8; overflow: hidden;
}
.property-contact-card .pc-header img {
 width: 100%; height: 100%; object-fit: cover;
 transition: transform .8s ease;
}
.property-contact-card:hover .pc-header img { transform: scale(1.04); }
.property-contact-card .pc-header-overlay {
 position: absolute; inset: 0;
 background: linear-gradient(to top,
 rgba(15, 10, 12, .85) 0%, rgba(58, 17, 20, .35) 55%, transparent 100%);
}
.property-contact-card .pc-title {
 /* Match the same 32px horizontal inset used by .pc-body so the heading
 visually aligns with the address rows below. Bottom 28px keeps a
 comfortable optical balance against the gradient overlay. */
 position: absolute; left: 32px; right: 32px; bottom: 28px;
 color: var(--v-white);
}
.property-contact-card .pc-title .pc-meta {
 font-size: 11px; font-weight: 600; letter-spacing: 2px;
 text-transform: uppercase; color: var(--v-sand); margin-bottom: 4px;
}
.property-contact-card .pc-title h3 {
 font-size: 28px; color: var(--v-white); margin: 0;
}
.property-contact-card .pc-body {
 /* Uniform 32px on every side, equal top/right/bottom/left. */
 padding: 32px;
}
.property-contact-card .pc-body .contact-row {
 padding: 14px 0;
}
.property-contact-card .pc-body .contact-row:first-child { padding-top: 0; }
.property-contact-card .pc-body .contact-row:last-of-type { padding-bottom: 0; }
.property-contact-card .pc-body .contact-row .ico {
 flex: 0 0 36px; width: 36px; height: 36px; font-size: 13px;
}
.property-contact-card .pc-body .contact-row .label { font-size: 10px; }
.property-contact-card .pc-body .contact-row .val { font-size: 14px; }
.property-contact-card .pc-footer {
 /* Symmetric 20px gap above and below the divider line, keeps the
 footer optically balanced against the rows above and the card edge. */
 margin-top: 20px; padding-top: 20px;
 border-top: 1px solid var(--v-stone);
 display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
}
.property-contact-card .pc-website {
 display: inline-flex; align-items: center; gap: 8px;
 background: var(--v-red); color: var(--v-white);
 padding: 12px 22px; font-size: 12px; font-weight: 600;
 letter-spacing: 1.5px; text-transform: uppercase;
 border-radius: 2px;
 transition: background .25s ease, transform .15s ease, box-shadow .25s ease;
}
.property-contact-card .pc-website:hover {
 background: var(--v-red-d); transform: translateY(-2px);
 box-shadow: 0 8px 22px rgba(184, 51, 58, .35);
}
.property-contact-card .pc-socials {
 display: flex; gap: 10px; margin-left: auto;
}
.property-contact-card .pc-socials a {
 width: 34px; height: 34px; display: grid; place-items: center;
 border: 1px solid var(--v-stone); border-radius: 50%;
 color: var(--v-mist); font-size: 13px;
 transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.property-contact-card .pc-socials a:hover {
 background: var(--v-red); border-color: var(--v-red); color: var(--v-white);
}
/* Optional secondary office block inside a property card */
.pc-secondary {
 /* Equal 16px padding on every side so the inner text is symmetrically
 inset; 20px top margin matches the .pc-footer rhythm. */
 margin-top: 20px; padding: 16px;
 background: var(--v-stone); border-radius: 3px;
 font-size: 13px; line-height: 1.55; color: var(--v-ink);
}
.pc-secondary .label {
 display: block; font-size: 10px; font-weight: 700;
 letter-spacing: 2px; text-transform: uppercase;
 color: var(--v-red); margin-bottom: 6px;
}
/* ─── INQUIRY FORM at the bottom ───────────────────────────── */
.sec-contact-form {
 background: var(--v-cream);
 padding: clamp(60px, 8vw, 100px) var(--gutter);
}
.contact-form-wrap {
 max-width: 880px; margin: 0 auto;
 background: var(--v-white);
 border: 1px solid var(--v-stone); border-radius: 4px;
 padding: clamp(30px, 4vw, 50px);
 box-shadow: var(--shadow-sm);
}
.contact-form-wrap .form-success {
 display: none;
 padding: 16px; margin-bottom: 18px;
 background: rgba(184, 51, 58, .08); border-left: 3px solid var(--v-red);
 font-size: 14px; border-radius: 2px;
}
.contact-form-wrap .form-success.is-visible { display: block; }
.contact-form-wrap .form-error {
 display: none;
 padding: 16px; margin-bottom: 18px;
 background: rgba(184, 51, 58, .14);
 border-left: 3px solid var(--v-red-d, #8e252b);
 color: var(--v-red-d, #8e252b);
 font-size: 14px; border-radius: 2px;
}
.contact-form-wrap .form-error.is-visible { display: block; }
.contact-form-wrap .form-row {
 display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px;
}
.contact-form-wrap .form-field { display: flex; flex-direction: column; }
.contact-form-wrap .form-field.full { grid-column: 1 / -1; }
.contact-form-wrap label {
 font-size: 11px; font-weight: 600; letter-spacing: 1.5px;
 text-transform: uppercase; color: var(--v-ink); margin-bottom: 6px;
}
.contact-form-wrap input,
  .contact-form-wrap select,
  .contact-form-wrap textarea {
 background: var(--v-cream); border: 1px solid var(--v-stone);
 padding: 13px 14px; font: inherit; font-size: 14px; color: var(--v-ink);
 border-radius: 2px;
 transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.contact-form-wrap input:focus, .contact-form-wrap select:focus, .contact-form-wrap textarea:focus {
 outline: 0; border-color: var(--v-red); background: var(--v-white);
 box-shadow: 0 0 0 3px rgba(184, 51, 58, .12);
}
.contact-form-wrap textarea { min-height: 130px; resize: vertical; }
.contact-form-wrap button[type="submit"] {
 background: var(--v-red); color: var(--v-white);
 border: 1px solid var(--v-red); padding: 14px 32px;
 font-size: 13px; font-weight: 600; letter-spacing: 2px;
 text-transform: uppercase; border-radius: 2px; cursor: pointer;
 transition: background .25s ease, transform .15s ease, box-shadow .25s ease;
}
.contact-form-wrap button[type="submit"]:hover {
 background: var(--v-red-d); transform: translateY(-2px);
 box-shadow: 0 10px 26px rgba(184, 51, 58, .3);
}
.contact-form-wrap button[type="submit"]:disabled {
 background: var(--v-mist); border-color: var(--v-mist);
 cursor: default; transform: none; box-shadow: none;
}
/* ─── RESPONSIVE ────────────────────────────────────────────── */
/* Prevent long emails / addresses from breaking the layout on tiny screens */
.contact-row .val,
.contact-row .val a,
.pc-secondary { overflow-wrap: anywhere; word-break: break-word; }
@media (max-width: 1024px) {
 .brand-contact-card {
 grid-template-columns: 1fr; gap: 32px;
 padding: 38px clamp(24px, 4vw, 44px);
 }
 .brand-contact-card .brand-side { text-align: center; }
 .brand-contact-card .brand-logo { display: flex; justify-content: center; }
 .brand-contact-card .brand-details .arch-divider { margin-left: auto; margin-right: auto; }
 .brand-contact-card .brand-details .arch-divider::before { left: 50%; transform: translate(-50%, -50%); }
 .brand-contact-card .brand-details .arch-divider::after { left: 50%; transform: translate(-50%, -50%); }
 .property-contact-grid { grid-template-columns: 1fr; gap: 28px; }
 .property-contact-card .pc-header { aspect-ratio: 16/9; }
 .contact-hero { min-height: 320px; }
}
@media (max-width: 768px) {
 .contact-hero {
 min-height: 280px; padding: 56px 20px;
 }
 .contact-hero .contact-hero-bg { object-position: 50% 35%; }
 .contact-hero .contact-hero-overlay {
 background: linear-gradient(180deg, rgba(90, 26, 31, .6) 0%, rgba(90, 26, 31, .82) 100%);
 }
 .contact-hero h1 { font-size: clamp(30px, 8vw, 46px); }
 .contact-hero p { font-size: 14.5px; line-height: 1.65; }
 .sec-brand-contact { padding: 48px 18px; }
 .brand-contact-card {
 padding: 26px 20px;
 grid-template-columns: 1fr;
 }
 .brand-contact-card .brand-logo img { height: 60px; }
 .brand-contact-card .brand-tag { font-size: 14px; }
 .brand-contact-card .brand-desc { font-size: 14px; line-height: 1.65; }
 .brand-contact-card .brand-details h2 { font-size: 24px; }
 .contact-row {
 padding: 14px 0; gap: 12px;
 align-items: flex-start;
 }
 .contact-row .ico {
 flex: 0 0 36px; width: 36px; height: 36px; font-size: 13px;
 }
 .contact-row .label { font-size: 10px; letter-spacing: 1.5px; }
 .contact-row .val { font-size: 14px; line-height: 1.55; }
 .sec-property-contacts { padding: 48px 18px; }
 .sec-property-contacts .section-head { margin-bottom: 32px; }
 .property-contact-card .pc-header { aspect-ratio: 16/9; }
 /* Match the 24px equal inset used by .pc-body on this breakpoint */
 .property-contact-card .pc-title { left: 24px; right: 24px; bottom: 24px; }
 .property-contact-card .pc-title h3 { font-size: 24px; }
 /* Uniform 24px on every side */
 .property-contact-card .pc-body { padding: 24px; }
 .property-contact-card .pc-footer {
 gap: 14px; padding-top: 16px; margin-top: 16px;
 flex-direction: column; align-items: flex-start;
 }
 .property-contact-card .pc-socials { margin-left: 0; }
 .property-contact-card .pc-website {
 width: 100%; justify-content: center; min-height: 44px;
 }
 .pc-secondary { font-size: 12.5px; padding: 14px; margin-top: 16px; }
 .sec-contact-form { padding: 48px 18px; }
 .contact-form-wrap { padding: 26px 22px; }
 .contact-form-wrap .form-row { grid-template-columns: 1fr; gap: 14px; }
 .contact-form-wrap input,
  .contact-form-wrap select,
  .contact-form-wrap textarea { font-size: 16px; padding: 12px 13px; }
 .contact-form-wrap button[type="submit"] {
 width: 100%; padding: 16px; min-height: 48px;
 }
 /* Breadcrumb, wrap gracefully if labels are long */
 .breadcrumb { padding: 12px 18px; font-size: 12px; }
}
@media (max-width: 480px) {
 .contact-hero { min-height: 240px; padding: 48px 16px; }
 .contact-hero .contact-hero-bg { object-position: 50% 30%; }
 .contact-hero .contact-hero-overlay {
 background: linear-gradient(180deg, rgba(90, 26, 31, .65) 0%, rgba(90, 26, 31, .85) 100%);
 }
 .contact-hero .eyebrow { font-size: 10px; letter-spacing: 3px; padding: 4px 12px; margin-bottom: 18px; }
 .sec-brand-contact, .sec-property-contacts, .sec-contact-form { padding: 40px 14px; }
 .brand-contact-card { padding: 20px; }
 /* Uniform 20px on every side */
 .property-contact-card .pc-body { padding: 20px; }
 .property-contact-card .pc-title { left: 20px; right: 20px; bottom: 20px; }
 .property-contact-card .pc-title h3 { font-size: 22px; }
 .contact-row .ico { flex: 0 0 32px; width: 32px; height: 32px; font-size: 12px; }
 .contact-row .val { font-size: 13.5px; }
 .contact-row .val a { display: inline-block; }
}
@media (max-width: 360px) {
 .contact-hero h1 { font-size: 26px; }
 .brand-contact-card .brand-details h2 { font-size: 22px; }
 .property-contact-card .pc-title h3 { font-size: 20px; }
 .property-contact-card .pc-socials a { width: 32px; height: 32px; font-size: 12px; }
}
