.page-hero {
padding: calc(var(--header-height) + var(--space-2xl)) 0 var(--space-2xl);
background: linear-gradient(180deg, var(--color-primary-bg) 0%, var(--color-bg) 100%);
text-align: center;
}
.page-hero-title {
font-family: var(--font-heading);
font-size: clamp(1.75rem, 4vw, 2.5rem);
font-weight: 800;
line-height: 1.2;
color: var(--color-text);
margin-bottom: var(--space-md);
}
.page-hero-desc {
font-size: 1.1rem;
color: var(--color-text-secondary);
max-width: 600px;
margin: 0 auto;
line-height: 1.6;
}
.contact-page-section {
padding: 0 0 var(--space-3xl);
}
.contact-page-layout {
display: grid;
grid-template-columns: 1fr;
gap: var(--space-2xl);
align-items: start;
}
.contact-page-info {
background: var(--color-bg-alt);
border-radius: var(--radius-lg);
padding: var(--space-xl);
border: 1px solid var(--color-border-light);
}
.contact-page-info-title {
font-family: var(--font-heading);
font-size: clamp(1.3rem, 2.5vw, 1.6rem);
font-weight: 800;
color: var(--color-text);
margin-bottom: var(--space-lg);
line-height: 1.2;
}
.contact-page-info-desc {
font-size: 0.9rem;
color: var(--color-text-secondary);
line-height: 1.6;
margin-bottom: var(--space-xl);
}
.contact-info-list {
display: flex;
flex-direction: column;
gap: var(--space-md);
margin-bottom: var(--space-xl);
}
.contact-info-item {
display: flex;
align-items: center;
gap: var(--space-md);
padding: var(--space-md);
background: var(--color-bg);
border-radius: var(--radius-md);
border: 1px solid var(--color-border-light);
transition: all var(--transition-fast);
flex-wrap: wrap;
}
.contact-info-item:hover {
border-color: var(--color-primary);
box-shadow: var(--shadow-xs);
}
.contact-info-icon {
width: 44px;
height: 44px;
border-radius: var(--radius-md);
background: var(--color-primary-light);
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.contact-info-icon svg,
.contact-info-icon i {
width: 20px;
height: 20px;
color: var(--color-primary);
}
.contact-info-item strong {
display: block;
font-family: var(--font-heading);
font-size: 0.85rem;
font-weight: 700;
color: var(--color-text);
margin-bottom: 0.15rem;
}
.contact-info-item p {
font-size: 0.85rem;
color: var(--color-text-secondary);
margin: 0;
}
.contact-info-highlights {
display: flex;
flex-direction: column;
gap: var(--space-md);
}
.contact-highlight {
display: flex;
gap: var(--space-md);
align-items: flex-start;
}
.contact-highlight svg,
.contact-highlight i {
width: 1.1rem;
height: 1.1rem;
color: var(--color-accent);
flex-shrink: 0;
margin-top: 0.15rem;
}
.contact-highlight strong {
display: block;
font-family: var(--font-heading);
font-size: 0.85rem;
font-weight: 700;
color: var(--color-text);
margin-bottom: 0.15rem;
}
.contact-highlight p {
font-size: 0.82rem;
color: var(--color-text-secondary);
margin: 0;
line-height: 1.45;
}
.contact-link {
text-decoration: none;
color: inherit;
}
a.contact-info-item {
transition: all var(--transition-fast);
}
a.contact-info-item:hover {
border-color: var(--color-primary);
box-shadow: var(--shadow-xs);
background: var(--color-primary-bg);
}
a.contact-info-item:hover .contact-info-icon {
background: var(--color-primary);
}
a.contact-info-item:hover .contact-info-icon svg,
a.contact-info-item:hover .contact-info-icon i {
color: #fff;
}
.contact-info-item p {
color: var(--color-text-secondary);
transition: color var(--transition-fast);
}
a.contact-info-item:hover p {
color: var(--color-primary);
}
.contact-link-icon {
width: 14px;
height: 14px;
color: var(--color-text-muted);
margin-left: auto;
flex-shrink: 0;
transition: color var(--transition-fast);
}
a.contact-info-item:hover .contact-link-icon {
color: var(--color-primary);
}
.contact-coverage {
margin-top: var(--space-xl);
padding-top: var(--space-lg);
border-top: 1px solid var(--color-border-light);
margin-bottom: var(--space-xl);
}
.contact-coverage-title {
font-family: var(--font-heading);
font-size: 0.85rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--color-text-muted);
margin-bottom: var(--space-md);
}
.coverage-card {
display: flex;
gap: var(--space-md);
align-items: flex-start;
padding: var(--space-md);
background: var(--color-bg);
border: 1px solid var(--color-border-light);
border-radius: var(--radius-md);
margin-bottom: var(--space-sm);
transition: all var(--transition-fast);
}
.coverage-card:hover {
border-color: var(--color-primary);
box-shadow: var(--shadow-xs);
}
.coverage-card svg,
.coverage-card i {
width: 1.1rem;
height: 1.1rem;
color: var(--color-primary) !important;
flex-shrink: 0;
margin-top: 0.2rem;
}
.coverage-card--hours svg,
.coverage-card--hours i {
color: var(--color-accent);
}
.coverage-card strong {
display: block;
font-family: var(--font-heading);
font-size: 0.85rem;
font-weight: 700;
color: var(--color-text);
}
.coverage-card span {
display: block;
font-size: 0.78rem;
color: var(--color-text-muted);
margin-bottom: 0.15rem;
}
.coverage-card p {
font-size: 0.82rem;
color: var(--color-text-secondary);
line-height: 1.4;
margin: 0;
}
.contact-map {
width: 100%;
height: auto;
border-radius: var(--radius-md);
margin-top: var(--space-xl);
border: 1px solid var(--color-border-light);
}
.contact-page-form-wrap {
background: var(--color-bg);
border: 1px solid var(--color-border-light);
border-radius: var(--radius-lg);
padding: var(--space-xl);
box-shadow: var(--shadow-sm);
}
.contact-page-form {
display: flex;
flex-direction: column;
gap: var(--space-lg);
}
.form-row {
display: grid;
grid-template-columns: 1fr;
gap: var(--space-lg);
}
.form-group {
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.form-label {
font-family: var(--font-heading);
font-size: 0.85rem;
font-weight: 700;
color: var(--color-text);
}
.required {
color: var(--color-red);
}
.form-input {
width: 100%;
padding: 0.75rem 1rem;
border: 1.5px solid var(--color-border);
border-radius: var(--radius-md);
font-size: 0.95rem;
color: var(--color-text);
background: var(--color-bg);
transition: all var(--transition-fast);
}
.form-input::placeholder {
color: var(--color-text-muted);
}
.form-input:focus {
outline: none;
border-color: var(--color-primary);
box-shadow: 0 0 0 3px rgba(30,111,217,0.1);
}
.form-input.error {
border-color: var(--color-red);
box-shadow: 0 0 0 3px rgba(231,76,60,0.1);
}
.form-input.valid {
border-color: var(--color-accent);
}
.form-select {
appearance: none;
-webkit-appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A6B7F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 1rem center;
padding-right: 2.5rem;
}
.form-textarea {
resize: vertical;
min-height: 100px;
}
.form-error {
font-size: 0.8rem;
color: var(--color-red);
min-height: 0;
opacity: 0;
transition: all var(--transition-fast);
}
.form-error.visible {
opacity: 1;
min-height: 1.2em;
}
.form-services {
border: none;
padding: 0;
}
.form-services .form-label {
margin-bottom: var(--space-md);
display: block;
font-size: 0.85rem;
}
.form-services-grid {
display: grid;
grid-template-columns: 1fr;
gap: 0.5rem;
}
.form-checkbox-label {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.5rem 0.75rem;
background: var(--color-bg);
border: 1px solid var(--color-border-light);
border-radius: var(--radius-sm);
font-size: 0.85rem;
font-weight: 500;
color: var(--color-text-secondary);
cursor: pointer;
transition: all var(--transition-fast);
user-select: none;
}
.form-checkbox-label:hover {
border-color: var(--color-primary);
background: var(--color-primary-bg);
}
.form-checkbox-label:has(input:checked) {
border-color: var(--color-primary);
background: var(--color-primary-light);
color: var(--color-primary);
font-weight: 600;
}
.form-checkbox-label input {
appearance: none;
-webkit-appearance: none;
width: 16px;
height: 16px;
border: 2px solid var(--color-border);
border-radius: 3px;
flex-shrink: 0;
position: relative;
cursor: pointer;
}
.form-checkbox-label input:checked {
background: var(--color-primary);
border-color: var(--color-primary);
}
.form-checkbox-label input:checked::after {
content: '';
position: absolute;
left: 3px;
top: 1px;
width: 5px;
height: 8px;
border: solid #fff;
border-width: 0 2px 2px 0;
transform: rotate(45deg);
}
.form-submit {
margin-top: var(--space-sm);
}
.form-disclaimer {
font-size: 0.8rem;
color: var(--color-text-muted);
text-align: center;
}
.form-disclaimer a {
color: var(--color-primary);
text-decoration: underline;
font-weight: 500;
}
.form-success {
display: none;
text-align: center;
padding: var(--space-2xl);
}
.form-success.visible {
display: block;
}
.form-success-icon {
width: 64px;
height: 64px;
background: var(--color-accent-light);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto var(--space-md);
}
.form-success-icon svg,
.form-success-icon i {
width: 32px;
height: 32px;
color: var(--color-accent);
}
.form-success h3 {
font-family: var(--font-heading);
font-size: 1.2rem;
font-weight: 700;
color: var(--color-text);
margin-bottom: var(--space-sm);
}
.form-success p {
font-size: 0.9rem;
color: var(--color-text-secondary);
}
.nav-link.active,
.mobile-nav-link.active {
color: var(--color-primary);
}
@media (min-width: 768px) {
.contact-page-layout {
grid-template-columns: 0.9fr 1.1fr;
}
.form-row {
grid-template-columns: 1fr 1fr;
}
.form-services-grid {
grid-template-columns: 1fr 1fr;
gap: 0.6rem;
}
}
@media (max-width: 768px) {
.contact-page-info {
padding: var(--space-lg) var(--space-md);
}
.contact-page-form-wrap {
padding: var(--space-lg) var(--space-md);
}
}
@media (max-width: 360px) {
.contact-page-form-wrap {
padding: var(--space-lg);
}
.contact-page-info {
padding: var(--space-lg);
}
.form-input {
padding: 0.6rem 0.75rem;
font-size: 0.9rem;
}
.form-checkbox-label {
padding: 0.4rem 0.6rem;
font-size: 0.8rem;
gap: 0.35rem;
}
.form-submit {
padding: 0.85rem 1.5rem;
font-size: 0.95rem;
}
}
