/*
Theme Name: Joy The Realtor Final Pro Responsive Full
Theme URI: https://greatbisolutions.com/
Author: Great BI Solutions
Description: Full responsive luxury realtor WordPress theme for Joy The Realtor with Miami/Broward positioning, property showcase, lead capture, realtor photo section, mobile menu, and dynamic button effects.
Version: 2.2.0
License: GPLv2 or later
Text Domain: joy-realtor-final-pro-responsive-full
*/

:root{
  --navy:#041f3d;
  --deep:#062f5f;
  --blue:#0878d8;
  --sky:#52c7ff;
  --aqua:#9cecff;
  --ice:#eefaff;
  --white:#ffffff;
  --sand:#f4eadc;
  --gold:#d7b46a;
  --ink:#102a43;
  --muted:#5f7183;
  --line:rgba(8,120,216,.16);
  --shadow:0 24px 70px rgba(4,31,61,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--ink);background:#fff;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(8,120,216,.12)}
.nav{max-width:1220px;margin:auto;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;position:relative}
.logo{font-size:23px;font-weight:900;letter-spacing:-.04em;color:var(--navy)}
.logo span{color:var(--blue)}
.menu{display:flex;gap:24px;align-items:center}
.menu a{font-size:14px;font-weight:800;color:#24435f}
.menu .nav-cta{padding:12px 18px;border-radius:999px;color:#fff;background:linear-gradient(135deg,var(--blue),var(--sky));box-shadow:0 12px 30px rgba(8,120,216,.25)}
.nav-toggle{display:none}
.hamburger{display:none;width:44px;height:44px;border-radius:14px;border:1px solid rgba(8,120,216,.16);align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer;background:#fff;box-shadow:0 10px 24px rgba(4,31,61,.08)}
.hamburger span{width:20px;height:2px;border-radius:999px;background:var(--navy);transition:.25s ease}

.hero{position:relative;overflow:hidden;min-height:820px;color:#fff;background:radial-gradient(circle at 15% 18%,rgba(156,236,255,.26),transparent 28%),radial-gradient(circle at 82% 16%,rgba(255,255,255,.25),transparent 24%),linear-gradient(135deg,#031a33 0%,#063c77 43%,#0d8ce9 76%,#75dcff 100%)}
.hero:before{content:"";position:absolute;inset:-120px;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.13) 45%,transparent 58%),radial-gradient(circle at 48% 74%,rgba(255,255,255,.12),transparent 30%);animation:floatGlow 11s ease-in-out infinite alternate}
@keyframes floatGlow{from{transform:translate3d(-20px,-12px,0) scale(1)}to{transform:translate3d(28px,16px,0) scale(1.04)}}
.hero-inner{position:relative;z-index:2;max-width:1220px;margin:auto;display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center;padding:104px 24px 82px;min-height:calc(100vh - 72px)}
.badge{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid rgba(255,255,255,.34);border-radius:999px;background:rgba(255,255,255,.12);font-size:13px;font-weight:850}
.hero h1{font-family:Georgia,Times New Roman,serif;margin:24px 0 22px;font-size:clamp(2.45rem,7vw,4.65rem);line-height:.95;letter-spacing:-.065em;max-width:700px}
.hero p{font-size:18px;line-height:1.85;color:rgba(255,255,255,.90);max-width:610px}
.actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;padding:15px 23px;font-weight:900;transition:.25s ease;position:relative;overflow:hidden}
.btn:before,.menu .nav-cta:before,.form button:before{content:"";position:absolute;top:0;left:-120%;width:80%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-18deg);transition:left .55s ease}
.btn:hover:before,.menu .nav-cta:hover:before,.form button:hover:before{left:130%}
.btn:hover,.menu .nav-cta:hover,.form button:hover{transform:translateY(-3px) scale(1.015);box-shadow:0 22px 48px rgba(8,120,216,.27)}
.btn-primary{background:#fff;color:var(--navy);box-shadow:0 20px 45px rgba(0,0,0,.20)}
.btn-secondary{border:1px solid rgba(255,255,255,.50);color:#fff;background:rgba(255,255,255,.08)}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff}
.btn-outline-blue{color:var(--navy);border:1px solid rgba(8,120,216,.28);background:rgba(255,255,255,.82)}
.hero-card{border-radius:34px;padding:16px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.36);box-shadow:0 36px 100px rgba(0,0,0,.28);backdrop-filter:blur(18px);transform:rotate(1.2deg)}
.hero-card img{width:100%;height:540px;object-fit:cover;border-radius:25px}
.hero-showcase{position:relative}
.floating-card{position:absolute;left:-18px;bottom:34px;width:255px;padding:20px;border-radius:24px;background:rgba(255,255,255,.92);color:var(--ink);box-shadow:0 25px 70px rgba(0,0,0,.18)}
.floating-card strong{display:block;color:var(--navy);font-size:24px}
.floating-card span{color:var(--muted);font-size:13px;line-height:1.5}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px}
.stat{padding:22px;border-radius:22px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.24)}
.stat strong{display:block;font-size:30px;color:#fff}.stat span{font-size:13px;color:rgba(255,255,255,.78);line-height:1.5}

.section{padding:96px 24px}.container{max-width:1220px;margin:auto}
.kicker{display:inline-block;color:var(--blue);text-transform:uppercase;letter-spacing:.17em;font-size:12px;font-weight:950;margin-bottom:12px}
.section h2{font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,5vw,3.15rem);line-height:1.04;letter-spacing:-.045em;color:var(--navy);margin:0 0 18px}
.lead{max-width:790px;color:var(--muted);font-size:17px;line-height:1.75}
.gradient-soft{background:radial-gradient(circle at 78% 20%,rgba(82,199,255,.18),transparent 28%),linear-gradient(135deg,#f2fbff 0%,#fff 48%,#e7f8ff 100%)}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:center}
.image-frame{border-radius:34px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.image-frame img{width:100%;height:520px;object-fit:cover}
.feature-list{display:grid;gap:16px;margin-top:28px}.two-col{grid-template-columns:repeat(2,1fr)}
.feature{padding:20px;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.76);box-shadow:0 12px 30px rgba(4,31,61,.06)}
.feature strong{display:block;color:var(--navy);font-size:18px;margin-bottom:6px}.feature span{color:var(--muted);line-height:1.6}

.service-grid,.property-grid,.neighborhood-grid,.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.service,.property,.neighborhood,.testimonial{border:1px solid var(--line);background:#fff;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);transition:.25s ease}
.service:hover,.property:hover,.neighborhood:hover,.testimonial:hover,.feature:hover{transform:translateY(-5px);border-color:rgba(8,120,216,.32)}
.service{padding:30px}.icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;margin-bottom:18px;color:#fff;background:linear-gradient(135deg,var(--blue),var(--sky));box-shadow:0 16px 32px rgba(8,120,216,.20)}
.service h3,.property h3,.neighborhood h3,.testimonial h3{margin:0 0 10px;color:var(--navy);font-size:23px}
.service p,.property p,.neighborhood p,.testimonial p{color:var(--muted);line-height:1.68}
.property img,.neighborhood img{width:100%;height:265px;object-fit:cover}
.property-body,.neighborhood-body,.testimonial{padding:26px}.price{color:var(--blue);font-weight:950;margin-bottom:8px}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.tags span{font-size:12px;font-weight:850;color:var(--deep);background:var(--ice);border:1px solid rgba(8,120,216,.12);padding:8px 10px;border-radius:999px}
.property img,.neighborhood img,.hero-card img,.image-frame img{transition:transform .7s ease,filter .7s ease}
.property:hover img,.neighborhood:hover img,.hero-card:hover img,.image-frame:hover img{transform:scale(1.045);filter:saturate(1.06) contrast(1.03)}

.realtor-section{background:radial-gradient(circle at 10% 20%,rgba(82,199,255,.18),transparent 24%),linear-gradient(135deg,#ffffff 0%,#effaff 100%)}
.realtor-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center;border:1px solid var(--line);border-radius:40px;padding:36px;background:rgba(255,255,255,.78);box-shadow:var(--shadow)}
.realtor-photo-wrap{border-radius:34px;padding:14px;background:linear-gradient(135deg,rgba(8,120,216,.20),rgba(82,199,255,.32),rgba(255,255,255,.8))}
.realtor-photo-wrap img{width:100%;height:520px;object-fit:cover;object-position:center top;border-radius:26px}
.cta-panel{position:relative;overflow:hidden;border-radius:40px;padding:60px;color:#fff;background:radial-gradient(circle at 90% 15%,rgba(255,255,255,.27),transparent 25%),linear-gradient(135deg,var(--navy),var(--blue),var(--sky));box-shadow:0 30px 90px rgba(8,120,216,.24)}
.cta-panel h2{color:#fff}.cta-panel p{color:rgba(255,255,255,.88)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.form{background:#fff;border-radius:30px;padding:30px;box-shadow:0 28px 80px rgba(0,0,0,.20)}
.form input,.form select,.form textarea{width:100%;margin-bottom:14px;padding:15px 16px;border:1px solid #d7eaf6;border-radius:15px;font:inherit;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 4px rgba(82,199,255,.18)}
.form button{width:100%;border:0;cursor:pointer;padding:16px 18px;border-radius:999px;font-weight:950;color:#fff;background:linear-gradient(135deg,var(--blue),var(--sky));box-shadow:0 15px 35px rgba(8,120,216,.25);position:relative;overflow:hidden}
.form-note{display:block;margin-top:12px;color:#7a8da0;font-size:12px;line-height:1.5}
.whatsapp-float{position:fixed;right:22px;bottom:22px;z-index:200;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#25d366,#7df5b5);color:#fff;font-weight:1000;box-shadow:0 18px 45px rgba(37,211,102,.35);animation:softPulse 2.6s ease-in-out infinite}
@keyframes softPulse{0%,100%{box-shadow:0 18px 45px rgba(37,211,102,.35);transform:translateY(0)}50%{box-shadow:0 24px 60px rgba(37,211,102,.50);transform:translateY(-2px)}}
.footer{background:#041d38;color:#cdeeff;padding:42px 24px;text-align:center}.footer strong{color:#fff}

@media(max-width:1100px){.property-grid,.neighborhood-grid,.service-grid,.testimonial-grid{grid-template-columns:repeat(2,1fr)}.hero-inner{gap:36px;padding:74px 24px 64px}}
@media(max-width:780px){
 .hamburger{display:flex}.menu{position:absolute;left:16px;right:16px;top:64px;display:grid;gap:0;padding:10px;border-radius:22px;background:rgba(255,255,255,.97);border:1px solid rgba(8,120,216,.12);box-shadow:0 24px 70px rgba(4,31,61,.16);transform:scaleY(.92);opacity:0;visibility:hidden;transition:.22s ease;transform-origin:top}.menu a{padding:14px 16px;border-radius:14px}.menu .nav-cta{text-align:center;margin-top:6px}.nav-toggle:checked ~ .menu{opacity:1;visibility:visible;transform:scaleY(1)}.nav-toggle:checked + .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle:checked + .hamburger span:nth-child(2){opacity:0}.nav-toggle:checked + .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
 .hero{min-height:auto}.hero-inner,.split,.cta-grid,.realtor-card{grid-template-columns:1fr}.hero-inner{min-height:auto;padding:58px 18px 52px}.hero p,.lead{font-size:16px;line-height:1.7}.actions{width:100%}.actions .btn{width:100%}.stats,.property-grid,.neighborhood-grid,.service-grid,.testimonial-grid,.two-col{grid-template-columns:1fr}.section{padding:62px 18px}.hero-card{transform:none;border-radius:26px;padding:10px}.hero-card img,.image-frame img{height:330px;border-radius:20px}.property img,.neighborhood img{height:220px}.floating-card{position:relative;left:auto;bottom:auto;width:auto;margin:14px 0 0}.cta-panel{border-radius:28px;padding:30px 18px}.form{padding:20px;border-radius:22px}.realtor-card{padding:18px;border-radius:28px;gap:26px}.realtor-photo-wrap img{height:380px}.whatsapp-float{right:16px;bottom:16px;width:54px;height:54px}
}
@media(max-width:430px){.logo{font-size:20px}.badge{font-size:11px;padding:9px 12px}.hero h1{font-size:2.35rem}.section h2{font-size:2rem}.hero-card img,.image-frame img{height:260px}.property-body,.neighborhood-body,.testimonial,.service{padding:22px}.realtor-photo-wrap img{height:320px}}


.joy-custom-form .form-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:15px;
}

.joy-custom-form .full-width{
grid-column:1 / -1;
}

.joy-custom-form input,
.joy-custom-form select,
.joy-custom-form textarea{
width:100%;
padding:14px 16px;
border:1px solid #d6e4f2;
border-radius:12px;
font-size:15px;
}

.joy-submit-button{
width:100%;
padding:15px;
border:none;
border-radius:999px;
background:linear-gradient(135deg,#1d75bd,#38aeea);
color:#fff;
font-weight:700;
cursor:pointer;
margin-top:10px;
}

@media(max-width:768px){
.joy-custom-form .form-grid{
grid-template-columns:1fr;
}
}

.form-error{
    display:block;
    margin-top:6px;
    color:#d93025;
    font-size:13px;
    font-weight:600;
}

.field-error{
    border-color:#d93025 !important;
    box-shadow:0 0 0 3px rgba(217,48,37,.12) !important;
}



.testimonial h3 {
    margin-bottom: 18px;
}

.specialties-list {
    margin-top: 0;
    padding-left: 20px;
}

.specialties-list li {
    margin-bottom: 12px;
    font-weight: 500;
    color: #0f2742;
}

.specialties-list,
.specialties-list li {
    color: #0f2742 !important;
}



.testimonial {
    color: #0f2742 !important;
}

.testimonial h3 {
    color: #041f3d !important;
}

.testimonial ul,
.testimonial li {
    color: #0f2742 !important;
}
