/* Colors follow your index.css palette */
:root{
  --maroon:#7A1E1E;
  --slate:#2C2C2C;
  --lilac:#2C2C2C;
  --muted:#666;
  --bg:#fff;
  --glass: rgba(255,255,255,0.9);
  --radius:14px;
  --container:1200px;
  --fw-heading: 'times new roman', serif;
  --fw-body: 'Poppins', sans-serif;
}

*{box-sizing:border-box}
body{font-family:var(--fw-body);margin:0;color:#222;}

/* page spacing */
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* hero */
.contact-hero{padding:48px 0 18px}
/* center the hero block and its contents */
.hero-inner{display:flex;align-items:center;gap:30px;justify-content:center}
.hero-text{ text-align:center; margin:0 auto; max-width:820px; }
.hero-text h1{font-family:var(--fw-heading);font-size:55px;color:var(--maroon);margin:0}
.lead{color:var(--muted);margin-top:10px;max-width:680px;margin-left:auto;margin-right:auto}

/* center the contact area content (grid cells centered) */
.contact-grid{display:grid;grid-template-columns: 1fr 480px;gap:30px;align-items:start;padding:40px 0;justify-items:center}

/* keep left cards full-width inside the centered cell */
.contact-cards{width:100%}
/* constrain the form column to expected width while centered */
.contact-form-wrap{width:100%;max-width:480px}

/* Responsive: keep layout stacked and centered on small screens */
@media (max-width:820px){
  .hero-inner{flex-direction:column-reverse;text-align:center}
  .hero-image img{width:70%}
  .contact-grid{grid-template-columns:1fr;justify-items:center;padding:24px 0}
  .contact-cards{max-width:920px}
}

/* illustration */
.hero-image img{width:260px;height:auto;display:block;border-radius:12px;box-shadow:0 18px 40px rgba(46,10,10,0.08)}

/* grid */
.contact-grid{display:grid;grid-template-columns: 1fr 480px;gap:30px;align-items:start;padding:40px 0}
@media (max-width:1024px){ .contact-grid{grid-template-columns:1fr 420px} }
@media (max-width:820px){ .contact-grid{grid-template-columns:1fr; } .hero-inner{flex-direction:column-reverse;text-align:center} .hero-image img{width:70%} }

/* left: cards */
.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:640px){ .contact-cards{grid-template-columns:1fr} }

.card{background:var(--glass);padding:20px;border-radius:12px;box-shadow:0 10px 30px rgba(19,12,12,0.05);color:#222}
.contact-card .icon{font-size:20px;background:var(--maroon);color:#fff;padding:12px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
.contact-card h3{margin:6px 0 8px;color:var(--maroon);font-size:1.1rem}
.contact-card p{margin:6px 0;color:var(--muted);font-size:0.95rem}
.contact-card a{color:var(--slate);text-decoration:none}

/* form block (right column) */
.contact-form-wrap{display:flex;flex-direction:column;gap:18px}

/* form */
.contact-form{background:#fff;padding:20px;border-radius:12px;box-shadow:0 12px 30px rgba(46,10,10,0.06)}
.contact-form h2{margin:0 0 8px;font-family:var(--fw-heading);color:var(--maroon);font-size:24px}
.contact-form label{display:block;font-size:0.9rem;color:var(--muted);margin-bottom:8px}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea{width:100%;padding:10px 12px;border:1px solid #e6e6e6;border-radius:8px;font-size:0.95rem;margin-top:8px;background:#fff;color:#222}
.row{display:flex;gap:12px}
.row label{flex:1}
textarea{resize:vertical;min-height:120px}

/* captcha */
.captcha-row{display:flex;gap:12px;align-items:center;margin:12px 0}
.captcha-question{background:linear-gradient(180deg,var(--lilac),#b5b6d9);color:#fff;padding:8px 12px;border-radius:8px;font-weight:600}
.captcha-row input{width:140px}

/* buttons */
.form-actions{display:flex;gap:12px;align-items:center;margin-top:8px}
.btn{padding:10px 18px;border-radius:10px;border:0;cursor:pointer;font-weight:600;font-size:0.95rem}
.btn.primary{background:linear-gradient(135deg,var(--maroon),#912525);color:#fff;box-shadow:0 8px 20px rgba(122,30,30,0.12)}
.btn.outline{background:#fff;border:1px solid #e3e3e3;color:var(--maroon)}
.btn:active{transform:translateY(1px)}

/* small message area */
.form-message{margin-top:12px;font-size:0.95rem;color:var(--slate)}

/* map card */
.map-card .map{border-radius:10px;overflow:hidden;margin:12px 0}
.socials{display:flex;gap:12px}
.socials a{display:inline-flex;width:40px;height:40px;border-radius:8px;background:var(--lilac);align-items:center;justify-content:center;color:#fff;text-decoration:none}

/* success overlay */
.success-modal{position:fixed;inset:0;background:rgba(0,0,0,0.45);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;pointer-events:none;transition:opacity .18s ease}
.success-modal.show{opacity:1;pointer-events:auto}
.success-card{background:#fff;padding:28px;border-radius:14px;max-width:520px;width:90%;text-align:center;box-shadow:0 18px 60px rgba(20,10,10,0.12)}
.success-card h3{color:var(--maroon);margin:0 0 8px}
.success-card p{color:var(--muted);margin-bottom:18px}

/* utility */
.muted{color:var(--muted);font-size:0.9rem}

/* responsive tweaks */
@media (max-width:520px){
  .row{flex-direction:column}
  .hero-text h1{font-size:24px}
  .contact-grid{padding:20px 0}
  .contact-form{padding:14px}
}


.address-link {
    color: var(--muted);
    text-decoration: none;
    transition: color 0.2s ease;
}

.address-link:hover {
    color: var(--maroon);
}

.address-link:focus {
    outline: 2px solid rgba(122,30,30,0.2);
    outline-offset: 2px;
}