/*
Theme Name: HOA Iguana Premium Final
Theme URI: https://hoaiguanacontrol.com/
Author: OpenAI
Description: Premium WordPress classic theme for HOA Iguana Control.
Version: 4.0
Requires at least: 6.4
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: hoa-iguana-premium-final
*/

:root{
  --bg:#f4f1e8;
  --card:#ffffff;
  --ink:#1a241c;
  --muted:#5f6d63;
  --brand:#143b29;
  --brand2:#21533b;
  --accent:#c8a96b;
  --line:#dde2da;
  --shadow:0 18px 50px rgba(13,32,22,.10);
  --radius:24px;
  --max:1200px;
}
*{box-sizing:border-box}
body{
  margin:0;
  color:var(--ink);
  background:linear-gradient(180deg,#f8f6ef 0%,#f2f0e7 100%);
  font-family:Inter,Arial,Helvetica,sans-serif;
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:var(--brand2);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.site-header{
  position:sticky;top:0;z-index:20;
  background:rgba(248,246,239,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(20,59,41,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0}
.brand{font-size:28px;font-weight:800;letter-spacing:-.04em;color:var(--brand)}
.tagline{font-size:13px;color:var(--muted);margin-top:4px;max-width:520px}
.main-nav{display:flex;gap:16px;flex-wrap:wrap;justify-content:flex-end}
.main-nav a{color:var(--ink);font-weight:700;font-size:14px}
.hero{padding:70px 0 34px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:center}
.eyebrow{
  display:inline-block;padding:9px 14px;border-radius:999px;
  background:rgba(200,169,107,.16);color:var(--brand);font-size:13px;font-weight:800;margin-bottom:18px
}
.hero h1,.page-title{
  font-size:clamp(40px,6vw,66px);line-height:1.02;margin:0 0 16px;letter-spacing:-.05em;color:var(--brand)
}
.hero .lead{font-size:20px;line-height:1.55;color:#304438;max-width:760px;margin:0 0 24px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 18px;border-radius:999px;font-weight:800;font-size:15px;
  border:1px solid transparent;box-shadow:0 10px 30px rgba(20,59,41,.14)
}
.btn-primary{background:var(--brand);color:#fff}
.btn-secondary{background:#fff;color:var(--brand);border-color:rgba(20,59,41,.12)}
.hero-visual{
  position:relative;background:linear-gradient(180deg,#fff,#f7f3e9);
  border:1px solid rgba(20,59,41,.08);border-radius:32px;padding:18px;box-shadow:var(--shadow)
}
.hero-stack{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}
.hero-stack img{width:100%;height:560px;object-fit:cover;border-radius:24px}
.hero-stack .side-stack{display:grid;grid-template-rows:1fr 1fr;gap:14px}
.hero-stack .side-stack img{height:273px}
.glass-badge{
  position:absolute;left:24px;right:24px;bottom:24px;
  background:rgba(255,255,255,.86);backdrop-filter:blur(8px);
  border:1px solid rgba(20,59,41,.08);border-radius:20px;padding:16px 18px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px
}
.glass-badge strong{display:block;font-size:22px;color:var(--brand)}
.glass-badge span{font-size:13px;color:var(--muted)}
.site-main{padding:14px 0 56px}
.section,.content-panel,.side-box{
  background:var(--card);border:1px solid rgba(20,59,41,.08);
  border-radius:var(--radius);box-shadow:var(--shadow)
}
.section{margin:28px 0;padding:34px}
.section-title{margin:0 0 12px;font-size:36px;line-height:1.05;letter-spacing:-.04em;color:var(--brand)}
.section-intro{font-size:18px;color:#33463a;margin:0 0 20px;max-width:840px}
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:#fff;border:1px solid rgba(20,59,41,.08);border-radius:22px;
  padding:22px;box-shadow:0 10px 28px rgba(13,32,22,.06)
}
.card h3{margin:0 0 10px;font-size:22px;line-height:1.15;color:var(--brand)}
.card p{margin:0;color:#425449}
.icon-chip{
  width:44px;height:44px;border-radius:14px;background:#efe3c8;display:grid;place-items:center;
  font-size:20px;margin-bottom:14px
}
.gallery-card{padding:14px}
.gallery-card img,.feature-photo{width:100%;height:270px;object-fit:cover;border-radius:20px}
.caption{font-size:14px;color:var(--muted);margin-top:8px}
.city-links{display:flex;flex-wrap:wrap;gap:10px}
.city-links a{
  display:inline-flex;padding:10px 14px;border-radius:999px;
  background:#f7f4ec;border:1px solid rgba(20,59,41,.08);font-weight:700;color:var(--brand)
}
.page-shell{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}
.content-panel{padding:34px}
.content-panel h2{font-size:34px;line-height:1.08;letter-spacing:-.04em;margin:30px 0 12px;color:var(--brand)}
.content-panel h3{font-size:24px;margin:24px 0 10px;color:var(--brand)}
.content-panel p,.content-panel li{color:#415348;font-size:17px}
.content-panel ul{padding-left:20px}
.side-panel{display:flex;flex-direction:column;gap:20px;position:sticky;top:94px}
.side-box{padding:20px}
.side-box h3{margin:0 0 12px;font-size:22px;color:var(--brand)}
.side-box p{margin:0 0 14px;color:#425449}
.side-box .btn{width:100%}
.side-box img{width:100%;height:300px;object-fit:cover;border-radius:18px}
.site-footer{background:#10261b;color:#fff;padding:38px 0;margin-top:26px}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:end}
.site-footer p{margin:0;color:rgba(255,255,255,.82)}
.site-footer strong,.site-footer a{color:#fff}
.small{font-size:14px}
@media (max-width:1080px){
  .hero-grid,.page-shell,.grid-4,.grid-3{grid-template-columns:1fr 1fr}
  .glass-badge{position:static;margin-top:16px}
  .hero-stack img{height:420px}
}
@media (max-width:760px){
  .header-inner,.footer-grid,.hero-grid,.page-shell,.grid-4,.grid-3{grid-template-columns:1fr;display:grid}
  .main-nav{justify-content:flex-start}
  .hero{padding-top:46px}
  .hero-stack{grid-template-columns:1fr}
  .hero-stack img,.hero-stack .side-stack img{height:240px}
  .section,.content-panel{padding:24px}
  .page-title,.hero h1{font-size:42px}
  .hero .lead{font-size:18px}
  .glass-badge{grid-template-columns:1fr}
  .side-panel{position:static}
}
