/* ============================================================
   Garden Plaza — site-wide stylesheet (Phase 3)
   Tokens + header/footer chrome are the single source carried
   from docs/assets/docs.css. Below the chrome is a generic
   landing-page component layer shared by all converted pages.
   ============================================================ */
:root{ --bg:#0b0f0d; --panel:#121815; --ink:#f3f6f4; --muted:#9fb0a8; --line:#1f2a25; --green:#33c98c; }
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.6;font-size:16px;
  font-family:"Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif}
img{max-width:100%;display:block} a{color:inherit;text-decoration:none}
.container{max-width:1280px;margin:0 auto;padding:0 26px}
:focus-visible{outline:3px solid var(--green);outline-offset:2px;border-radius:4px}
.skip{position:absolute;left:-9999px;top:0;z-index:50;background:var(--green);color:#05130d;
  padding:10px 16px;font-weight:700;border-radius:0 0 8px 0}
.skip:focus{left:0}
header{position:sticky;top:0;z-index:20;background:rgba(11,15,13,.72);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:100px}
.brand img{width:150px;height:auto;display:block}
.menu{display:flex;gap:30px;list-style:none;margin:0;padding:0;font-size:14px;font-weight:600}
.menu a{color:var(--muted);padding:6px 0;display:inline-block} .menu a:hover,.menu a.active{color:var(--green)}
.navtoggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;
  background:none;border:0;cursor:pointer}
.navtoggle span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .2s,opacity .2s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-backdrop{display:none}
footer{border-top:1px solid var(--line);margin-top:40px}
.foot{display:flex;justify-content:center;text-align:center;align-items:center;flex-wrap:wrap;gap:14px;padding:28px 0;color:var(--muted);font-size:14px}
@media(max-width:820px){
  .navtoggle{display:flex;margin-left:auto}
  .nav{height:64px}
  .brand img{width:70px}
  .menu{position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;background:var(--panel);
    border-bottom:1px solid var(--line);padding:8px 26px 18px;display:none}
  .menu.open{display:flex}
  .menu a{padding:14px 0;font-size:16px;border-bottom:1px solid var(--line)}
  .foot{justify-content:center;text-align:center}
  /* modal-style dim+blur behind the open menu (page content dimmed; header + menu stay clear) */
  .nav-backdrop{display:block;position:fixed;inset:0;z-index:15;background:rgba(8,12,10,.5);
    -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;visibility:hidden;
    transition:opacity .25s ease,visibility .25s ease;pointer-events:none}
  .nav-backdrop.open{opacity:1;visibility:visible;pointer-events:auto}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* ============================================================
   Shared landing-page components
   ============================================================ */
.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}
main{display:block}

/* Page hero / banner (carried from docs) */
.banner{position:relative;padding:54px 0 34px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#0e1512,transparent);text-align:center}
.pill{display:inline-block;background:rgba(51,201,140,.16);color:var(--green);border:1px solid rgba(51,201,140,.4);font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin-bottom:14px}
h1.title{font-size:clamp(28px,5vw,46px);margin:0 0 8px;font-weight:800;letter-spacing:-.02em}
.banner .meta{color:#cfe0d8;font-size:16px;max-width:72ch;margin:0 auto}

/* Sections */
.section{padding:46px 0}
.section + .section{border-top:1px solid var(--line)}
.sec-title{font-size:clamp(22px,3.4vw,32px);font-weight:800;letter-spacing:-.01em;margin:0 0 12px;text-align:center}
.sec-head{font-size:22px;margin:30px 0 14px;font-weight:800}
.lede{color:var(--muted);font-size:17px;text-align:center;max-width:72ch;margin:0 auto}
.prose{max-width:72ch;margin:0 auto;color:#d7e4dd}
.prose a{color:var(--green)} .prose a:hover{text-decoration:underline}
.prose p{margin:10px 0}
.prose h2{font-size:22px;margin:30px 0 10px;color:var(--ink);font-weight:800}
.prose h3{font-size:18px;margin:22px 0 8px;color:var(--green);font-weight:700}
/* Legal pages: main section numbers (1., 2., 3.) in bright glowing blue, kin to the green sub-numbers */
.tabpanel.prose h2{color:#38cdf0;text-shadow:0 0 10px rgba(56,205,240,.5),0 0 2px rgba(56,205,240,.35)}
.prose h4{font-size:16px;margin:16px 0 6px;color:#cfe0d8;font-weight:700}
.prose ul{padding-left:22px;margin:10px 0}
.prose li{margin:6px 0}
.prose strong,.prose b{color:var(--ink);font-weight:700}
.center{text-align:center}
.narrow{max-width:720px;margin-left:auto;margin-right:auto}
.note{color:var(--muted);font-style:italic}
.muted{color:var(--muted)}

/* White plate behind transparent (dark-ink) logos so they stay readable on the dark theme */
.logo-plate{background:#fff;padding:12px 18px;border-radius:12px;display:inline-block}

/* Figures */
.figure{margin:24px auto;max-width:920px}

/* Responsive 16:9 video embed */
.video{position:relative;padding-top:56.25%;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#000;max-width:760px;margin:18px auto 0}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* App-store / badge link row */
.badges{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;align-items:center;margin:18px 0}
.badges img{height:50px;width:auto;border-radius:8px}
.figure img{border-radius:14px;border:1px solid var(--line);width:100%;height:auto}

/* Buttons */
.actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:24px 0}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;padding:11px 22px;
  border-radius:12px;font-weight:800;font-size:15px;border:1px solid transparent;cursor:pointer;
  transition:background .15s,border-color .15s,color .15s}
.btn-green{background:var(--green);color:#05130d}
.btn-green:hover{background:#46e2a1}
.btn-ghost{background:var(--panel);color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-sm{padding:8px 14px;min-height:38px;font-size:13px;border-radius:10px}

/* CTA (carried from docs) */
.linkouts{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 4px}
.cta{display:inline-flex;gap:10px;background:var(--green);color:#05130d;font-weight:800;padding:12px 22px;border-radius:12px;min-height:44px;align-items:center}
.cta.ghost{background:var(--panel);color:var(--ink);border:1px solid var(--line)}
.cta.ghost:hover{border-color:var(--green);color:var(--green)}

/* Tabs (legal page, and any tabbed content) */
.tabbar{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;border-bottom:1px solid var(--line);margin:8px 0 0}
.tab{appearance:none;border:0;background:none;color:var(--muted);font-weight:700;font-size:15px;padding:12px 18px;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-1px;min-height:44px;display:inline-flex;align-items:center;gap:8px}
.tab:hover{color:var(--ink)}
.tab[aria-selected="true"]{color:var(--green);border-bottom-color:var(--green)}
.tabpanel{margin-top:18px}
.tabpanel[hidden]{display:none}

/* Tables */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:14px;background:var(--panel)}
.gp-table{width:100%;border-collapse:collapse;font-size:15px;min-width:360px}
.gp-table thead th{background:#0e1512;color:var(--green);text-align:left;font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:13px 16px;border-bottom:1px solid var(--line)}
.gp-table td{padding:13px 16px;border-bottom:1px solid var(--line);color:var(--ink)}
.gp-table tbody tr:last-child td{border-bottom:0}
.gp-table tbody tr:hover td{background:rgba(51,201,140,.05)}
.gp-table .num{text-align:center;color:var(--muted);width:54px}

/* Info list (definition-style groups) */
.infolist{list-style:none;margin:18px 0 0;padding:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
.infolist li{padding:12px 16px;border-bottom:1px solid var(--line);font-size:14px;color:var(--ink)}
.infolist li:last-child{border-bottom:0}
.infolist li.head{background:#0e1512;color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:13px}
.infolist b{color:var(--muted);font-weight:700}
.infolist a{color:var(--green)}

/* Link list (sitemap) — entire row is clickable */
.linklist{list-style:none;margin:18px 0 0;padding:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
.linklist li{border-bottom:1px solid var(--line)}
.linklist li:last-child{border-bottom:0}
.linklist a{display:block;padding:13px 16px;color:var(--ink);font-weight:600}
.linklist a:hover{background:rgba(51,201,140,.06);color:var(--green)}
.linklist .u{display:block;color:var(--muted);font-size:12px;font-weight:400;margin-top:2px;overflow-wrap:anywhere}

/* Cards grid */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin:22px 0 0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px}
.card:hover{border-color:var(--green)}
.card h3{margin:0 0 8px;font-size:17px}
.card p{margin:0;color:var(--muted);font-size:15px}

.tag{background:rgba(51,201,140,.14);color:var(--green);border:1px solid rgba(51,201,140,.4);font-size:11px;font-weight:700;letter-spacing:.05em;padding:2px 8px;border-radius:999px}
.hr{border:0;border-top:1px solid var(--line);margin:36px 0}

/* Inline icon-link rows (e.g. service-provider contact icons) */
.iconlinks{display:inline-flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:7px;font-size:17px}
.iconlinks a{color:var(--green);line-height:1}
.iconlinks a:hover{color:#46e2a1}

/* Provider / directory card grid — 3 per row, centred frame */
.providers{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;max-width:1000px;margin:22px auto 0}
@media(max-width:900px){.providers{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:600px){.providers{grid-template-columns:1fr}}
.provider{display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:20px;transition:border-color .15s,transform .15s,box-shadow .15s}
.provider:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 8px 26px rgba(0,0,0,.35)}
.provider .tag{align-self:flex-start;text-transform:uppercase}
.provider h3{margin:0;font-size:16.5px;line-height:1.35;font-weight:700}
.provider .iconlinks{margin-top:auto;padding-top:4px;border-top:1px solid var(--line);width:100%}
.provider .for-rent{color:#e9837b;font-weight:700;font-size:13px}

/* Homepage body */
.home-intro{padding-top:14px}
.home-intro h1{margin-top:0;margin-bottom:0}
.home-intro .lead{color:var(--muted);margin-top:-6px}
/* Resident-portal: payment icons + CSS Web / CSS Home blocks */
.pay-icons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:14px}
.pay-icons img{border-radius:6px;display:block}
.portal-apps{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:30px;align-items:start}
.portal-app .logo-plate{margin:8px 0}
.portal-app .home-apps{margin-top:10px}
@media (max-width:760px){.portal-apps{grid-template-columns:1fr}}
/* Homepage section rhythm + alternating background bands (segmentation, no <hr>) */
.home-sec{padding-top:48px;padding-bottom:48px}
.home-band{padding:48px 0;background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
/* Homepage: centered layout to match the other revamped pages */
.page-home main>section{text-align:center}
.page-home .home-apps,.page-home .stat-actions{justify-content:center}
.page-home .lede,.page-home .home-intro p{max-width:72ch;margin-left:auto;margin-right:auto}
.home-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.home-photos img{width:100%;height:200px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.home-apps{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:16px}
.explore-cards{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin:8px auto 0}
.explore-card{flex:0 0 168px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 14px;min-height:120px;background:var(--panel);border:1px solid var(--line);border-radius:14px;color:var(--ink);transition:border-color .15s,transform .15s}
.explore-card i{font-size:26px;color:var(--green)}
.explore-card:hover{border-color:var(--green);transform:translateY(-2px)}
.stat-band{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:46px 0}
.stat-tile{display:flex;flex-direction:column;align-items:center;gap:6px}
.stat-tile>i{font-size:38px;color:var(--green);margin-bottom:6px}
.stat-num{font-size:clamp(36px,5vw,54px);font-weight:800;line-height:1;color:var(--ink);letter-spacing:-.02em}
.stat-tile h3{margin:6px 0 0;font-size:18px;font-weight:700}
.stat-tile .btn-sm{margin-top:12px}
.stat-tile .btn{border-color:rgba(51,201,140,.35)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:24px}
.contact-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px 26px;text-align:left}
.contact-card h3{margin:0 0 18px;font-size:18px;display:flex;align-items:center;gap:10px}
.contact-card h3 i{color:var(--green)}
.cinfo{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.cinfo li{display:flex;gap:13px;align-items:flex-start;line-height:1.5}
.cinfo .ci-ico{flex:0 0 22px;color:var(--green);font-size:15px;margin-top:3px;text-align:center}
.cinfo a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
.cinfo a:hover{color:var(--green);border-color:var(--green)}
.home-map{margin-top:24px;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
/* Navigate-to links under the map */
.map-nav{margin-top:20px}
.map-nav__label{font-weight:700;margin:0 0 12px}
.map-nav__links{display:flex;gap:16px;justify-content:center;align-items:center;flex-wrap:wrap}
.map-nav__links img{border-radius:14px;transition:transform .15s}
.map-nav__links a:hover img{transform:translateY(-3px)}
/* Site-wide contact modal */
.cm-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-start;justify-content:center;padding:5vh 18px;background:rgba(4,8,6,.72);backdrop-filter:blur(3px);overflow:auto}
.cm-modal[hidden]{display:none}
.cm-box{position:relative;width:100%;max-width:920px;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:30px 28px 34px;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.cm-title{margin:0 0 20px;text-align:center}
.cm-close{position:absolute;top:14px;right:16px;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;background:var(--panel);color:var(--ink);font-size:24px;line-height:1;cursor:pointer}
.cm-close:hover{border-color:var(--green);color:var(--green)}
.home-map iframe{display:block;filter:grayscale(1) contrast(.9) brightness(.95);transition:filter .3s}
.home-map:hover iframe{filter:none}
.home-credit{margin-top:20px;font-size:13px}
@media (max-width:760px){.home-photos{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr;gap:34px}}
