/* Contact Page Styles - mobile-first
   Variables and a clean, luxurious aesthetic (ivory + deep-gray + gold)
*/

:root{
  --ivory:#fbf7f2;
  --text:#222222;
  --muted:#6b6b6b;
  --accent:#b5733a; /* warm gold/bronze */
  --card:#ffffff;
  --shadow:0 12px 30px rgba(33,33,33,0.07);
  --radius:12px;
  --font-heading: 'Libre Baskerville', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&family=Libre+Baskerville:wght@400;700&display=swap');

body{background:var(--ivory);color:var(--text);font-family:var(--font-body);}
.container{width:92%;max-width:1200px;margin:0 auto;padding:28px 0}

/* Hero */
.contact-hero{position:relative;min-height:54vh;display:flex;align-items:flex-end;background-image:url('../images/contact-hero.jpg');background-size:cover;background-position:center;border-radius:0;margin-top:80px;padding-top:20px}
.contact-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.6),rgba(0,0,0,0.35));backdrop-filter: blur(2px);}
.contact-hero .hero-inner{position:relative;z-index:2;color:#fff;padding:36px 0;opacity:0;transform:translateY(8px);animation:fadeInUp .9s ease forwards}
.breadcrumb{color:rgba(255,255,255,0.95);font-size:0.95rem;margin-bottom:12px}
.hero-title{font-family:var(--font-heading);font-size:clamp(1.6rem,5vw,3.2rem);margin:0 0 10px}
.hero-sub{color:rgba(255,255,255,0.95);max-width:720px;margin-bottom:16px}

/* Hero layout: stack on mobile, split on larger screens */
.hero-row{display:flex;flex-direction:column;gap:18px}
.hero-content{max-width:720px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}

/* Quick contact card on hero */
.hero-card{background:rgba(255,255,255,0.96);color:var(--text);border-radius:12px;box-shadow:var(--shadow);padding:18px;max-width:360px}
.hero-card .card-inner h4{margin:0 0 6px;font-family:var(--font-heading)}
.hero-card .card-inner p{margin:0 0 12px;color:var(--muted)}
.card-contacts{display:flex;flex-direction:column;gap:8px}
.card-link{display:inline-flex;gap:10px;align-items:center;padding:10px 12px;border-radius:8px;background:linear-gradient(180deg, #fff, #fbfbfb);text-decoration:none;color:var(--text);font-weight:600;box-shadow:0 8px 18px rgba(33,33,33,0.04)}
.card-link i{color:var(--accent);min-width:18px}
.card-note{margin-top:12px;font-size:0.9rem}

/* Intro */
.contact-intro .lead{text-align:center;color:var(--muted);max-width:900px;margin:22px auto;font-size:clamp(0.95rem,1.8vw,1.05rem)}

/* Contact Info Grid */
.contact-info{padding:18px 0}
.info-grid{display:grid;grid-template-columns:1fr;gap:12px}
.info-item{background:var(--card);padding:16px;border-radius:10px;box-shadow:var(--shadow);display:flex;gap:12px;align-items:center}
.info-item .icon{font-size:1.6rem}
.info-item h4{margin:0;font-family:var(--font-heading);font-size:1rem}
.info-item p,a{margin:0;color:var(--muted)}

/* Form + Map layout */
.contact-form-section{padding:8px 0 28px}
.form-grid{display:grid;grid-template-columns:1fr;gap:18px}
.form-card{background:var(--card);padding:18px;border-radius:12px;box-shadow:var(--shadow)}
.contact-form .form-row{display:flex;flex-direction:column;margin-bottom:12px}
.contact-form label{font-size:0.9rem;color:var(--text);margin-bottom:6px}
.contact-form input,.contact-form select,.contact-form textarea{padding:12px 14px;border-radius:10px;border:1px solid #e8e5e2;background:#fff;outline:none;transition:box-shadow .18s ease,border-color .18s ease,transform .18s ease}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{box-shadow:0 6px 18px rgba(181,115,58,0.08);border-color:rgba(181,115,58,0.25)}
.contact-form textarea{resize:vertical}
.form-row--full{grid-column:1/-1}
.form-actions{display:flex;gap:12px;align-items:center}
.btn{display:inline-block;padding:10px 16px;border-radius:10px;text-decoration:none;font-weight:600;transition:transform .18s ease,box-shadow .18s ease}
.btn-primary{background:var(--accent);color:#fff;border:0;box-shadow:0 8px 22px rgba(181,115,58,0.12)}
.btn-primary:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(181,115,58,0.14)}
.btn-ghost{background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text)}

/* info-item hover */
.info-item{transition:transform .18s ease,box-shadow .18s ease}
.info-item:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(33,33,33,0.06)}

@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.map-card{background:var(--card);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.map-wrap{width:100%;height:280px;background:#000}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
.map-caption{padding:12px 14px;margin:0;color:var(--muted);font-size:0.95rem}

/* Why contact */
.why-contact{padding:18px 0}
.why-grid{display:grid;grid-template-columns:1fr;gap:12px}
.why-item{background:linear-gradient(180deg,rgba(255,255,255,0.98),#fff);padding:14px;border-radius:10px;box-shadow:var(--shadow);font-weight:600;text-align:center}

/* Full width CTA */
.full-cta{background:linear-gradient(90deg,rgba(181,115,58,0.98),rgba(181,115,58,0.92));color:#fff;padding:22px;border-radius:12px;margin:18px 0}
.full-cta .cta-inner{display:flex;flex-direction:column;gap:12px;align-items:center}
.full-cta h2{margin:0;font-family:var(--font-heading)}

/* Responsive rules */
@media(min-width:700px){
  .info-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:2fr 1fr;align-items:start}
  .form-row--full{grid-column:auto}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .full-cta .cta-inner{flex-direction:row;justify-content:space-between}
}

@media(min-width:900px){
  .contact-hero{min-height:64vh;align-items:center}
  .hero-row{flex-direction:row;align-items:center;justify-content:space-between}
  .hero-content{flex:1;padding-right:28px}
  .hero-card{flex:0 0 360px}
}

@media(min-width:1100px){
  .info-grid{grid-template-columns:repeat(4,1fr)}
  .form-grid{grid-template-columns:1.4fr 1fr}
  .why-grid{grid-template-columns:repeat(4,1fr)}
}

/* Utilities */
.muted{color:var(--muted)}
.lead{font-size:clamp(0.95rem,1.8vw,1.05rem)}

/* small helpful notes */
/* All transitions use ease-in-out feel, rounded corners and soft shadows for premium aesthetic */
