/* ==========================================
RED CASTLE REALTY CITY GUIDE
city-guide.css
========================================== */

:root{
--red:#c8102e;
--red-dark:#a10c24;
--black:#111111;
--dark:#222222;
--white:#ffffff;
--light:#f5f5f5;
--border:#e7e7e7;
}

*{
margin:0;
padding:0;
box-sizing:border-box;
}

body{
font-family:Arial, Helvetica, sans-serif;
background:#f4f4f4;
color:#333;
line-height:1.6;
}

img{
max-width:100%;
display:block;
}

.city-guide{
max-width:1400px;
margin:30px auto;
display:grid;
grid-template-columns:3fr 1fr;
gap:20px;
padding:0 15px;
}
.main-content{
    display:flex;
    flex-direction:column;
    gap:20px;
}

/* ==========================================
HERO
========================================== */

.hero-banner{
display:grid;
grid-template-columns:42% 58%;
background:#fff;
border-radius:10px;
overflow:hidden;
box-shadow:0 2px 15px rgba(0,0,0,.08);
}

.hero-text{
padding:50px;
}

.hero-text h1{
font-size:50px;
font-weight:800;
color:#081525;
line-height:1;
}

.hero-text h2{
color:var(--red);
font-size:36px;
margin:10px 0 20px;
}

.hero-text p{
margin-bottom:18px;
}

.hero-image img{
width:100%;
height:100%;
object-fit:cover;
}

/* ==========================================
STATS BAR
========================================== */

.stats-bar{
display:grid;
grid-template-columns:repeat(4,1fr);
background:linear-gradient(
90deg,
#a10c24,
#c8102e
);
color:white;
margin-top:15px;
border-radius:10px;
overflow:hidden;
}

.stat-box{
padding:25px;
text-align:center;
border-right:1px solid rgba(255,255,255,.25);
}

.stat-box:last-child{
border-right:none;
}

.stat-box span{
display:block;
font-size:15px;
}

.stat-box strong{
display:block;
font-size:32px;
margin-top:8px;
}

/* ==========================================
CARD GRID
========================================== */

.card-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:15px;
margin-top:20px;
}

.info-card{
background:white;
border-radius:10px;
border:1px solid var(--border);
padding:20px;
box-shadow:0 1px 6px rgba(0,0,0,.05);
}

.info-card h3{
color:#111;
font-size:26px;
margin-bottom:15px;
}

.info-card ul{
padding-left:18px;
}

.info-card li{
margin-bottom:8px;
}

.image-card img{
border-radius:8px;
margin-top:15px;
height:130px;
object-fit:cover;
width:100%;
}

/* ==========================================
FAQ
========================================== */

.faq-section{
background:#fff;
margin-top:20px;
padding:25px;
border-radius:10px;
}

.faq-section h2{
margin-bottom:20px;
}

details{
border:1px solid #ddd;
margin-bottom:10px;
border-radius:5px;
}

summary{
cursor:pointer;
padding:15px;
font-weight:bold;
}

details p{
padding:0 15px 15px;
}

/* ==========================================
CONTACT CARD
========================================== */

.contact-card{
background:#fff;
border-radius:10px;
padding:25px;
margin-top:20px;
display:flex;
gap:25px;
align-items:center;
}

.contact-card img{
width:130px;
height:160px;
object-fit:cover;
border-radius:8px;
}

.contact-card h3{
margin-bottom:10px;
}

.cta-btn{
display:inline-block;
background:var(--red);
color:white;
padding:14px 28px;
text-decoration:none;
border-radius:5px;
margin-top:15px;
font-weight:bold;
}

.cta-btn:hover{
background:var(--red-dark);
}

/* ==========================================
SIDEBAR
========================================== */

.sidebar{
display:flex;
flex-direction:column;
gap:20px;
}

.sidebar-box,
.market-widget{
background:white;
border-radius:10px;
overflow:hidden;
box-shadow:0 2px 10px rgba(0,0,0,.08);
}

.sidebar-box h3,
.market-widget h3{
background:var(--red);
color:white;
padding:18px;
font-size:20px;
}

.sidebar-box ul{
list-style:none;
}

.sidebar-box li{
border-bottom:1px solid #eee;
}

.sidebar-box a{
display:block;
padding:16px 18px;
text-decoration:none;
color:#222;
transition:.3s;
}

.sidebar-box a:hover{
background:#fafafa;
color:var(--red);
}

.market-widget{
padding-bottom:20px;
}

.market-widget img{
padding:15px;
}

.market-widget a{
display:block;
width:90%;
margin:15px auto;
text-align:center;
background:white;
color:var(--red);
border:2px solid var(--red);
padding:14px;
text-decoration:none;
font-weight:bold;
}

.market-widget a:hover{
background:var(--red);
color:white;
}

/* ==========================================
MOBILE
========================================== */

@media(max-width:992px){

.city-guide{
grid-template-columns:1fr;
}

.hero-banner{
grid-template-columns:1fr;
}

.hero-text h1{
font-size:50px;
}

.hero-text h2{
font-size:30px;
}

.card-grid{
grid-template-columns:1fr;
}

.stats-bar{
grid-template-columns:repeat(2,1fr);
}

.contact-card{
flex-direction:column;
text-align:center;
}

}

@media(max-width:600px){

.stats-bar{
grid-template-columns:1fr;
}

.hero-text{
padding:30px;
}

.hero-text h1{
font-size:42px;
}

.hero-text h2{
font-size:26px;
}

}
/* =====================================
   RED CASTLE FOOTER
===================================== */

.rcr-footer{
    background:#081d42;
    color:#fff;
    margin-top:80px;
}

.footer-container{
    max-width:1400px;
    margin:auto;
    padding:70px 30px;
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1.5fr;
    gap:50px;
}

.footer-logo{
    max-width:320px;
    margin-bottom:25px;
}

.footer-description{
    line-height:1.8;
    color:#d6d6d6;
}

.footer-links h3,
.footer-contact h3,
.footer-cta h3{
    color:#d8b46a;
    margin-bottom:25px;
}

.footer-links ul,
.footer-contact ul{
    list-style:none;
    padding:0;
}

.footer-links li,
.footer-contact li{
    margin-bottom:15px;
}

.footer-links a,
.footer-contact a{
    color:#fff;
    text-decoration:none;
}

.footer-links a:hover,
.footer-contact a:hover{
    color:#c8102e;
}

.social-icons{
    margin-top:30px;
}

.social-icons a{
    display:inline-flex;
    width:55px;
    height:55px;
    border:2px solid #fff;
    border-radius:50%;
    align-items:center;
    justify-content:center;
    color:#fff;
    margin-right:12px;
    text-decoration:none;
}

.footer-cta{
    border:1px solid rgba(255,255,255,.15);
    border-radius:16px;
    padding:35px;
}

.footer-stats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
    margin:25px 0;
}

.footer-stats strong{
    display:block;
    font-size:36px;
    color:#d8b46a;
}

.footer-stats span{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:2px;
}

.footer-btn{
    display:block;
    background:#c8102e;
    color:#fff;
    text-align:center;
    text-decoration:none;
    padding:18px;
    border-radius:8px;
    font-weight:700;
}

.footer-btn:hover{
    background:#a10c24;
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);
    text-align:center;
    padding:25px;
    color:#ccc;
    font-size:14px;
}

@media(max-width:992px){

.footer-container{
    grid-template-columns:1fr;
}

}
/* SIDEBAR CONTACT FORM */

.sidebar-form{
    padding:20px;
}

.sidebar-form input,
.sidebar-form textarea{
    width:100%;
    padding:14px;
    margin-bottom:12px;
    border:1px solid #ddd;
    border-radius:6px;
    font-size:15px;
    font-family:inherit;
}

.sidebar-form textarea{
    resize:vertical;
}

.sidebar-form button{
    width:100%;
    background:#c8102e;
    color:#fff;
    border:none;
    padding:15px;
    border-radius:6px;
    font-size:16px;
    font-weight:700;
    cursor:pointer;
    transition:.3s;
}

.sidebar-form button:hover{
    background:#a10c24;
}
/* SOLD PROPERTIES SIDEBAR */

.sold-widget{
    overflow:hidden;
}

.sold-item{
    padding:15px;
    border-bottom:1px solid #eee;
}

.sold-item:last-of-type{
    border-bottom:none;
}

.sold-item img{
    width:100%;
    height:140px;
    object-fit:cover;
    border-radius:6px;
    margin-bottom:10px;
}

.sold-item h4{
    margin:0 0 5px;
    font-size:18px;
}

.sold-item p{
    color:#c8102e;
    font-weight:700;
}

.sold-btn{
    background:#c8102e;
    color:#ffffff !important;
    text-decoration:none;
    font-weight:700;
}

.sold-btn:hover{
    color:#a10c24 !important;
	color:#c8102e !important;
    text-decoration:none;
    font-weight:700;
}
.service-icon{
    width:78px;
    height:78px;
}

.card-title{
    display:flex;
    align-items:center;
    gap:15px;
    margin-bottom:0px;
}

.card-title .service-icon{
    flex-shrink:0;
}

.card-title span{
    line-height:1;
}
.contact-page{
    max-width:1200px;
    margin:50px auto;
    padding:0 20px;
}

.contact-container{
    background:#fff;
    border-radius:12px;
    padding:40px;
    box-shadow:0 2px 15px rgba(0,0,0,.08);
}

.contact-header{
    text-align:center;
    margin-bottom:40px;
}

.contact-header h1{
    color:#7b001c;
    font-size:54px;
    margin-bottom:10px;
}

.contact-header p{
    font-size:24px;
    font-style:italic;
}

.contact-form label{
    display:block;
    font-weight:700;
    margin-bottom:10px;
    margin-top:20px;
}

.contact-form input[type=text],
.contact-form input[type=email],
.contact-form input[type=tel],
.contact-form textarea{
    width:100%;
    padding:16px;
    border:1px solid #ddd;
    font-size:16px;
    border-radius:4px;
}

.two-column{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
}

.radio-group{
    display:flex;
    gap:20px;
    margin-top:15px;
}

.radio-list{
    display:flex;
    flex-direction:column;
    gap:12px;
    margin-top:10px;
}

.submit-btn{
    width:100%;
    margin-top:35px;
    background:#c8102e;
    color:#fff;
    border:none;
    padding:20px;
    font-size:28px;
    font-weight:700;
    cursor:pointer;
    border-radius:4px;
}

.submit-btn:hover{
    background:#a10c24;
}

@media(max-width:768px){

.two-column{
    grid-template-columns:1fr;
}

/* CONTACT HERO FORM */

.hero-contact-form{
    background:#ffffff;
    padding:35px;
    height:100%;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.hero-contact-form h3{
    text-align:center;
    color:#c8102e;
    font-size:32px;
    margin-bottom:25px;
}

.hero-contact-form input,
.hero-contact-form select,
.hero-contact-form textarea{
    width:100%;
    padding:14px;
    margin-bottom:15px;
    border:1px solid #ddd;
    border-radius:5px;
    font-size:16px;
}

.hero-contact-form button{
    width:100%;
    background:#c8102e;
    color:#fff;
    border:none;
    padding:16px;
    font-size:18px;
    font-weight:700;
    border-radius:5px;
    cursor:pointer;
}

.hero-contact-form button:hover{
    background:#a10c24;
}

.hero-contact-form select{
    background:#fff;
}

@media(max-width:992px){

    .hero-contact-form{
        padding:25px;
    }

}