*{
margin:0;
padding:0;
box-sizing:border-box;
}
html{
scroll-behavior:smooth;
}
body{
font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
line-height:1.6;
color:#333;
background-color:#ffffff;
}
.container{
max-width:1200px;
margin:0 auto;
padding:0 20px;
}
h1, h2, h3, h4, h5, h6{
font-weight:600;
margin-bottom:1rem;
color:#2c3e50;
}
h1{
font-size:2.5rem;
}
h2{
font-size:2rem;
margin-bottom:1.5rem;
}
h3{
font-size:1.5rem;
}
p{
margin-bottom:1rem;
color:#555;
}
a{
color:#3498db;
text-decoration:none;
transition:color 0.3s ease;
}
a:hover{
color:#2980b9;
}
header{
background:linear-gradient(135deg, #2c3e50 0%, #34495e 100%);
color:white;
padding:1rem 0;
position:sticky;
top:0;
z-index:1000;
box-shadow:0 2px 10px rgba(0,0,0,0.1);
}
.nav-container{
display:flex;
justify-content:space-between;
align-items:center;
flex-wrap:wrap;
max-width:1200px;
margin:0 auto;
padding:0 20px;
}
.logo{
color:white;
font-size:1.8rem;
margin-bottom:0;
}
.tagline{
color:#ecf0f1;
font-size:0.9rem;
margin:0;
}
.nav-menu{
display:flex;
list-style:none;
gap:2rem;
flex-wrap:wrap;
margin:0;
padding:0;
}
.nav-menu a{
color:white;
font-weight:500;
padding:0.5rem 1rem;
border-radius:5px;
transition:background-color 0.3s ease;
}
.nav-menu a:hover{
background-color:rgba(255,255,255,0.1);
color:white;
}
.biography-section{
padding:4rem 0;
background-color:#f8f9fa;
}
.bio-content{
display:grid;
grid-template-columns:1fr;
gap:2rem;
margin-bottom:3rem;
align-items:center;
}
.section-title{
text-align:center;
color:#2c3e50;
margin-bottom:2rem;
font-size:2.2rem;
}
.bio-content{
display:flex;
align-items:flex-start;
gap:2rem;
margin-bottom:3rem;
}
.bio-image{
flex-shrink:0;
}
.professional-headshot{
width:160px;
height:160px;
border-radius:50%;
object-fit:cover;
border:4px solid #3498db;
box-shadow:0 6px 20px rgba(0,0,0,0.15);
}
.bio-text{
flex:1;
}
.bio-summary{
font-size:1.1rem;
line-height:1.8;
margin-bottom:1.5rem;
color:#444;
}
.additional-bio{
color:#555;
line-height:1.7;
margin-bottom:0;
}
.credentials-vertical{
margin-top:2rem;
}
.credentials-vertical h4{
color:#2c3e50;
margin-bottom:0.8rem;
margin-top:1.5rem;
font-size:1.1rem;
font-weight:600;
}
.credentials-vertical h4:first-child{
margin-top:0;
}
.credentials-vertical ul{
list-style:none;
padding:0;
margin:0 0 1.5rem 0;
}
.credentials-vertical li{
padding:0.3rem 0;
position:relative;
padding-left:1.2rem;
font-size:0.95rem;
color:#555;
line-height:1.4;
}
.credentials-vertical li:before{
content:"•";
color:#3498db;
font-weight:bold;
font-size:1rem;
position:absolute;
left:0;
top:0.3rem;
}
.services-section{
padding:4rem 0;
background-color:white;
}
.services-section h2{
text-align:center;
margin-bottom:3rem;
color:#2c3e50;
}
.services-grid{
display:grid;
grid-template-columns:1fr;
gap:2rem;
}
.service-item{
background:#f8f9fa;
padding:2rem;
border-radius:10px;
text-align:center;
transition:transform 0.3s ease, box-shadow 0.3s ease;
border:1px solid #e9ecef;
}
.service-item:hover{
transform:translateY(-5px);
box-shadow:0 10px 25px rgba(0,0,0,0.1);
}
.service-item h3{
color:#3498db;
margin-bottom:1rem;
}
.service-item p{
color:#666;
line-height:1.6;
}
.portfolio-section{
padding:4rem 0;
background-color:#f8f9fa;
}
.portfolio-section h2{
text-align:center;
margin-bottom:1rem;
color:#2c3e50;
}
.portfolio-intro{
text-align:center;
margin-bottom:3rem;
font-size:1.1rem;
color:#666;
max-width:600px;
margin-left:auto;
margin-right:auto;
}
.portfolio-grid{
display:grid;
grid-template-columns:1fr;
gap:2rem;
}
.property-card{
background:white;
border-radius:10px;
overflow:hidden;
box-shadow:0 5px 15px rgba(0,0,0,0.1);
transition:transform 0.3s ease, box-shadow 0.3s ease;
}
.property-card:hover{
transform:translateY(-5px);
box-shadow:0 15px 30px rgba(0,0,0,0.15);
}
.portfolio-section .property-card .property-image{
width:100% !important;
height:120px !important;
max-height:120px !important;
min-height:120px !important;
overflow:hidden !important;
display:block !important;
}
.portfolio-section .property-card .property-image img{
width:100% !important;
height:100% !important;
max-height:120px !important;
object-fit:cover !important;
transition:transform 0.3s ease;
display:block !important;
}
.portfolio-section img{
max-height:120px !important;
height:120px !important;
object-fit:cover !important;
}
.property-card:hover .property-image img{
transform:scale(1.05);
}
.property-details{
padding:1.5rem;
}
.property-details h3{
color:#2c3e50;
margin-bottom:0.5rem;
font-size:1.3rem;
}
.property-type{
color:#3498db;
font-weight:500;
margin-bottom:1rem;
}
.property-specs{
display:flex;
flex-wrap:wrap;
gap:1rem;
margin-bottom:1rem;
}
.property-specs span{
background:#ecf0f1;
padding:0.3rem 0.8rem;
border-radius:20px;
font-size:0.9rem;
color:#555;
}
.sale-info{
display:flex;
justify-content:space-between;
align-items:center;
flex-wrap:wrap;
gap:1rem;
border-top:1px solid #eee;
padding-top:1rem;
}
.sale-price{
font-size:1.4rem;
font-weight:600;
color:#27ae60;
}
.sale-date{
color:#666;
font-size:0.9rem;
}
.contact-section{
padding:4rem 0;
background-color:white;
}
.contact-section h2{
text-align:center;
margin-bottom:1rem;
color:#2c3e50;
}
.contact-intro{
text-align:center;
margin-bottom:3rem;
font-size:1.1rem;
color:#666;
}
.contact-content{
display:grid;
grid-template-columns:1fr;
gap:3rem;
}
.contact-info{
display:grid;
grid-template-columns:1fr;
gap:2rem;
}
.contact-item h3{
color:#3498db;
margin-bottom:0.5rem;
font-size:1.2rem;
}
.contact-item p{
color:#555;
line-height:1.6;
}
.contact-item a{
color:#3498db;
font-weight:500;
}
.contact-form{
background:#f8f9fa;
padding:2rem;
border-radius:10px;
}
.contact-form h3{
color:#2c3e50;
margin-bottom:1.5rem;
text-align:center;
}
.form-group{
margin-bottom:1.5rem;
}
.form-group label{
display:block;
margin-bottom:0.5rem;
color:#555;
font-weight:500;
}
.form-group input,
.form-group select,
.form-group textarea{
width:100%;
padding:0.8rem;
border:1px solid #ddd;
border-radius:5px;
font-size:1rem;
transition:border-color 0.3s ease;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
outline:none;
border-color:#3498db;
box-shadow:0 0 0 2px rgba(52, 152, 219, 0.2);
}
.submit-btn{
background:linear-gradient(135deg, #3498db 0%, #2980b9 100%);
color:white;
padding:1rem 2rem;
border:none;
border-radius:5px;
font-size:1rem;
font-weight:600;
cursor:pointer;
transition:transform 0.3s ease, box-shadow 0.3s ease;
width:100%;
}
.submit-btn:hover{
transform:translateY(-2px);
box-shadow:0 5px 15px rgba(52, 152, 219, 0.3);
}
.form-message{
padding:1rem;
border-radius:5px;
margin-bottom:1rem;
font-weight:500;
display:none;
}
.form-message.success{
background-color:#d4edda;
color:#155724;
border:1px solid #c3e6cb;
display:block;
}
.form-message.error{
background-color:#f8d7da;
color:#721c24;
border:1px solid #f5c6cb;
display:block;
}
.form-message.info{
background-color:#d1ecf1;
color:#0c5460;
border:1px solid #bee5eb;
display:block;
}
footer{
background:#2c3e50;
color:white;
padding:2rem 0 1rem;
text-align:center;
}
footer .container{
max-width:1200px;
margin:0 auto;
padding:0 20px;
}
footer p{
color:#ecf0f1;
margin:0;
}
.footer-content{
display:grid;
grid-template-columns:1fr;
gap:2rem;
text-align:center;
margin-bottom:2rem;
}
.footer-info h3{
color:white;
margin-bottom:0.5rem;
}
.footer-info p{
color:#bdc3c7;
margin-bottom:0.3rem;
}
.footer-links{
display:flex;
justify-content:center;
gap:2rem;
flex-wrap:wrap;
}
.footer-links a{
color:#bdc3c7;
transition:color 0.3s ease;
}
.footer-links a:hover{
color:white;
}
.footer-social{
display:flex;
justify-content:center;
gap:1rem;
}
.footer-social a{
color:#bdc3c7;
padding:0.5rem 1rem;
border:1px solid #bdc3c7;
border-radius:5px;
transition:all 0.3s ease;
}
.footer-social a:hover{
color:white;
border-color:white;
background-color:rgba(255,255,255,0.1);
}
.footer-bottom{
text-align:center;
padding-top:2rem;
border-top:1px solid #34495e;
}
.footer-bottom p{
color:#bdc3c7;
font-size:0.9rem;
}
@media (min-width:768px){
.nav-menu{
gap:2.5rem;
}
.bio-content{
grid-template-columns:300px 1fr;
gap:3rem;
}
.services-grid{
grid-template-columns:repeat(2, 1fr);
}
.portfolio-grid{
grid-template-columns:repeat(2, 1fr);
}
.contact-content{
grid-template-columns:1fr 1fr;
}
.contact-info{
grid-template-columns:repeat(2, 1fr);
}
.footer-content{
grid-template-columns:repeat(3, 1fr);
text-align:left;
}
.footer-links{
justify-content:flex-start;
}
.footer-social{
justify-content:flex-end;
}
}
@media (min-width:1024px){
.container{
padding:0 40px;
}
h1{
font-size:3rem;
}
h2{
font-size:2.5rem;
}
.logo h1{
font-size:2rem;
}
.services-grid{
grid-template-columns:repeat(3, 1fr);
}
.portfolio-grid{
grid-template-columns:repeat(2, 1fr);
gap:3rem;
}
.contact-info{
grid-template-columns:repeat(2, 1fr);
gap:3rem;
}
.property-specs{
gap:1.5rem;
}
}
@media (min-width:1200px){
.services-grid{
grid-template-columns:repeat(3, 1fr);
gap:3rem;
}
.portfolio-grid{
grid-template-columns:repeat(3, 1fr);
}
}
@media (max-width:767px){
.nav-container{
flex-direction:column;
gap:1rem;
}
.nav-menu{
justify-content:center;
gap:1rem;
}
.nav-menu a{
padding:0.5rem 0.8rem;
font-size:0.9rem;
}
.biography-section{
padding:2rem 0;
}
.services-section,
.portfolio-section,
.contact-section{
padding:3rem 0;
}
.bio-content{
flex-direction:column;
align-items:center;
text-align:center;
gap:1.5rem;
}
.professional-headshot{
width:120px;
height:120px;
}
.property-specs{
justify-content:center;
}
.sale-info{
justify-content:center;
text-align:center;
}
}
@media (prefers-reduced-motion:reduce){
*{
animation-duration:0.01ms !important;
animation-iteration-count:1 !important;
transition-duration:0.01ms !important;
}
}
a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus{
outline:3px solid #3498db;
outline-offset:2px;
box-shadow:0 0 0 1px #ffffff, 0 0 0 4px #3498db;
}
.skip-link{
position:absolute;
top:-40px;
left:6px;
background:#3498db;
color:white;
padding:8px;
text-decoration:none;
border-radius:4px;
z-index:9999;
font-weight:bold;
}
.skip-link:focus{
top:6px;
}
.error-message{
color:#e74c3c;
font-size:0.875rem;
margin-top:0.25rem;
display:none;
}
.error-message.show{
display:block;
}
.help-text{
color:#666;
font-size:0.875rem;
margin-top:0.25rem;
}
.form-group input[aria-invalid="true"],
.form-group select[aria-invalid="true"],
.form-group textarea[aria-invalid="true"]{
border-color:#e74c3c;
box-shadow:0 0 0 2px rgba(231, 76, 60, 0.2);
}
.form-group label span[aria-label="required"]{
color:#e74c3c;
font-weight:bold;
}
.sr-only{
position:absolute;
width:1px;
height:1px;
padding:0;
margin:-1px;
overflow:hidden;
clip:rect(0, 0, 0, 0);
white-space:nowrap;
border:0;
}
@media (prefers-contrast:high){
.service-item,
.property-card,
.contact-form{
border:2px solid #333;
}
.nav-menu a:hover,
.nav-menu a:focus{
background-color:#ffffff;
color:#2c3e50;
}
.submit-btn:hover,
.submit-btn:focus{
background:#ffffff;
color:#2c3e50;
border:2px solid #2c3e50;
}
}
.tagline{
color:#ecf0f1;
}
.footer-info p,
.footer-links a,
.footer-social a,
.footer-bottom p{
color:#ecf0f1;
}
.service-item:focus-within,
.property-card:focus-within{
outline:3px solid #3498db;
outline-offset:2px;
}
.additional-bio{
color:#555;
}
.portfolio-intro,
.contact-intro{
color:#555;
}
.sale-date{
color:#555;
}
.help-text{
color:#555;
}