/* ==========================================================================
   AcademicLab — Template Contact Styles
   Extracted from template-contact.php
   ========================================================================== */

/* --- Dark mode patch applied --- */

/* Hero block */
.al-contact-hero{background:var(--uh-red);padding:4rem 0 3rem;}
.al-contact-hero__inner{max-width:1100px;margin:0 auto;padding:0 2rem;}
.al-contact-hero .al-eyebrow{color:rgba(255,255,255,.6);}
.al-contact-hero .al-eyebrow a{color:inherit;text-decoration:none;}
.al-contact-hero h1{font-family:var(--font-display)!important;color:#fff!important;text-transform:uppercase;font-size:clamp(2.5rem,5vw,4rem)!important;margin:.25rem 0 .75rem!important;}
.al-contact-hero p{color:rgba(255,255,255,.8);font-size:1.05rem;margin:0;}

/* Split layout */
.al-contact-split{max-width:1200px;margin:0 auto;padding:3.5rem 2rem 5rem;display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:3rem;align-items:flex-start;}
.al-contact-split__form{min-width:0;}          /* prevents embedded form from overflowing the grid track */
.al-contact-split__aside{display:flex;flex-direction:column;gap:2rem;min-width:0;}

/* Form block base (was missing — caused layout breakage when a real form was embedded) */
.al-contact-form{min-width:0;}
.al-contact-form form{max-width:100%;}
.al-contact-form input,.al-contact-form textarea,.al-contact-form select{max-width:100%;box-sizing:border-box;}
.al-contact-form img,.al-contact-form iframe{max-width:100%;height:auto;}

/* Centered layout */
.al-contact-centered{max-width:1200px;margin:0 auto;padding:3.5rem 2rem 5rem;}
.al-contact-centered__form{max-width:640px;margin:0 auto 3rem;}
.al-contact-centered__info-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem;}
.al-contact-info-card{background:var(--dm-card-bg, #fff);border:1px solid var(--dm-border, #e8e8e8);border-top:3px solid var(--uh-red);padding:1.5rem;text-align:center;}
.al-contact-info-card i{font-size:1.8rem;color:var(--uh-red);display:block;margin-bottom:.75rem;}
.al-contact-info-card h4{font-family:var(--font-display);text-transform:uppercase;font-size:.85rem;color:var(--dm-heading, var(--uh-slate));margin:0 0 .5rem;}
.al-contact-info-card p,.al-contact-info-card ul{font-size:.88rem;color:var(--dm-text-muted, #555);margin:0;line-height:1.6;}
.al-contact-info-card ul{list-style:none;padding:0;}
.al-contact-info-card a{color:var(--uh-red);text-decoration:none;}

/* Minimal layout */
.al-contact-minimal{max-width:1100px;margin:0 auto;padding:3.5rem 2rem 5rem;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:3.5rem;align-items:flex-start;}
.al-contact-minimal__main{min-width:0;}
.al-contact-minimal__sidebar{position:sticky;top:2rem;min-width:0;}

/* Contact info block */
.al-contact-info{background:var(--dm-surface, #f9fafb);border:1px solid var(--dm-border, #e8e8e8);border-left:4px solid var(--uh-gold);padding:1.5rem;}
.al-contact-info__heading{font-family:var(--font-display)!important;text-transform:uppercase;color:var(--dm-heading, var(--uh-slate))!important;font-size:1rem!important;margin:0 0 1rem!important;}
.al-contact-info__lab{font-size:.95rem;color:var(--dm-heading, var(--uh-slate));margin:.1rem 0!important;}
.al-contact-info__dept{font-size:.85rem;color:var(--dm-text-muted, #777);margin:.1rem 0 .75rem!important;}
.al-contact-info__row{display:flex;align-items:flex-start;gap:.65rem;font-size:.88rem;color:var(--dm-text-muted, #555);margin:.5rem 0;line-height:1.5;}
.al-contact-info__row i{color:var(--uh-red);margin-top:.15rem;flex-shrink:0;width:14px;}
.al-contact-info__row a{color:var(--dm-text-muted, #555);text-decoration:none;}
.al-contact-info__row a:hover{color:var(--uh-red);}
.al-contact-info__hours{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--dm-border, #eee);}
.al-contact-info__hours h4{font-family:var(--font-display);text-transform:uppercase;font-size:.8rem;color:var(--dm-heading, var(--uh-slate));margin:0 0 .5rem;display:flex;align-items:center;gap:.4rem;}
.al-contact-info__hours h4 i{color:var(--uh-red);}
.al-contact-info__hours ul{list-style:none;padding:0;margin:0;}
.al-contact-info__hours li{font-size:.82rem;color:var(--dm-text-muted, #666);padding:.2rem 0;border-bottom:1px dotted var(--dm-border, #ddd);}

/* Form block */
.al-contact-form__heading{font-family:var(--font-display)!important;text-transform:uppercase;color:var(--dm-heading, var(--uh-slate))!important;font-size:1.1rem!important;margin:0 0 1.5rem!important;padding-bottom:.5rem;border-bottom:3px solid var(--uh-red);}
.al-contact-form__note{background:var(--dm-surface, #fff8ec);border-left:3px solid var(--uh-gold);padding:.75rem 1rem;font-size:.85rem;color:var(--dm-text-muted, #555);}
.al-contact-fallback-form{opacity:.5;pointer-events:none;}
.al-cf-row{margin-bottom:1rem;}
.al-cf-row label{display:block;font-size:.82rem;font-weight:600;color:var(--dm-heading, var(--uh-slate));margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.5px;}
.al-cf-row input,.al-cf-row textarea{width:100%;padding:.7rem 1rem;border:1px solid var(--dm-border, #ddd);font-size:.92rem;color:var(--dm-text, #333);background:var(--dm-card-bg, #fafafa);}
.al-cf-note{font-size:.78rem;color:var(--dm-text-light, #999);text-align:center;margin-top:1rem;}

/* Map block */
.al-contact-map__label{font-family:var(--font-display)!important;text-transform:uppercase;color:var(--dm-heading, var(--uh-slate))!important;font-size:.95rem!important;margin:0 0 .75rem!important;display:flex;align-items:center;gap:.5rem;}
.al-contact-map__label i{color:var(--uh-red);}
.al-contact-map__embed{height:320px;background:var(--dm-surface, #f0f0f0);overflow:hidden;}
.al-contact-centered__map .al-contact-map__embed{height:400px;}
.al-contact-map__embed iframe{width:100%;height:100%;border:0;display:block;}

/* Responsive layout adjustments */
@media(max-width:900px){
    .al-contact-split,.al-contact-minimal{grid-template-columns:1fr;}
    .al-contact-minimal__sidebar{position:static;}
}
@media(max-width:600px){
    .al-contact-centered__info-row{grid-template-columns:1fr 1fr;}
    .al-contact-hero{padding:2.75rem 0 2rem;}
    .al-contact-map__embed,.al-contact-centered__map .al-contact-map__embed{height:260px;}
}
@media(max-width:420px){
    .al-contact-centered__info-row{grid-template-columns:1fr;}
}
