/*
Theme Name: Sell Stuck Land
Theme URI: https://sellstucklandllc.com/
Author: Sell Stuck Land LLC
Description: Custom WordPress theme for Sell Stuck Land — a land-buying lead generation site with a real photo gallery of land and neighborhood settings.
Version: 1.0
Requires at least: 5.8
Requires PHP: 7.4
Text Domain: sellstuckland
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#FAF7F2;
  --cream2:#F2EDE4;
  --rust:#C8541A;
  --rust-dark:#A03E0F;
  --rust-light:#FBEEE8;
  --rust-mid:#F0CBB8;
  --forest:#1E3A2F;
  --forest-mid:#2D5441;
  --forest-light:#E8F0EB;
  --gold:#B8943A;
  --gold-light:#F7F1E3;
  --stone:#6B6560;
  --stone-light:#9E9790;
  --border:#E0D8CE;
  --white:#FFFFFF;
  --display:'Playfair Display',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--forest);background:var(--cream);font-size:16px;line-height:1.6}

/* FLOATING WA */
.float-wa{position:fixed;bottom:28px;right:28px;z-index:999;background:#25D366;color:#fff;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;text-decoration:none;box-shadow:0 6px 24px rgba(37,211,102,0.4);transition:transform 0.2s}
.float-wa:hover{transform:scale(1.1)}

/* NAV */
nav{position:sticky;top:0;z-index:100;background:rgba(250,247,242,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 6%;height:70px}
.logo{font-family:var(--display);font-size:22px;font-weight:900;color:var(--forest);text-decoration:none;letter-spacing:-0.3px}
.logo span{color:var(--rust)}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-family:var(--body);text-decoration:none;color:var(--stone);font-size:14px;font-weight:500;letter-spacing:0.2px;transition:color 0.2s}
.nav-links a:hover{color:var(--rust)}
.nav-cta{background:var(--rust)!important;color:var(--white)!important;padding:10px 24px;border-radius:6px;font-weight:700!important;transition:background 0.2s!important}
.nav-cta:hover{background:var(--rust-dark)!important}

/* HERO */
.hero{background:var(--forest);color:var(--white);min-height:92vh;display:flex;align-items:center;padding:0 6%;position:relative;overflow:hidden}
.hero-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 70% 50%,rgba(184,148,58,0.12) 0%,transparent 60%),radial-gradient(circle at 20% 80%,rgba(200,84,26,0.08) 0%,transparent 50%);pointer-events:none}
.hero-inner{max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1.1fr 0.9fr;gap:72px;align-items:center;position:relative;z-index:1;padding:80px 0}
.hero-label{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);border:1px solid rgba(184,148,58,0.35);padding:7px 16px;border-radius:3px;margin-bottom:28px}
.hero h1{font-family:var(--display);font-size:clamp(40px,5.5vw,68px);font-weight:900;line-height:1.05;letter-spacing:-1.5px;color:var(--white);margin-bottom:24px}
.hero h1 .accent{color:var(--rust);font-style:italic}
.hero-desc{font-size:17px;color:rgba(255,255,255,0.72);line-height:1.75;max-width:500px;margin-bottom:40px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-rust{background:var(--rust);color:var(--white);padding:16px 32px;border-radius:6px;font-size:15px;font-weight:700;text-decoration:none;transition:background 0.2s,transform 0.15s;display:inline-block;letter-spacing:0.3px}
.btn-rust:hover{background:var(--rust-dark);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.85);padding:15px 28px;border-radius:6px;font-size:15px;font-weight:600;text-decoration:none;transition:all 0.2s;display:inline-block}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.hero-right{display:flex;flex-direction:column;gap:3px}
.hero-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:28px 28px 24px;margin-bottom:12px;transition:background 0.2s}
.hero-card:hover{background:rgba(255,255,255,0.08)}
.hero-card-icon{font-size:28px;margin-bottom:12px}
.hero-card h4{font-family:var(--display);font-size:20px;font-weight:700;color:var(--white);margin-bottom:6px}
.hero-card p{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.6}

/* DIVIDER */
.section-divider{height:1px;background:var(--border);margin:0 6%}

/* LAND & NEIGHBORHOOD GALLERY */
.gallery{padding:100px 6%;background:var(--cream2)}
.gallery-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:18px;max-width:1100px}
.gallery-item{position:relative;border-radius:16px;overflow:hidden;background:var(--stone-light)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item-tall{grid-row:1 / 3}
.gallery-item:not(.gallery-item-tall){aspect-ratio:1/1}
.gallery-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;background:linear-gradient(180deg,transparent,rgba(30,58,47,0.85));color:var(--white);font-size:14px;font-weight:600;letter-spacing:0.2px}
@media(max-width:768px){
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gallery-item-tall{grid-row:auto;grid-column:1 / 3;aspect-ratio:16/9}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item-tall{grid-column:1}
}

/* SITUATIONS — who we help */
.situations{padding:100px 6%;background:var(--cream)}
.section-wrap{max-width:1100px;margin:0 auto}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--rust);margin-bottom:14px}
.section-h{font-family:var(--display);font-size:clamp(32px,4vw,48px);font-weight:900;color:var(--forest);letter-spacing:-1px;margin-bottom:16px;line-height:1.1}
.section-p{font-size:16px;color:var(--stone);max-width:540px;line-height:1.75;margin-bottom:56px}
.sit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden}
.sit-card{background:var(--white);padding:32px 28px;transition:background 0.2s}
.sit-card:hover{background:var(--rust-light)}
.sit-emoji{font-size:32px;margin-bottom:16px}
.sit-card h3{font-family:var(--display);font-size:19px;font-weight:700;color:var(--forest);margin-bottom:10px}
.sit-card p{font-size:14px;color:var(--stone);line-height:1.65}

/* PROCESS */
.process{padding:100px 6%;background:var(--forest)}
.process .section-h{color:var(--white)}
.process .section-p{color:rgba(255,255,255,0.6);margin-bottom:60px}
.process .eyebrow{color:var(--gold)}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.proc-card{position:relative}
.proc-num{font-family:var(--display);font-size:64px;font-weight:900;color:rgba(184,148,58,0.2);line-height:1;margin-bottom:4px}
.proc-card h3{font-family:var(--display);font-size:20px;font-weight:700;color:var(--white);margin-bottom:10px}
.proc-card p{font-size:14px;color:rgba(255,255,255,0.58);line-height:1.7}
.proc-divider{width:40px;height:2px;background:var(--rust);margin:14px 0}

/* PROMISE */
.promise{padding:100px 6%;background:var(--cream2)}
.promise-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.promise .section-h{margin-bottom:10px}
.promise-intro{font-size:16px;color:var(--stone);line-height:1.75;margin-bottom:40px}
.promise-list{display:flex;flex-direction:column;gap:20px}
.promise-item{display:flex;gap:16px;align-items:flex-start}
.pi-check{width:28px;height:28px;border-radius:50%;background:var(--forest);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;flex-shrink:0;margin-top:2px}
.pi-text h4{font-size:15px;font-weight:700;color:var(--forest);margin-bottom:3px}
.pi-text p{font-size:14px;color:var(--stone);line-height:1.6}
.promise-panel{background:var(--forest);border-radius:20px;padding:48px 40px;color:var(--white);position:sticky;top:90px}
.promise-panel .pp-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.promise-panel h3{font-family:var(--display);font-size:28px;font-weight:900;color:var(--white);line-height:1.2;margin-bottom:8px}
.promise-panel .pp-sub{font-size:14px;color:rgba(255,255,255,0.55);margin-bottom:32px}
.pp-steps{display:flex;flex-direction:column;gap:20px}
.pp-step{display:flex;gap:14px;align-items:flex-start}
.pp-dot{width:10px;height:10px;border-radius:50%;background:var(--rust);flex-shrink:0;margin-top:6px}
.pp-step-text{font-size:14px;color:rgba(255,255,255,0.78);line-height:1.6}
.pp-step-text strong{color:var(--white)}
.pp-guarantee{background:rgba(184,148,58,0.12);border:1px solid rgba(184,148,58,0.3);border-radius:10px;padding:18px 20px;margin-top:28px}
.pp-guarantee p{font-size:13px;color:var(--gold);line-height:1.6;font-weight:500}

/* ABOUT */
.about{padding:100px 6%;background:var(--cream)}
.about-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-left .section-p{margin-bottom:28px}
.about-left p+p{margin-top:16px}
.about-metrics{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:36px}
.metric{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:22px 20px}
.metric .n{font-family:var(--display);font-size:36px;font-weight:900;color:var(--rust);letter-spacing:-1px;line-height:1}
.metric .l{font-size:13px;color:var(--stone);margin-top:4px}
.about-right{display:flex;flex-direction:column;gap:14px}
.about-value{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:22px 20px;transition:border-color 0.2s}
.about-value:hover{border-color:var(--rust)}
.av-icon{font-size:24px;flex-shrink:0;width:44px;height:44px;background:var(--rust-light);border-radius:10px;display:flex;align-items:center;justify-content:center}
.av-text h4{font-size:15px;font-weight:700;color:var(--forest);margin-bottom:3px}
.av-text p{font-size:13px;color:var(--stone);line-height:1.55}

/* TESTIMONIALS */
.testimonials{padding:100px 6%;background:var(--cream2)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.testi-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:32px 28px}
.stars{color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:14px}
.testi-card blockquote{font-size:15px;color:var(--forest);line-height:1.75;margin-bottom:20px;font-style:italic}
.testi-author{font-size:13px;font-weight:700;color:var(--forest)}
.testi-loc{font-size:12px;color:var(--stone-light);margin-top:2px}

/* CONTACT */
.contact{padding:100px 6%;background:var(--forest)}
.contact-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:0.9fr 1.1fr;gap:72px;align-items:start}
.contact .eyebrow{color:var(--gold)}
.contact .section-h{color:var(--white);margin-bottom:14px}
.contact .section-p{color:rgba(255,255,255,0.6);margin-bottom:36px}
.reach-options{display:flex;flex-direction:column;gap:12px}
.reach-btn{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:12px;padding:18px 20px;text-decoration:none;color:var(--white);font-weight:600;font-size:15px;transition:all 0.2s}
.reach-btn:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.25)}
.reach-btn.wa:hover{border-color:rgba(37,211,102,0.5)}
.reach-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.ri-wa{background:rgba(37,211,102,0.15)}
.ri-call{background:rgba(200,84,26,0.2)}
.ri-email{background:rgba(255,255,255,0.1)}
.reach-sub{font-size:12px;color:rgba(255,255,255,0.45);font-weight:400;margin-top:2px}

/* FORM */
.form-card{background:var(--white);border-radius:20px;padding:44px 40px}
.form-card h3{font-family:var(--display);font-size:24px;font-weight:900;color:var(--forest);margin-bottom:6px}
.form-card .fc-sub{font-size:14px;color:var(--stone);margin-bottom:28px}
.progress-wrap{margin-bottom:28px}
.progress-label{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--stone);margin-bottom:8px;letter-spacing:0.3px}
.progress-bar{height:4px;background:var(--border);border-radius:4px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--rust),var(--gold));border-radius:4px;transition:width 0.45s ease}
.form-step{display:none}
.form-step.active{display:block;animation:fadeUp 0.3s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--stone)}
.opt{font-weight:400;color:#C0BAB2;font-size:10px;text-transform:none;letter-spacing:0;margin-left:4px}
.fg input,.fg select,.fg textarea{padding:12px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:var(--body);color:var(--forest);background:var(--cream);outline:none;transition:all 0.2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--rust);background:var(--white);box-shadow:0 0 0 3px rgba(200,84,26,0.08)}
.fg select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-color:var(--cream);padding-right:36px;cursor:pointer}
.fg textarea{resize:vertical;min-height:80px}
.motiv-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.motiv-card{border:1.5px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:all 0.2s;background:var(--cream)}
.motiv-card:hover,.motiv-card.selected{border-color:var(--rust);background:var(--rust-light)}
.motiv-emoji{font-size:22px;margin-bottom:7px}
.motiv-title{font-size:13px;font-weight:700;color:var(--forest);margin-bottom:2px}
.motiv-desc{font-size:11px;color:var(--stone);line-height:1.4}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:16px}
.chip{border:1.5px solid var(--border);border-radius:50px;padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s;background:var(--cream);color:var(--forest);font-family:var(--body)}
.chip:hover{border-color:var(--rust);color:var(--rust)}
.chip.selected{border-color:var(--rust);background:var(--rust);color:var(--white)}
.smart-hint{background:var(--rust-light);border:1px solid var(--rust-mid);border-radius:8px;padding:13px 16px;font-size:13px;color:var(--rust-dark);margin-bottom:16px;display:none;line-height:1.55}
.form-nav{display:flex;gap:12px;margin-top:8px}
.btn-back{flex:1;background:var(--cream);border:1.5px solid var(--border);color:var(--stone);padding:13px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--body);transition:border-color 0.2s}
.btn-back:hover{border-color:var(--stone)}
.btn-next{flex:2;background:var(--rust);color:var(--white);border:none;padding:14px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--body);transition:all 0.2s}
.btn-next:hover{background:var(--rust-dark);transform:translateY(-1px)}
.btn-submit{width:100%;background:var(--forest);color:var(--white);border:none;padding:16px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;font-family:var(--body);transition:all 0.2s;letter-spacing:0.2px}
.btn-submit:hover{background:var(--forest-mid);transform:translateY(-1px)}
.form-note{font-size:12px;color:var(--stone-light);text-align:center;margin-top:12px}
.success-screen{display:none;text-align:center;padding:32px 0}
.success-screen .s-icon{font-size:56px;margin-bottom:18px}
.success-screen h3{font-family:var(--display);font-size:24px;font-weight:900;color:var(--forest);margin-bottom:10px}
.success-screen p{font-size:15px;color:var(--stone);line-height:1.7;margin-bottom:24px}
.success-wa{display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;text-decoration:none;padding:14px 28px;border-radius:8px;font-weight:700;font-size:15px;transition:opacity 0.2s}
.success-wa:hover{opacity:0.88}

/* FOOTER */
footer{background:var(--cream2);border-top:1px solid var(--border);padding:60px 6% 36px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;max-width:1100px;margin:0 auto 40px}
.footer-logo{font-family:var(--display);font-size:22px;font-weight:900;color:var(--forest)}
.footer-logo span{color:var(--rust)}
.footer-brand p{font-size:13px;color:var(--stone);line-height:1.7;margin-top:10px;max-width:280px}
.footer-contact{margin-top:16px;display:flex;flex-direction:column;gap:7px}
.footer-contact a{font-size:14px;color:var(--stone);text-decoration:none;font-weight:600;transition:color 0.2s}
.footer-contact a:hover{color:var(--rust)}
.footer-col h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--forest);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:14px;color:var(--stone);text-decoration:none;transition:color 0.2s}
.footer-col ul a:hover{color:var(--rust)}
.footer-bottom{max-width:1100px;margin:0 auto;border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--stone-light);flex-wrap:wrap;gap:10px}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px;padding:80px 0 60px}
  .hero-right{flex-direction:row;flex-wrap:wrap}
  .hero-card{flex:1;min-width:200px;margin-bottom:0}
  .promise-inner{grid-template-columns:1fr}
  .promise-panel{position:static}
  .about-inner{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sit-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .nav-links li:not(:last-child){display:none}
  .form-row{grid-template-columns:1fr}
  .motiv-grid{grid-template-columns:1fr 1fr}
  .about-metrics{grid-template-columns:1fr 1fr}
  footer{text-align:center}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .motiv-grid{grid-template-columns:1fr}
  .form-card{padding:28px 20px}
  .hero-right{flex-direction:column}
}
