/*
Theme Name: Above 55 Theme
Theme URI: https://above55.example
Author: Above 55
Author URI: https://above55.example
Description: A classic PHP theme for Above 55 — a 55+ community directory + downsizing lead-gen site. Built for seniors: large type, high contrast, 44px+ hit targets. Designed to pair with JetEngine for CPTs (Community, Guide, Product) and a custom AJAX search & filter UI.
Version: 1.0.0
Requires at least: 6.2
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: above55
Tags: real-estate, directory, senior, custom-post-types, jetengine
*/

/* ---------- Design tokens ---------- */
:root{
  --green:#1E3F26;
  --green-deep:#15301C;
  --green-soft:#2C5535;
  --cream:#F5EFE4;
  --sand:#E8DFCC;
  --sand-deep:#D9CCB0;
  --terra:#C06B4A;
  --terra-deep:#A85638;
  --ink:#1B1A17;
  --ink-2:#3A3833;
  --ink-3:#6B6860;
  --line:#DCD3BF;
  --bg:#FBF8F1;
  --white:#ffffff;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(30,63,38,.08),0 2px 8px rgba(30,63,38,.04);
  --shadow-md:0 4px 14px rgba(30,63,38,.10),0 2px 6px rgba(30,63,38,.06);
  --fs-base:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{font-size:var(--fs-base)}
body{
  font-family:'Source Serif 4','Iowan Old Style','Georgia',serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"liga","kern";
}
h1,h2,h3,h4,.display,.ui{font-family:'Hammersmith One','Trebuchet MS',sans-serif;font-weight:400;letter-spacing:.005em}
h1{font-size:clamp(2.4rem,5.2vw,4.2rem);line-height:1.02;margin:0}
h2{font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.1;margin:0 0 .5rem}
h3{font-size:1.25rem;line-height:1.2;margin:0 0 .35rem}
p{margin:0 0 1rem}
a{color:var(--green);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--terra-deep)}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block;height:auto}
input,select,button,textarea{font-size:1rem;font-family:inherit}
:focus-visible{outline:3px solid var(--terra);outline-offset:2px;border-radius:6px}

.wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.ui{font-family:'Inter',system-ui,sans-serif;font-weight:500;letter-spacing:.01em}
.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}

/* Utility bar */
.utility{background:var(--green-deep);color:#E8DFCC;font-family:'Inter',system-ui,sans-serif;font-size:.85rem}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;padding-top:10px;padding-bottom:10px;gap:16px;flex-wrap:wrap}
.utility a{color:#E8DFCC;text-decoration:none}
.utility a:hover{color:#fff}
.utility .left,.utility .right{display:flex;gap:18px;align-items:center}
.u-dot{width:6px;height:6px;border-radius:50%;background:#8CB295;display:inline-block;margin-right:6px;vertical-align:middle}

/* Header */
header.site{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;backdrop-filter:saturate(1.1)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:24px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo img{height:24px;width:auto}
nav.primary{display:flex;gap:6px;align-items:center}
nav.primary a, nav.primary .menu-item > a{
  font-family:'Hammersmith One',sans-serif;
  text-decoration:none;color:var(--ink);
  padding:12px 16px;border-radius:10px;font-size:1.05rem;letter-spacing:.01em;
}
nav.primary a:hover, nav.primary .current-menu-item > a{background:var(--sand);color:var(--green)}
nav.primary ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.header-cta{display:flex;gap:10px;align-items:center}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;border-radius:12px;border:2px solid transparent;
  font-family:'Hammersmith One',sans-serif;font-size:1.05rem;letter-spacing:.02em;
  text-decoration:none;min-height:48px;transition:transform .05s ease,background .15s,border-color .15s,color .15s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-primary:hover{background:var(--green-deep);border-color:var(--green-deep);color:#fff}
.btn-terra{background:var(--terra);color:#fff;border-color:var(--terra)}
.btn-terra:hover{background:var(--terra-deep);border-color:var(--terra-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-cream{background:var(--cream);color:var(--green);border-color:var(--sand-deep)}
.btn-cream:hover{background:#fff;color:var(--green-deep)}
.btn-lg{padding:18px 28px;font-size:1.15rem;min-height:56px}
.btn-sm{padding:10px 14px;font-size:.95rem;min-height:40px;border-radius:10px}

.burger{display:none;background:transparent;border:2px solid var(--green);border-radius:10px;padding:10px 12px;color:var(--green);font-family:'Hammersmith One',sans-serif}

/* Hero */
.hero{position:relative;background:var(--green);color:#fff;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1100px 500px at 85% -10%, rgba(192,107,74,.22), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(245,239,228,.12), transparent 60%);
  pointer-events:none;
}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;padding-top:72px;padding-bottom:84px;align-items:center}
.hero h1 .accent{color:#F2C9B3;display:block}
.hero .kicker{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(245,239,228,.12);border:1px solid rgba(245,239,228,.25);
  color:#F5EFE4;padding:8px 14px;border-radius:999px;
  font-family:'Inter',sans-serif;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:24px;
}
.hero p.lede{font-size:1.25rem;max-width:52ch;color:#EFE6D4;margin-top:22px}
.hero .stats{display:flex;gap:36px;margin-top:30px;flex-wrap:wrap}
.hero .stat .n{font-family:'Hammersmith One',sans-serif;font-size:2.1rem;line-height:1;color:#F2C9B3}
.hero .stat .l{font-family:'Inter',sans-serif;font-size:.9rem;color:#D9CCB0;letter-spacing:.04em}

.search-card{
  background:var(--cream);color:var(--ink);
  border-radius:var(--radius-lg);padding:22px;
  box-shadow:0 30px 60px rgba(0,0,0,.25),0 8px 20px rgba(0,0,0,.15);
  border:1px solid var(--sand-deep);
}
.search-card h3{font-size:1.35rem;color:var(--green);margin-bottom:14px}
.search-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:'Inter',sans-serif;font-size:.85rem;color:var(--ink-2);font-weight:600;letter-spacing:.02em}
.field input, .field select{
  background:#fff;border:2px solid var(--sand-deep);border-radius:10px;
  padding:14px 14px;font-size:1.05rem;color:var(--ink);min-height:50px;
  font-family:'Inter',sans-serif;
}
.field input:focus, .field select:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px rgba(30,63,38,.15)}
.search-card .go{margin-top:14px;width:100%}
.search-card .hint{font-size:.9rem;color:var(--ink-3);margin-top:10px;font-family:'Inter',sans-serif}

/* Trust bar */
.trust{background:var(--cream);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;justify-content:space-between;align-items:center;gap:40px;padding:22px 24px;flex-wrap:wrap}
.trust .item{display:flex;gap:12px;align-items:center;color:var(--ink-2);font-family:'Inter',sans-serif;font-size:.95rem;font-weight:500}
.trust .icon{width:36px;height:36px;border-radius:10px;background:#fff;border:1px solid var(--sand-deep);display:grid;place-items:center;color:var(--green)}

/* Section scaffolding */
section.block{padding:88px 0}
.eyebrow{font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:var(--green);font-weight:700}
.sec-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:36px;gap:24px;flex-wrap:wrap}
.sec-head p{max-width:60ch;color:var(--ink-2);margin:10px 0 0}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;
  background:#fff;border:2px solid var(--line);color:var(--ink-2);
  font-family:'Inter',sans-serif;font-weight:500;font-size:.95rem;cursor:pointer;
  min-height:44px;text-decoration:none;
}
.chip:hover{border-color:var(--green);color:var(--green)}
.chip.on{background:var(--green);color:#fff;border-color:var(--green)}

/* Community grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--sand-deep)}
.ph{
  aspect-ratio:4/3;background:
    repeating-linear-gradient(135deg,var(--sand) 0 14px,var(--sand-deep) 14px 28px);
  position:relative;color:var(--green-deep);
  display:flex;align-items:flex-end;padding:14px;overflow:hidden;
}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ph .tag{
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;font-size:.72rem;
  background:rgba(255,255,255,.9);color:var(--green-deep);padding:6px 10px;border-radius:6px;
  border:1px solid var(--sand-deep);position:relative;z-index:1;
}
.ph .badge{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--green);color:#fff;padding:6px 12px;border-radius:999px;
  font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.04em;
}
.ph .save{
  position:absolute;top:12px;right:12px;z-index:2;width:40px;height:40px;border-radius:50%;
  background:#fff;border:none;display:grid;place-items:center;color:var(--green);box-shadow:var(--shadow-sm);
  cursor:pointer;font-size:1.1rem;
}
.card-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-body h3{font-size:1.3rem;color:var(--green-deep)}
.card-body h3 a{color:inherit;text-decoration:none}
.card-body h3 a:hover{color:var(--terra-deep)}
.meta{display:flex;gap:14px;color:var(--ink-3);font-family:'Inter',sans-serif;font-size:.9rem;flex-wrap:wrap}
.meta span{display:inline-flex;align-items:center;gap:6px}
.amenities{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.amenities .a{font-family:'Inter',sans-serif;font-size:.8rem;background:var(--cream);color:var(--green);padding:4px 10px;border-radius:999px;border:1px solid var(--sand-deep)}
.card-foot{border-top:1px solid var(--line);padding:14px 22px;display:flex;justify-content:space-between;align-items:center;background:#FBF8F1}
.price{font-family:'Hammersmith One',sans-serif;color:var(--green-deep);font-size:1.15rem}
.price small{font-family:'Inter',sans-serif;font-size:.8rem;color:var(--ink-3);font-weight:400;letter-spacing:.02em;margin-left:4px}
.load-more{display:flex;justify-content:center;margin-top:36px}

/* Downsize split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--sand-deep);background:var(--cream)}
.split .left{padding:56px;background:var(--green);color:#fff}
.split .left h2{color:#fff}
.split .left .eyebrow{color:#F2C9B3}
.split .left ul{list-style:none;padding:0;margin:22px 0 30px;display:flex;flex-direction:column;gap:16px}
.split .left li{display:flex;gap:12px;align-items:flex-start;color:#EFE6D4;font-size:1.05rem;line-height:1.5}
.split .left li > span:last-child{flex:1;min-width:0}
.check{flex:0 0 26px;height:26px;border-radius:50%;background:#F2C9B3;color:var(--green-deep);display:grid;place-items:center;margin-top:2px}
.split form{padding:56px;display:flex;flex-direction:column;gap:14px}
.split form h3{font-size:1.5rem;color:var(--green-deep)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.consent{font-family:'Inter',sans-serif;font-size:.82rem;color:var(--ink-3);display:flex;gap:10px;align-items:flex-start;line-height:1.45}
.consent input{margin-top:4px}

/* Guides */
.guides{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.guide{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s;text-decoration:none;color:inherit}
.guide:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.guide .ph{aspect-ratio:16/10}
.guide-body{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1}
.cat{font-family:'Inter',sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--terra-deep);font-weight:700}
.guide h3{font-size:1.1rem;color:var(--green-deep);line-height:1.3}
.guide .read{font-family:'Inter',sans-serif;font-size:.85rem;color:var(--ink-3);margin-top:auto;padding-top:8px}

/* Affiliate products */
.aff{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prods{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prod{background:#fff;border-radius:var(--radius);border:1px solid var(--sand-deep);padding:18px;display:flex;flex-direction:column;gap:10px}
.prod .ph{aspect-ratio:1/1;border-radius:10px}
.prod h4{font-family:'Hammersmith One',sans-serif;font-size:1.05rem;margin:4px 0 0;color:var(--green-deep);font-weight:400}
.stars{color:#C98A3B;font-size:.95rem;letter-spacing:2px}
.prod .p{font-family:'Hammersmith One',sans-serif;color:var(--ink);font-size:1.2rem}
.prod .disc{font-family:'Inter',sans-serif;font-size:.72rem;color:var(--ink-3)}

/* Testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;display:flex;flex-direction:column;gap:14px}
.quote .mark{font-family:'Hammersmith One',sans-serif;color:var(--terra);font-size:3rem;line-height:.5;height:18px}
.quote p{font-size:1.05rem;color:var(--ink-2);font-style:italic}
.quote .who{display:flex;gap:12px;align-items:center;margin-top:auto}
.avatar{width:48px;height:48px;border-radius:50%;background:var(--sand);border:1px solid var(--sand-deep);display:grid;place-items:center;font-family:'Hammersmith One',sans-serif;color:var(--green);font-size:1.1rem}
.who .name{font-family:'Hammersmith One',sans-serif;color:var(--green-deep)}
.who .where{font-family:'Inter',sans-serif;font-size:.85rem;color:var(--ink-3)}

/* Footer */
footer.site{background:var(--green-deep);color:#D9CCB0;padding:64px 0 32px;font-family:'Inter',sans-serif}
footer.site a{color:#D9CCB0;text-decoration:none}
footer.site a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:36px}
footer h4{font-family:'Hammersmith One',sans-serif;color:#fff;font-size:1.05rem;margin:0 0 14px;font-weight:400;letter-spacing:.04em}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
footer .logo img{height:40px}
.foot-desc{margin:18px 0;font-size:.95rem;line-height:1.6;color:#B8AE93;max-width:34ch}
.foot-legal{border-top:1px solid rgba(245,239,228,.12);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.85rem;color:#8E8670}
.foot-legal a{color:#8E8670}

/* Sticky mobile CTA */
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;background:#fff;border-top:1px solid var(--line);padding:10px 12px;box-shadow:0 -6px 20px rgba(0,0,0,.08);gap:8px}
.mcta a{flex:1;text-align:center}

/* Archive layout (search results) */
.arc-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start}
.sidebar{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;position:sticky;top:92px}
.sidebar h4{font-family:'Hammersmith One',sans-serif;font-size:1.05rem;margin:0 0 10px;color:var(--green-deep);font-weight:400}
.sidebar .facet{padding:14px 0;border-top:1px solid var(--line)}
.sidebar .facet:first-of-type{border-top:none;padding-top:0}
.sidebar .facet label{display:flex;gap:10px;align-items:center;padding:6px 0;color:var(--ink-2);font-family:'Inter',sans-serif;font-size:.95rem;cursor:pointer}
.sidebar .facet label input{width:18px;height:18px}
.results-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.results-head .count{font-family:'Inter',sans-serif;color:var(--ink-3)}
.results-head select{padding:10px 12px;border-radius:10px;border:1px solid var(--sand-deep);background:#fff;font-family:'Inter',sans-serif;min-height:44px}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:36px}
.pagination a,.pagination span{padding:10px 14px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink-2);text-decoration:none;font-family:'Inter',sans-serif;min-width:44px;text-align:center}
.pagination .current{background:var(--green);color:#fff;border-color:var(--green)}

/* Single community */
.single-hero{background:var(--green);color:#fff;padding:40px 0}
.single-hero .crumbs{font-family:'Inter',sans-serif;font-size:.85rem;color:#B8AE93;margin-bottom:10px}
.single-hero .crumbs a{color:#D9CCB0}
.single-hero h1{font-size:clamp(2rem,4vw,3rem)}
.single-hero .loc{color:#EFE6D4;font-size:1.1rem;margin-top:6px}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px;margin-top:0}
.gallery .ph{aspect-ratio:auto;min-height:200px}
.gallery .ph:first-child{grid-row:span 2;min-height:416px}
.detail-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;padding:48px 0}
.detail-main .stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;background:var(--cream);border:1px solid var(--sand-deep);border-radius:var(--radius-lg);padding:22px;margin-bottom:32px}
.detail-main .stat-row .s .n{font-family:'Hammersmith One',sans-serif;color:var(--green-deep);font-size:1.4rem}
.detail-main .stat-row .s .l{font-family:'Inter',sans-serif;font-size:.8rem;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}
.detail-aside{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;position:sticky;top:92px}
.detail-aside h3{font-size:1.2rem;color:var(--green-deep)}

/* Responsive */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:32px;padding-top:48px;padding-bottom:56px}
  nav.primary{display:none}
  .burger{display:inline-flex}
  .grid,.guides,.prods,.quotes{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .split .left,.split form{padding:36px 28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  section.block{padding:64px 0}
  .mcta{display:flex}
  body{padding-bottom:72px}
  .header-cta .btn:not(.burger){display:none}
  .arc-layout,.detail-layout{grid-template-columns:1fr}
  .sidebar,.detail-aside{position:static}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery .ph:first-child{grid-row:auto;grid-column:span 2;min-height:240px}
  .detail-main .stat-row{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .grid,.guides,.prods,.quotes{grid-template-columns:1fr}
  .search-grid,.two{grid-template-columns:1fr}
  h1{font-size:2.2rem}
  .hero .stats{gap:20px}
}

/* WP core classes */
.alignwide{max-width:1100px;margin-left:auto;margin-right:auto}
.alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.wp-caption{max-width:100%}
.screen-reader-text{position:absolute !important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
