/* ===== Find Us + Contact pages ===== */

.page-hero { padding: clamp(36px, 5vw, 64px) 0 clamp(24px, 3vw, 36px); text-align: center; }
.page-hero h1 { font-size: clamp(2.7rem, 5.6vw, 4.4rem); }
.page-hero h1 .script { color: var(--green); display: block; font-size: .6em; }
.page-hero p { color: var(--ink-soft); max-width: 56ch; margin: 14px auto 0; font-size: 1.08rem; }

/* Big map */
.map-wide { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 21/8; border: 1px solid rgba(36,31,27,.1); }
.map-wide iframe { width: 100%; height: 100%; border: 0; }
@media (max-width: 760px) { .map-wide { aspect-ratio: 4/3; } }

/* Info columns */
.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.info-card { background: var(--card); border: 1px solid rgba(36,31,27,.08); border-radius: var(--r-lg); padding: 28px 26px; box-shadow: var(--shadow-sm); }
.info-card .ic { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 16px; }
.info-card .ic svg { width: 25px; height: 25px; }
.info-card h3 { font-size: 1.4rem; margin-bottom: 8px; }
.info-card p { color: var(--ink-soft); margin: 0; font-size: .96rem; }
.info-card a.lk { color: var(--red); font-weight: 700; display: inline-block; margin-top: 8px; }
@media (max-width: 820px) { .info-grid { grid-template-columns: 1fr; } }

/* Hours table */
.hours-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(26px, 4vw, 56px); align-items: center; }
.hours { background: var(--card); border: 1px solid rgba(36,31,27,.08); border-radius: var(--r-lg); padding: 12px 28px; box-shadow: var(--shadow-sm); }
.hours .hr { display: flex; justify-content: space-between; align-items: center; padding: 15px 0; border-bottom: 1px solid rgba(36,31,27,.1); }
.hours .hr:last-child { border-bottom: 0; }
.hours .hr.today { font-weight: 800; }
.hours .hr .day { font-weight: 600; }
.hours .hr.today .day::after { content: "Today"; margin-left: 10px; font-size: .68rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: #fff; background: var(--green); padding: 3px 9px; border-radius: var(--r-pill); vertical-align: middle; }
.hours .hr .time { color: var(--ink-soft); }
.hours .hr.today .time { color: var(--ink); }
@media (max-width: 820px) { .hours-wrap { grid-template-columns: 1fr; } }

/* Contact form */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 60px); align-items: start; }
.form-card { background: var(--card); border: 1px solid rgba(36,31,27,.08); border-radius: var(--r-lg); padding: clamp(26px, 3vw, 36px); box-shadow: var(--shadow-sm); }
.form-card h2 { font-size: 1.9rem; }
.form-card p.sub { color: var(--ink-soft); margin: 6px 0 22px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-weight: 700; font-size: .88rem; margin-bottom: 7px; }
.field input, .field textarea, .field select { width: 100%; font-family: inherit; font-size: 1rem; padding: 13px 15px; border-radius: var(--r-sm); border: 1.5px solid rgba(36,31,27,.18); background: var(--paper); color: var(--ink); transition: border-color .18s ease, box-shadow .18s ease; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(44,106,64,.15); }
.field textarea { resize: vertical; min-height: 120px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .form-row { grid-template-columns: 1fr; } }

.contact-side { display: grid; gap: 16px; }
.side-row { display: flex; gap: 16px; align-items: flex-start; background: var(--card); border: 1px solid rgba(36,31,27,.08); border-radius: var(--r); padding: 20px 22px; box-shadow: var(--shadow-sm); }
.side-row .si { width: 44px; height: 44px; border-radius: 11px; flex: none; display: grid; place-items: center; background: var(--green-tint); color: var(--green-deep); }
.side-row .si svg { width: 22px; height: 22px; }
.side-row b { display: block; font-size: 1.05rem; }
.side-row span { color: var(--ink-soft); font-size: .93rem; }
.side-row a { color: var(--red); font-weight: 700; }
