/* ============================================================
   contact.css
   Styles for the standalone Johken Interior Contact page.
   ============================================================ */

/* HERO */
.contact-hero{margin-top:80px;height:420px;background:var(--charcoal);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;}
.contact-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.contact-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,28,26,.7) 0%,rgba(28,28,26,.5) 100%);}
.contact-hero-content{position:relative;z-index:2;max-width:640px;padding:0 24px;}
.contact-hero-content h1{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,4.5vw,56px);font-weight:300;color:var(--cream);line-height:1.15;margin-bottom:20px;}
.contact-hero-content h1 em{font-style:italic;color:var(--gold);}
.contact-hero-sub{font-size:15px;font-weight:300;line-height:1.8;color:var(--sand);max-width:520px;margin:0 auto;}

/* CONTACT INFO CARDS */
.contact-info-section{padding:80px 80px 0;background:var(--warm-white);}
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1200px;margin:-60px auto 0;position:relative;z-index:3;}
.contact-card{background:var(--cream);padding:36px 28px;text-align:center;border-top:3px solid var(--gold);transition:transform .3s,box-shadow .3s;}
.contact-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.08);}
.cc-icon{color:var(--gold);margin-bottom:16px;display:flex;justify-content:center;}
.cc-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-weight:500;}
.cc-value{font-size:14px;font-weight:300;color:var(--charcoal);line-height:1.6;}
.cc-secondary{font-size:12px;font-weight:300;color:var(--muted);margin-top:4px;}

/* CONTACT MAIN (FORM + MAP) */
.contact-main{padding:80px;background:var(--charcoal);}
.contact-main-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:1200px;margin:0 auto;}
.contact-form-side .section-label{color:var(--gold);}
.contact-form-side .section-title{color:var(--cream);font-size:clamp(26px,3vw,40px);font-weight:200;margin-bottom:8px;}
.contact-form-side .section-title em{color:var(--gold);}
.contact-form-side .divider{margin-bottom:32px;}

/* Form — dark theme matching service quote form */
.contact-form{display:flex;flex-direction:column;gap:18px;position:relative;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--sand);}
.form-group input,.form-group textarea,.form-group select{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:13px 16px;color:var(--cream);font-family:'Jost',sans-serif;font-size:14px;font-weight:300;outline:none;transition:border .2s;resize:none;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold);}
.form-group select option{background:var(--charcoal);}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(200,184,154,.35);}
.form-submit{padding:15px 36px;background:var(--gold);color:var(--deep-brown);border:none;font-family:'Jost',sans-serif;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.25s;align-self:flex-start;}
.form-submit:hover{background:var(--gold-light);}

/* Success message */
.form-success{display:none;text-align:center;padding:48px 24px;}
.form-success.show{display:block;}
.fs-icon{width:56px;height:56px;border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--gold);margin:0 auto 18px;}
.fs-title{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--cream);margin-bottom:10px;}
.fs-text{font-size:13px;font-weight:300;color:var(--sand);line-height:1.7;}

/* Map side */
.contact-map-side{display:flex;flex-direction:column;gap:0;}
.map-placeholder{flex:1;min-height:400px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--sand);font-size:13px;}
.map-placeholder iframe{width:100%;height:100%;border:none;}
.map-info-bar{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--deep-brown);color:var(--sand);font-size:13px;font-weight:300;}
.mib-icon{color:var(--gold);flex-shrink:0;display:flex;}

/* FOOTER — reuse interior footer styles in shared.css */
footer{background:var(--deep-brown);border-top:1px solid rgba(201,168,76,.18);}

/* RESPONSIVE */
@media(max-width:900px){
  .contact-hero{height:340px;}
  .contact-cards{grid-template-columns:1fr 1fr;margin-top:-40px;}
  .contact-info-section{padding:60px 24px 0;}
  .contact-main{padding:60px 24px;}
  .contact-main-inner{grid-template-columns:1fr;gap:40px;}
}
@media(max-width:540px){
  .contact-cards{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .contact-hero{height:300px;}
  .contact-hero-content h1{font-size:28px;}
}
