﻿/* Base public-site layout stylesheet restored from d18fe06. Theme overrides live in index.html. */

:root{
--c50:#F0EBE3;--c100:#F5D9A8;--c200:#E4A84B;--c400:#C17E2F;--c500:#B06D2A;--c600:#9A6322;--c700:#7A4E1A;--c800:#5C3A12;
--p50:#EEF3F0;--p100:#D0DED6;--p200:#A3BDB0;--p300:#78A68B;--p400:#4E8A6A;--p600:#1B5E3B;--p700:#14472A;--p800:#0D3520;
--s50:#F7F5F0;--s100:#E8E5DF;--s200:#C5C1B8;--s300:#A19D95;--s400:#6E6A64;--s500:#5C5850;--s600:#45423C;--s700:#33312C;--s800:#232220;
--ch:#09090A;--r:#B93A2E;--info:#2874A6;
--ok:#1f8f5f;--warn:#c98918;--risk:#B93A2E;
--sp-xs:4px;--sp-sm:8px;--sp-md:14px;--sp-lg:24px;--sp-xl:32px;--sp-2xl:48px;
--emergency-bg:#FCECEC;--emergency-border:#F5C1C1;--emergency-text:#7A2020;
--shadow-1:0 2px 8px rgba(9,9,10,.06);--shadow-2:0 8px 24px rgba(9,9,10,.08);--shadow-3:0 16px 40px rgba(9,9,10,.12);
--mx:clamp(24px,12.5vw,200px);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Lato',sans-serif;color:var(--ch);background:var(--s50);font-size:clamp(20px,2.2vw + 12px,26px)}
a{text-decoration:none;color:inherit;cursor:pointer}
.site{width:100%;max-width:none;margin:0 auto;background:#fff;box-shadow:none}

.alert{display:flex;align-items:center;gap:10px;padding:10px 24px;background:var(--c50);border-bottom:1px solid var(--c100);font-size:15px;color:var(--c800)}
.alert .dot{width:8px;height:8px;border-radius:50%;background:var(--c500);flex-shrink:0}
.alert a{color:var(--c500);font-weight:700}
.alert .x{cursor:pointer;font-size:20px;color:var(--c400);margin-left:auto}

.top{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid var(--s100)}
.top-left{display:flex;align-items:center;gap:12px}
.logo-mark{width:76px;height:auto}
.logo-text{font-size:17px;font-weight:900;letter-spacing:.07em;line-height:1.2;color:var(--ch);transition:color .15s;text-transform:uppercase}
.logo-sub{font-size:17px;font-weight:700;color:var(--s400);letter-spacing:.07em;line-height:1.2;transition:color .15s;text-transform:uppercase}
.logo-wordmark{height:44px;width:auto;display:block}
@media (max-width:768px){.logo-wordmark{height:32px}}
.top-right{display:flex;align-items:center;gap:16px}
.top-phone{font-size:14px;color:var(--s500);font-weight:600}
.social-icons{display:flex;gap:6px}
.soc{width:30px;height:30px;border-radius:50%;background:var(--s50);border:1px solid var(--s100);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--s400);transition:.15s}
.soc:hover{background:var(--p100);color:var(--p700);border-color:var(--p200)}
.login-btn{padding:8px 20px;border-radius:6px;background:var(--c500);color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;border:none;cursor:pointer;transition:.15s}
.login-btn:hover{background:var(--c600)}
.login-icon{display:none}
.mob-search-btn{display:none;width:44px;height:44px;border-radius:6px;background:var(--p600);border:none;cursor:pointer;align-items:center;justify-content:center;color:#fff;font-size:16px;transition:.15s}
.mob-search-btn:hover{background:var(--p700)}
.mob-search-btn.search-active{background:var(--p700)}
.hamburger{display:none;width:44px;height:44px;border-radius:6px;background:var(--p600);border:none;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger span{display:block;width:18px;height:2px;background:#fff;border-radius:1px;transition:.2s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(3px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(3px,-5px)}

nav.main{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;background:var(--p600);position:sticky;top:0;z-index:100}
nav.main>.nav-inner{justify-content:center}
nav.main .nav-links{display:flex;align-items:center}
nav.main .nav-item{position:relative}
nav.main .nav-link{display:block;padding:15px 22px;font-size:13px;font-weight:700;letter-spacing:.06em;color:rgba(255,255,255,.90);border-bottom:3px solid transparent;transition:.15s;cursor:pointer}
nav.main .nav-link:hover,nav.main .nav-link.active{color:#fff;background:rgba(255,255,255,.06)}
nav.main .nav-link.active{border-bottom-color:var(--c400)}
nav.main .nav-link i{font-size:9px;margin-left:4px;opacity:.5}
.dropdown{display:block;visibility:hidden;opacity:0;pointer-events:none;position:absolute;top:100%;left:0;min-width:240px;background:#fff;border:1px solid var(--s100);border-radius:0 0 8px 8px;box-shadow:0 12px 32px rgba(0,0,0,.12);padding:6px 0;z-index:200;transition:opacity .15s ease,visibility 0s linear .2s;max-height:calc(100vh - 130px);overflow-y:auto;overscroll-behavior:contain}
.nav-item:hover .dropdown{visibility:visible;opacity:1;pointer-events:auto;transition:opacity .15s ease,visibility 0s}
.dropdown a{display:block;padding:10px 20px;font-size:14px;color:var(--s600);font-weight:500;transition:.15s}
.dropdown a:hover{background:var(--p100);color:var(--p700)}
.dropdown .dd-head{font-weight:700;color:var(--s700);padding-top:12px;padding-bottom:4px}
.dropdown .dd-head:hover{background:var(--p100);color:var(--p700)}
.dropdown .dd-sub{padding-left:32px;font-size:13px;padding-top:7px;padding-bottom:7px;color:var(--s500)}
.nav-search{padding:10px 20px}
.nav-link-staff{color:var(--c200)!important;border-bottom-color:transparent!important}
.nav-link-staff:hover{color:#fff!important;background:rgba(193,126,47,.15)!important}
.nav-inner{display:flex;align-items:center;width:100%;padding:0 var(--mx)}
.nav-search-box{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.5);font-size:13px;cursor:pointer;transition:.15s}
.nav-search-box:hover{background:rgba(255,255,255,.16)}

.mobile-menu{display:none;background:#fff;border-bottom:1px solid var(--s100);max-height:0;overflow:hidden;transition:max-height .35s ease}
.mobile-menu.open{max-height:2000px}
.mobile-menu .mm-search{padding:10px 16px;background:var(--s50);border-bottom:1px solid var(--s100);display:flex;align-items:center;gap:8px;font-size:14px;color:var(--s500)}
.mobile-menu .mm-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--s100);font-size:15px;font-weight:700;letter-spacing:.04em;cursor:pointer}
.mobile-menu .mm-item.active{color:var(--p600)}
.mobile-menu .mm-item i.fa-chevron-down{font-size:14px;color:var(--p600);transition:transform .25s ease;flex-shrink:0}
.mobile-menu .mm-sub{background:var(--s50);max-height:0;overflow:hidden;transition:max-height .3s ease}
.mobile-menu .mm-sub.open{max-height:700px}
.mobile-menu .mm-sub a{display:block;padding:11px 16px 11px 32px;font-size:14px;color:var(--s500);font-weight:500;border-bottom:1px solid var(--s100)}
.mobile-menu .mm-sub a:hover{color:var(--p600)}
.mm-footer{padding:12px 16px;display:flex;align-items:center;gap:8px}
.mm-footer .soc{width:32px;height:32px}

.hero{position:relative;min-height:440px;overflow:hidden;display:flex;flex-direction:column}
#hero-slides{position:absolute;inset:0;z-index:0}
#hero-slides::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(10,20,14,.65),rgba(10,20,14,.5));pointer-events:none;z-index:2}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;z-index:1}
.hero-slide.active{opacity:1}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#0a140e}
.hero-slide video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;opacity:.08;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.15),transparent 60%),radial-gradient(circle at 70% 30%,rgba(176,109,42,.2),transparent 50%);z-index:3}
.hero-fade{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,rgba(10,20,14,.6),transparent);z-index:3}
.hero-watermark{position:absolute;top:30px;right:40px;opacity:.05;z-index:4}
.hero-content{position:relative;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:40px 24px}
.hero-rule{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.hero-rule span{font-size:12px;font-weight:700;letter-spacing:.15em;color:var(--c400)}
.hero-rule .line{width:40px;height:1px;background:var(--c400);opacity:.5}
.hero h1{font-size:clamp(28px,5vw,46px);color:#fff;letter-spacing:.02em;line-height:1.08}
.hero h1 .light{font-weight:300}
.hero h1 .bold{font-weight:900}
.hero .hero-desc{font-size:18px;color:rgba(255,255,255,.55);margin-top:14px;max-width:520px;line-height:1.65}
.hero-ctas{margin-top:28px;display:flex;gap:12px}
.btn-copper{padding:13px 30px;border-radius:6px;background:var(--c500);color:#fff;font-size:14px;font-weight:700;letter-spacing:.05em;border:none;cursor:pointer;transition:.15s}
.btn-copper:hover{background:var(--c600)}
.btn-outline{padding:13px 30px;border-radius:6px;background:var(--p600);color:#fff;font-size:14px;font-weight:700;letter-spacing:.05em;border:1.5px solid var(--p600);cursor:pointer;transition:.15s}
.btn-outline:hover{background:var(--p700);border-color:var(--p700)}
.hero-tm{font-size:11px;color:rgba(255,255,255,.50);margin-top:22px;letter-spacing:.05em;font-style:italic}

.qa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));justify-content:center;border-bottom:1px solid var(--s100);padding:16px var(--mx);gap:12px;background:var(--s50)}
.qa-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 10px;cursor:pointer;transition:.2s;border-radius:16px;background:#fff;border:1px solid var(--s100);box-shadow:var(--shadow-1)}

.qa-card:hover{background:var(--p50);transform:translateY(-3px);box-shadow:var(--shadow-2)}
.qa-card:hover .qa-icon{transform:scale(1.1)}
.qa-icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;transition:.2s}
.qa-label{font-size:13px;font-weight:700;letter-spacing:.06em;color:var(--ch);text-align:center}
.qa-desc{font-size:12px;color:var(--s400);text-align:center}

.section{padding:48px 32px 40px}
.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px}
.section-header h2{font-size:33px;font-weight:900;letter-spacing:.03em;text-transform:uppercase}
.section-header .sub{font-size:17px;color:var(--s400);margin-top:4px}
.section-header .more{font-size:13px;color:var(--c500);font-weight:700;letter-spacing:.04em}
.section-header .more:hover{color:var(--c600)}

.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news-card{border-radius:10px;overflow:hidden;border:1px solid var(--s100);transition:.25s;cursor:pointer;box-shadow:var(--shadow-1)}
.news-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-3)}
.news-img{height:150px;position:relative;display:flex;align-items:flex-end;padding:14px}
.news-tag{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:4px;background:rgba(0,0,0,.45);font-size:10px;font-weight:700;color:#fff;letter-spacing:.08em}
.news-body{padding:20px}
.news-body h3{font-size:18px;font-weight:900;letter-spacing:.02em;margin-bottom:8px;line-height:1.3}
.news-body p{font-size:15px;color:var(--s400);line-height:1.6;margin-bottom:14px}
.news-body .cta{font-size:13px;color:var(--c500);font-weight:700;letter-spacing:.03em}
.news-body .cta:hover{color:var(--c600)}

.projects-banner{background:var(--c50);padding:56px var(--mx);margin:48px 0}
.csb-inner{}
.csb-section-title{text-align:center;font-size:clamp(16px,2vw,22px);font-weight:900;letter-spacing:.06em;color:var(--ch);margin:0 0 36px;text-transform:uppercase}
.csb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.csb-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.09);display:flex;flex-direction:column}
.csb-card-img{width:100%;height:200px;background-size:cover;background-position:center;background-color:var(--s100);display:block;flex-shrink:0}
.csb-card-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.csb-tag{font-size:14px;font-weight:800;letter-spacing:.08em;color:var(--c400);text-transform:uppercase;margin-bottom:10px}
.csb-timeline{font-size:clamp(18px,1.8vw,24px);font-weight:400;color:var(--ch);margin:0 0 12px;line-height:1.2}
.csb-card-desc{font-size:14px;color:var(--s500);line-height:1.65;margin-bottom:16px}
.csb-features{margin-bottom:20px}
.csb-features-head{font-size:12px;font-weight:900;letter-spacing:.08em;color:var(--s700);text-transform:uppercase;margin-bottom:8px}
.csb-feat-list{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;padding-left:18px;margin:0}
.csb-feat-list li{font-size:13px;color:var(--s500)}
.csb-card-footer{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:auto;padding-top:4px}
.csb-link{color:var(--c500);font-weight:700;font-size:14px;cursor:pointer;transition:color .15s}
.csb-link:hover{color:var(--c600)}
.csb-note{font-size:11px;color:var(--s400);font-style:italic}
@media(max-width:900px){.csb-grid{grid-template-columns:1fr}}
@media(max-width:600px){.projects-banner{padding:40px 16px}}
.proj-detail-item{padding:24px 0;border-bottom:1px solid var(--s100);overflow:hidden}
.proj-detail-item:last-child{border-bottom:none}
.proj-detail-title{font-size:16px;font-weight:800;color:var(--ch);margin-bottom:10px;letter-spacing:.01em}
.proj-detail-body p{font-size:15px;color:var(--s600);line-height:1.75;margin:0}
.proj-detail-images{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.proj-detail-img{width:100%;height:auto;border-radius:8px;display:block;cursor:pointer;transition:opacity .15s}
.proj-detail-img:hover{opacity:.88}
#img-modal{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.88);flex-direction:column}
#img-modal-bar{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--p800);flex-shrink:0}
#img-modal-title{font-size:14px;font-weight:700;color:#fff;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#img-modal-dl{color:var(--c200);font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap}
#img-modal-close{background:none;border:none;color:#fff;font-size:26px;cursor:pointer;padding:4px 8px;line-height:1;flex-shrink:0;border-radius:4px;transition:.15s}
#img-modal-close:hover{background:rgba(255,255,255,.15)}
#img-modal-body{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:hidden;cursor:pointer}
#img-modal-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;display:block}
@media(max-width:600px){.proj-detail-images{grid-template-columns:1fr}}
.split{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:0 32px 48px;align-items:stretch}
.events-panel{border:1px solid var(--s100);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
#home-evt-list{flex:1;display:flex;flex-direction:column}
.events-header{padding:16px 20px;background:var(--p600);display:flex;justify-content:space-between;align-items:center}
.events-header h3{font-size:15px;font-weight:700;color:#fff;letter-spacing:.05em}
.events-header a{font-size:11px;color:var(--c200);font-weight:700;letter-spacing:.04em}
.events-header a:hover{color:#fff}
.evt-item{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--s100);transition:.15s;cursor:pointer;flex:1}
.evt-item:last-child{border-bottom:none}
.evt-item:hover{background:var(--s50);transform:translateY(-1px);box-shadow:var(--shadow-2)}
.evt-date{width:48px;height:48px;border-radius:8px;background:var(--s50);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}
.evt-date .m{font-size:10px;font-weight:700;color:var(--s600);letter-spacing:.06em}
.evt-date .d{font-size:20px;font-weight:900;color:var(--ch);line-height:1}
.evt-date.meeting{background:var(--p50)}
.evt-date.reg{background:var(--c50)}
.evt-info{flex:1;min-width:0}
.evt-info .name{font-size:15px;font-weight:700;color:var(--ch);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.evt-info .time{font-size:13px;color:var(--s400);margin-top:2px}
.evt-arrow{font-size:18px;color:var(--s200)}

.sidebar{display:flex;flex-direction:column;gap:16px}
.sidebar .contact-card{flex:1}
.about-card{border:1px solid var(--s100);border-radius:10px;padding:16px;background:linear-gradient(135deg,var(--c50),var(--s50));box-shadow:var(--shadow-1)}
.about-card h3{font-size:15px;font-weight:900;color:var(--c700);letter-spacing:.05em;margin-bottom:10px}
.about-card p{font-size:15px;color:var(--s500);line-height:1.65;margin-bottom:14px}
.about-card a{font-size:14px;color:var(--c500);font-weight:700}
.contact-card{border:1px solid var(--s100);border-radius:10px;padding:16px}
.contact-card h3{font-size:15px;font-weight:900;color:var(--p700);letter-spacing:.05em;margin-bottom:14px}
.contact-row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}
.contact-row .label{color:var(--s400);font-weight:700;letter-spacing:.03em}
.contact-row .val{color:var(--ch);font-weight:500;text-align:right}
.emergency{margin-top:10px;padding:8px 12px;border-radius:6px;background:var(--emergency-bg);border:1px solid var(--emergency-border);display:flex;align-items:center;gap:8px}
.emergency .elabel{font-size:12px;font-weight:900;color:var(--emergency-text);letter-spacing:.03em}
.emergency .eval{font-size:14px;color:var(--emergency-text);font-weight:600}

footer{background:var(--p800);padding:22px 32px 14px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:16px}
.footer-brand-inner{display:flex;align-items:flex-start;gap:18px}
.footer-brand .logo-text-f{font-size:17px;font-weight:900;color:#fff;letter-spacing:.07em;margin-top:2px;line-height:1.2;text-transform:uppercase}
.footer-brand .logo-sub-f{font-size:17px;font-weight:700;color:rgba(255,255,255,.55);letter-spacing:.07em;line-height:1.2;margin-bottom:8px;text-transform:uppercase}
.footer-brand .addr{font-size:13px;color:rgba(255,255,255,.70);line-height:1.8}
.footer-social{display:flex;gap:8px;margin-top:14px}
.footer-social .soc{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.5)}
.footer-social .soc:hover{background:rgba(255,255,255,.16);color:#fff}
.footer-col h4{font-size:12px;font-weight:700;color:var(--c400);letter-spacing:.08em;margin-bottom:14px}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.70);padding:5px 0;transition:.15s}
.footer-col a:hover{color:#fff}
.footer-emergency{margin-top:18px;padding:12px 14px;border-radius:6px;background:rgba(193,126,47,.12);border:1px solid rgba(193,126,47,.2)}
.footer-emergency .fe-label{font-size:10px;font-weight:700;color:var(--c400);letter-spacing:.06em;margin-bottom:2px}
.footer-emergency .fe-num{font-size:15px;color:var(--c200);font-weight:700}
.skip-link{position:absolute;left:-9999px;top:0;z-index:9999;background:var(--p700);color:#fff;padding:8px 16px;font-size:15px;font-weight:700;text-decoration:none;border-radius:0 0 6px 0}
.skip-link:focus{left:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:16px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;font-size:12px;color:rgba(255,255,255,.60)}
.footer-bottom .legal{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.footer-bottom a:hover{color:rgba(255,255,255,.5)}

.page{display:none}
.page.active{display:block}
.page-hero{padding:60px 32px 48px;background:linear-gradient(135deg,#1a3a24,#0f2518);color:#fff;text-align:center}
.page-hero h1{font-size:clamp(24px,4vw,36px);font-weight:900;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}
.page-hero p{font-size:19px;color:rgba(255,255,255,.55);max-width:700px;margin:0 auto}
.page-hero .breadcrumb{font-size:12px;color:rgba(255,255,255,.65);margin-bottom:16px;letter-spacing:.04em}
.page-hero .breadcrumb a{color:var(--c400)}

.page-body{padding:48px 32px;margin:0 auto}
.page-body h2{font-size:31px;font-weight:900;letter-spacing:.03em;margin-bottom:14px;color:var(--ch);text-transform:uppercase}
.page-body h3{font-size:22px;font-weight:900;letter-spacing:.02em;margin:30px 0 12px;color:var(--p700)}
.page-body p{font-size:18px;color:var(--s500);line-height:1.75;margin-bottom:18px}
.page-body ul{margin:0 0 18px 22px;font-size:18px;color:var(--s500);line-height:1.9}
.page-body ul li{margin-bottom:6px}

.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin:24px 0}
.info-card{border:1px solid var(--s100);border-radius:10px;overflow:hidden;transition:.2s;cursor:pointer;box-shadow:var(--shadow-1)}
.info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.info-card .ic-head{padding:16px 20px;font-size:14px;font-weight:900;letter-spacing:.04em;color:#fff;min-height:100px;display:flex;align-items:flex-end}
.info-card .ic-body{padding:20px}
.info-card .ic-body p{font-size:14px;margin-bottom:10px}
.info-card .ic-body a{font-size:13px;color:var(--c500);font-weight:700}

.activity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:24px 0}
.act-card{border:1px solid var(--s100);border-radius:10px;padding:20px;text-align:center;transition:.2s;cursor:pointer;box-shadow:var(--shadow-1)}
.act-card:hover{border-color:var(--c400);background:var(--c50);box-shadow:var(--shadow-2)}
.act-card i{font-size:31px;color:var(--c500);margin-bottom:10px}
.cal-month-head{font-size:12px;font-weight:800;letter-spacing:.1em;color:var(--p600);text-transform:uppercase;border-bottom:2px solid var(--p100);padding-bottom:6px;margin:28px 0 14px}
.cal-month-head:first-child{margin-top:0}
.cal-event{display:flex;align-items:flex-start;gap:16px;padding:14px 0;border-bottom:1px solid var(--s100)}
.cal-event:last-child{border-bottom:none}
.cal-event.cal-past{opacity:.45}
.cal-event.cal-past .cal-date{background:var(--s400)!important}
.cal-date{flex-shrink:0;width:52px;text-align:center;background:var(--p600);color:#fff;border-radius:8px;padding:6px 4px;line-height:1.1}
.cal-date .cal-m{font-size:10px;font-weight:700;letter-spacing:.08em;opacity:.8;text-transform:uppercase}
.cal-date .cal-d{font-size:24px;font-weight:900}
.cal-info{flex:1;min-width:0}
.cal-title{font-size:15px;font-weight:700;color:var(--s700);margin-bottom:3px}
.cal-time{font-size:13px;color:var(--s400);margin-bottom:5px}
.cal-loc{font-size:13px;color:var(--s400);margin-bottom:5px}
.cal-reg{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;padding:2px 8px;border-radius:20px}
.cal-reg.required{background:var(--c50);color:var(--c700);border:1px solid var(--c200)}
.cal-reg.members{background:var(--emergency-bg);color:var(--emergency-text);border:1px solid var(--emergency-border)}
.cal-reg.open{background:var(--p50);color:var(--p700);border:1px solid var(--p100)}
.cal-reg.board{background:#D3C7B8;color:var(--s700);border:1px solid #b8aa98}
.act-card h4{font-size:14px;font-weight:900;letter-spacing:.04em;margin-bottom:6px}
.act-card p{font-size:13px;color:var(--s400);line-height:1.5}

.doc-list{margin:18px 0;border:1px solid var(--s100);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-1)}
.doc-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--s100);transition:.15s;cursor:pointer;text-decoration:none;position:relative}
.doc-item-private{outline:1.5px dashed var(--c400);outline-offset:-2px;background:rgba(193,121,60,.04)!important}
.doc-item-private::after{content:'PRIVATE';position:absolute;top:50%;right:12px;transform:translateY(-50%);font-size:10px;font-weight:800;color:var(--c500);letter-spacing:.06em;pointer-events:none}
.acc-group-private>.acc-head{border-left:3px solid var(--c400)}
.acc-group-private>.acc-head .acc-title::after{content:' — PRIVATE';font-size:11px;color:var(--c500);font-weight:700}
#doc-view-toggle{display:none;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:5px 14px;border:1.5px solid var(--c400);border-radius:20px;cursor:pointer;background:#fff;color:var(--c600);transition:.15s;margin:6px 0 14px;letter-spacing:.03em}
#doc-view-toggle:hover{background:var(--c50);border-color:var(--c500)}
#doc-view-toggle.priv{background:var(--c500);color:#fff;border-color:var(--c500)}
.doc-item:last-child{border-bottom:none}
.doc-item:hover{background:var(--p50)}
.doc-item i.doc-icon{font-size:20px;color:var(--tmma-sage);flex-shrink:0}
.doc-item .di-info{flex:1;min-width:0}
.doc-item .di-info .di-name{font-size:14px;font-weight:700;color:var(--ch)}
.doc-item .di-info .di-desc{font-size:12px;color:var(--s400);margin-top:2px}
.doc-item .di-dl{white-space:nowrap;display:flex;align-items:center;gap:6px;flex-shrink:0}
.di-eye{background:none;border:1px solid var(--s200);border-radius:5px;padding:5px 9px;cursor:pointer;color:var(--p600);font-size:12px;display:flex;align-items:center;gap:4px;font-family:inherit;text-decoration:none}
.di-eye:hover{background:var(--p50);border-color:var(--p300)}
.di-dl-btn{background:var(--c100,#f5e9cc);color:var(--c700,#8a6218);border-radius:5px;padding:5px 9px;font-size:12px;font-weight:700;text-decoration:none;display:flex;align-items:center;gap:4px}
.di-dl-btn:hover{background:var(--c200,#ead5a0)}
#legal-modal{display:none;position:fixed;inset:0;z-index:9100;background:rgba(0,0,0,.75);align-items:center;justify-content:center;padding:20px}
#legal-modal-box{background:#fff;border-radius:12px;max-width:780px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
#legal-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--s100);flex-shrink:0}
#legal-modal-head h2{font-size:18px;font-weight:900;color:var(--p700);letter-spacing:.03em;margin:0}
#legal-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--s400);line-height:1;padding:4px 8px;border-radius:4px;transition:.15s}
#legal-modal-close:hover{color:var(--p700);background:var(--s100)}
#legal-modal-esc{font-size:12px;color:var(--s400);font-weight:600;letter-spacing:.05em;margin-right:4px}
#legal-modal-body{overflow-y:auto;padding:24px 32px;font-size:14px;line-height:1.8;color:var(--s600)}
#legal-modal-body h3{font-size:14px;font-weight:900;color:var(--p700);letter-spacing:.04em;text-transform:uppercase;margin:22px 0 6px}
#legal-modal-body h3:first-child{margin-top:0}
#legal-modal-body p{margin:0 0 12px}
#legal-modal-body ul{margin:0 0 12px;padding-left:20px}
#legal-modal-body li{margin-bottom:4px}
#legal-modal-body .legal-updated{font-size:12px;color:var(--s400);margin-top:20px;padding-top:16px;border-top:1px solid var(--s100)}
#pdf-modal{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.82);flex-direction:column}
#pdf-modal-bar{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--tmma-sage);flex-shrink:0}
#pdf-modal-title{font-size:14px;font-weight:700;color:#fff;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#pdf-modal-dl{color:var(--c200);font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap}
#pdf-modal-close{background:none;border:none;color:#fff;font-size:26px;cursor:pointer;padding:4px 8px;line-height:1;flex-shrink:0;border-radius:4px;transition:.15s}
#pdf-modal-close:hover{background:rgba(255,255,255,.15)}
#pdf-modal iframe{flex:1;border:none;width:100%}
/* ── Accordion ── */
.acc-group{margin:20px 0 32px;border:1px solid var(--s100);border-radius:12px;overflow:hidden}
.acc-head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;background:var(--s50);cursor:pointer;user-select:none;transition:.15s;border-bottom:1px solid transparent}
.acc-head:hover{background:var(--p50)}
.acc-head.open{background:var(--p600);border-bottom-color:var(--p700)}
.acc-head-left{display:flex;align-items:center;gap:12px}
.acc-head-left i{font-size:18px;color:var(--p600);width:20px;text-align:center}
.acc-head.open .acc-head-left i{color:#fff}
.acc-title{font-size:14px;font-weight:900;letter-spacing:.04em;color:var(--ch);text-transform:uppercase}
.acc-head.open .acc-title{color:#fff}
.acc-count{font-size:12px;font-weight:700;color:var(--s400);background:var(--s100);border-radius:10px;padding:2px 8px}
.acc-head.open .acc-count{background:rgba(255,255,255,.2);color:rgba(255,255,255,.8)}
.acc-chevron{font-size:12px;color:var(--s400);transition:transform .2s}
.acc-head.open .acc-chevron{transform:rotate(180deg);color:rgba(255,255,255,.7)}
.acc-body{display:none;background:#fff}
.acc-body.open{display:block}
.term-body{padding:18px 22px 22px;color:var(--s600);font-size:14px;line-height:1.6}
.term-body p{margin:0 0 12px}
.term-body ul{margin:0 0 14px 22px;padding:0}
.term-body ul ul{margin:6px 0 10px 22px}
.term-body li{margin:0 0 6px;line-height:1.55}
.term-body h5{font-size:13px;font-weight:900;letter-spacing:.04em;color:var(--p700);margin:18px 0 8px;text-transform:uppercase}
.term-body h5:first-child{margin-top:0}
.term-body strong{color:var(--ch);font-weight:700}
.doc-year-sep{padding:7px 20px 5px;font-size:11px;font-weight:900;letter-spacing:.07em;color:var(--s400);text-transform:uppercase;background:var(--s50);border-top:1px solid var(--s100);border-bottom:1px solid var(--s100)}

/* ── Pool FAQ ── */
.faq-list{margin:20px 0 32px;border:1px solid var(--s100);border-radius:12px;overflow:hidden}
.faq-item{border-bottom:1px solid var(--s100)}
.faq-item:last-child{border-bottom:none}
.faq-q{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 20px;cursor:pointer;user-select:none;background:#fff;gap:16px;transition:.15s}
.faq-q:hover{background:var(--p50)}
.faq-q.open{background:var(--p50)}
.faq-q-text{font-size:17px;font-weight:700;color:var(--ch);flex:1;line-height:1.4}
.faq-q.open .faq-q-text{color:var(--p700)}
.faq-q-icon{font-size:12px;color:var(--s400);transition:transform .2s;flex-shrink:0;margin-top:2px}
.faq-q.open .faq-q-icon{transform:rotate(180deg);color:var(--p600)}
.faq-a{display:none;padding:0 20px 18px 20px;font-size:17px;color:var(--s500);line-height:1.75;background:#fff}
.faq-a.open{display:block}
.faq-a strong{color:var(--ch)}
.faq-sub{margin:10px 0 0;padding-left:16px}
.faq-sub li{margin-bottom:8px}

.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin:24px 0}
.team-card{border:1px solid var(--s100);border-radius:14px;padding:32px;text-align:center;transition:.2s;box-shadow:var(--shadow-1)}
.team-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}
.team-card .avatar{width:80px;height:80px;border-radius:50%;background:var(--p100);display:flex;align-items:center;justify-content:center;font-size:30px;color:var(--p600);margin:0 auto 16px;font-weight:900;border:2px solid var(--p200)}
.team-card h4{font-size:17px;font-weight:900;margin-bottom:2px}
.team-card .creds{font-size:13px;color:var(--s400);font-style:italic;margin-bottom:4px}
.team-card .role{font-size:14px;color:var(--s400);margin-bottom:12px}
.team-card a{display:block;font-size:14px;color:var(--c500);font-weight:600;margin-top:5px}
.team-card--portal{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px}
.portal-link{display:inline-block;font-size:13px;font-weight:700;color:var(--c500);background:var(--c50,#F0EBE3);padding:10px 16px;border-radius:8px;border:1px solid rgba(176,109,42,.3);text-decoration:none;transition:.15s;margin-top:8px;line-height:1.4}
.portal-link:hover{background:var(--tmma-copper,#B06D2A);color:#fff;border-color:var(--tmma-copper,#B06D2A)}

.brand-link{display:flex;align-items:center;gap:12px;background:none;border:none;padding:0;cursor:pointer;text-align:left;font-family:'Lato',Arial,sans-serif;-webkit-font-smoothing:auto}
.brand-link:hover .logo-text,.brand-link:hover .logo-sub{color:var(--p700)}
.brand-link:focus-visible{outline:2px solid var(--c400);outline-offset:4px;border-radius:8px}


@media(min-width:769px){
  .top,.section,footer,.page-hero{padding-left:var(--mx);padding-right:var(--mx)}
  .split{padding-left:var(--mx);padding-right:var(--mx)}
  .page-body{padding-left:var(--mx);padding-right:var(--mx);max-width:none}
}

/* ── Tablet nav: hamburger up to 1024px so the desktop nav isn't crammed ── */
@media(max-width:1024px){
  .top-phone,.social-icons,.nav-search{display:none!important}
  .mob-search-btn{display:flex}
  .hamburger{display:flex}
  .login-btn{width:44px;height:44px;padding:0;font-size:16px;letter-spacing:0}
  .login-label{display:none}
  .login-icon{display:inline}
  nav.main .nav-links{display:none}
  .mobile-menu{display:block}
}
@media(max-width:1024px) and (min-width:769px){
  .mobile-menu .mm-item{padding:14px 24px}
  .mobile-menu .mm-search{padding:10px 24px}
  .mobile-menu .mm-sub a{padding:11px 24px 11px 48px}
  .mm-footer{padding:12px 24px}
  #search-bar-inner{padding:16px 24px 20px}
}

@media(max-width:768px){
  .top{padding:10px 16px}
  .logo-mark{width:52px}
  .logo-text{font-size:12px}
  .logo-sub{font-size:12px;letter-spacing:.05em}
  .top-phone,.social-icons,.nav-search{display:none!important}
  .mob-search-btn{display:flex}
  .hamburger{display:flex}
  .login-btn{width:44px;height:44px;padding:0;font-size:16px;letter-spacing:0}
  .login-label{display:none}
  .login-icon{display:inline}
  nav.main .nav-links{display:none}
  .mobile-menu{display:block}
  .hero{min-height:320px}
  .hero .hero-desc{font-size:14px;margin-top:8px}
  .hero-ctas{flex-direction:column;width:100%;max-width:280px;gap:8px}
  .hero-ctas .btn-copper,.hero-ctas .btn-outline{text-align:center;width:100%}
  .hero-watermark{display:none}
  .qa-grid{grid-template-columns:repeat(2,1fr);padding:14px 16px;gap:10px}
  .qa-card{padding:20px 12px}
  .section{padding:28px 16px 24px}
  .news-grid{grid-template-columns:1fr;gap:14px}
  .news-card{display:block}
  .news-img{width:100%;height:160px;min-height:unset}
  .news-body{padding:12px 14px}
  .news-body h3{font-size:14px}
  .news-body p{font-size:12px;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
  .split{grid-template-columns:1fr;padding:0 16px 28px;gap:16px}
  .page-hero{padding:36px 16px 28px}
  .page-body{padding:28px 16px}
  footer{padding:28px 16px 16px}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-brand-inner{flex-direction:column;align-items:center;text-align:center}
  .footer-brand-inner img{width:140px}
  .footer-brand{align-items:center;text-align:center}
  .footer-brand-link{display:flex;justify-content:center;width:100%;margin:0 auto}
  .footer-main-logo{width:200px}
  .footer-brand-info{text-align:center}
  .footer-brand-info i{display:inline;margin-right:4px}
  .footer-brand-info-indent{padding-left:0}
  .footer-col{text-align:center}
  .footer-col a{display:block;text-align:center}
  .footer-emergency{text-align:center;align-self:center}
  .card-grid,.activity-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
/* ── Page-hero photos ── */
#page-community  .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-01.jpg') center/cover no-repeat}
#page-amenities  .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-02.jpg') center/cover no-repeat}
#page-resources  .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-03.jpg') center/cover no-repeat}
#page-contact    .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-04.jpg') center/cover no-repeat}
#page-title-transfer .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-04.jpg') center/cover no-repeat}
#page-rental-access .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-04.jpg') center/cover no-repeat}
#page-rental     .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-04.jpg') center/cover no-repeat}
#page-arc-access .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-01.jpg') center/cover no-repeat}
#page-arc        .page-hero{background:linear-gradient(rgba(10,20,14,.78),rgba(10,20,14,.68)),url('/uploads/tmma-01.jpg') center/cover no-repeat}
/* ── Pool hours ── */
.hours-block{border:1px solid var(--s100);border-radius:10px;overflow:hidden;margin:16px 0 32px;width:100%}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--s100)}
.hours-row:last-child{border-bottom:none}
.hours-row:nth-child(even){background:var(--s50)}
.hours-day{font-size:19px;font-weight:700;color:var(--s700)}
.hours-time{font-size:19px;font-weight:700;color:var(--p600)}
/* ── Amenities section divider ── */
.amenity-section{margin-top:40px;padding-top:32px;border-top:1px solid var(--s100)}
/* ── Amenity showcase cards ── */
.amen-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin:24px 0 0}
@media(max-width:900px){.amen-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.amen-grid{grid-template-columns:repeat(2,1fr)}}
.amen-card{border-radius:16px;overflow:hidden;border:1px solid var(--s100);cursor:pointer;transition:.2s;box-shadow:var(--shadow-1);background:#fff}
.amen-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-3)}
.amen-card.active{border-color:var(--s100);box-shadow:var(--shadow-1)}
.amen-card-img{height:120px;background-size:cover;background-position:center}
.amen-card-info{padding:12px}
.amen-card-info h4{font-size:15px;font-weight:900;letter-spacing:.04em;margin-bottom:6px;color:var(--ch)}
.amen-card-info p{font-size:14px;color:var(--s400);line-height:1.5;margin:0}
.amen-expand{margin:20px 0 32px;border-radius:16px;overflow:hidden;border:1px solid var(--p200);box-shadow:var(--shadow-2);animation:amenIn .3s cubic-bezier(.16,1,.3,1)}
@keyframes amenIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.amen-expand-inner{display:grid;grid-template-columns:1fr 1.3fr}
.amen-expand-img{background-size:cover;background-position:center;min-height:300px}
.amen-expand-body{padding:32px 36px;overflow-y:auto}
.amen-expand-body h3{font-size:22px;font-weight:900;letter-spacing:.03em;margin-bottom:14px;color:var(--p700)}
.amen-expand-body p{font-size:15px;color:var(--s500);line-height:1.75;margin-bottom:12px}
.amen-expand-body ul{font-size:15px;color:var(--s500);line-height:2;margin:0 0 14px;padding-left:20px}
.amen-expand-close{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--s400);background:none;border:none;cursor:pointer;padding:0;margin-top:18px;font-family:inherit;transition:.15s}
.amen-expand-close:hover{color:var(--p700)}
@media(max-width:768px){.amen-expand-inner{grid-template-columns:1fr}.amen-expand-img{min-height:200px}.amen-expand-body{padding:20px 18px}}
/* ── Site map ── */
#section-community-map{padding-left:clamp(16px,3vw,56px);padding-right:clamp(16px,3vw,56px)}
.community-map-shell{border:1px solid var(--s100);border-radius:12px;background:#fff;overflow:hidden;aspect-ratio:3250/2190;width:100%;box-shadow:var(--shadow-1)}
.community-map-embed{display:block;width:100%;height:100%}
.community-map-link{margin-top:14px}
.community-map-link a{color:var(--p600);font-weight:700;font-size:15px}
@media(max-width:768px){.community-map-shell{height:440px}}
.sm-section-head{font-size:14px;font-weight:800;letter-spacing:.08em;color:var(--p600);border-bottom:2px solid var(--p100);padding-bottom:9px;margin:0 0 16px;text-transform:uppercase}
.sm-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.sm-link{font-size:17px;color:var(--s500);cursor:pointer;text-decoration:none;transition:.15s;display:block}
.sm-link:hover{color:var(--p700)}
.sm-link-primary{color:var(--p700);font-weight:700}
.sm-link-cta{color:var(--c500);font-weight:700}
.sm-link-cta:hover{color:var(--c600)}
/* ── Year-at-a-glance ── */
#yag-mobile-pager{display:none;margin-bottom:24px}
.yag-mobile-months{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--s100)}
.yag-mobile-months .yag-month{border-right:1px solid var(--s100);border-bottom:1px solid var(--s100);padding:10px 8px}
.yag-mobile-months .yag-month:nth-child(odd){border-right:1px solid var(--s100)}
.yag-mobile-months .yag-month:nth-child(2n){border-right:none}
.yag-mobile-months .yag-month:nth-child(n+3){border-bottom:none}
.yag-nav-btn{background:none;border:none;color:rgba(255,255,255,.75);font-size:22px;cursor:pointer;padding:0 6px;line-height:1;border-radius:4px;transition:.15s;flex-shrink:0}
.yag-nav-btn:hover:not(:disabled){color:#fff}
.yag-nav-btn:disabled{opacity:.25;cursor:default}
@media(max-width:480px){#year-glance{display:none}#yag-mobile-pager{display:block}}
.yag-box{margin:0 0 28px;border:1px solid var(--s100);border-radius:14px;overflow:hidden;background:#fff;box-shadow:var(--shadow-1)}
.yag-head{padding:14px 20px;background:var(--p600);display:flex;align-items:center;justify-content:space-between}
.yag-head h4{font-size:14px;font-weight:700;color:#fff;letter-spacing:.05em;margin:0}
.yag-head span{font-size:12px;color:rgba(255,255,255,.55)}
.yag-months{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--s100)}
.yag-month{padding:10px 8px;border-right:1px solid var(--s100);border-bottom:1px solid var(--s100)}
.yag-month:nth-child(6n){border-right:none}
.yag-month:nth-child(n+7){border-bottom:none}
.yag-month-name{font-size:10px;font-weight:800;letter-spacing:.08em;color:var(--p600);text-transform:uppercase;margin-bottom:5px}
.yag-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.yag-day{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:8px;color:var(--s500);border-radius:3px}
.yag-day.has-event{background:var(--p600);color:#fff;border-radius:4px;font-weight:700;cursor:pointer;transition:.1s}
.yag-day.has-event:hover{background:var(--p700)}
.yag-day.has-required{background:var(--c500);color:#fff;border-radius:4px;font-weight:700;cursor:pointer;transition:.1s}
.yag-day.has-required:hover{background:var(--c600)}
.yag-day.has-board{background:#D3C7B8;color:var(--s700);border-radius:4px;font-weight:700;cursor:pointer;transition:.1s}
.yag-day.has-board:hover{background:#b8aa98}
.yag-day.has-past{background:#97A09D;color:#fff;border-radius:4px;font-weight:700;cursor:pointer;transition:.1s}
.yag-day.has-past:hover{background:#7d8885}
.yag-day.today-marker{outline:2px solid var(--c400);outline-offset:0;border-radius:4px}
.yag-day.has-required.today-marker{outline-color:#fff}
.yag-legend{display:flex;align-items:center;flex-wrap:wrap;gap:8px 20px;padding:9px 20px;border-top:1px solid var(--s100);font-size:12px;color:var(--s400)}
.yag-legend-item{display:flex;align-items:center;gap:5px}
.yag-legend-dot{width:10px;height:10px;border-radius:3px;display:inline-block;flex-shrink:0}
.yag-legend-dot.open{background:var(--p600)}
.yag-legend-dot.required{background:var(--c500)}
.yag-legend-dot.board{background:#D3C7B8;border:1px solid #b8aa98}
@media(max-width:768px){.yag-months{grid-template-columns:repeat(3,1fr)}.yag-month:nth-child(6n){border-right:1px solid var(--s100)}.yag-month:nth-child(3n){border-right:none}.yag-month:nth-child(-n+9){border-bottom:1px solid var(--s100)}.yag-month:nth-child(n+10){border-bottom:none}}
@media(max-width:768px){.community-map-shell{min-height:520px;overflow:auto}.community-map-embed{width:780px;height:520px}}
/* ── ADA Accessibility Widget ── */
.ada-fab{position:fixed;bottom:28px;left:28px;z-index:9999;width:46px;height:46px;border-radius:50%;background:#0D7EC4;border:none;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;transition:.2s}
.ada-fab:hover{background:#0a6aaa;transform:scale(1.07)}
.ada-fab i{font-size:20px;color:#fff}
.ada-panel{position:fixed;bottom:82px;left:28px;z-index:9998;width:262px;border-radius:16px;background:#fff;box-shadow:0 12px 40px rgba(0,0,0,.18);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--s100)}
.ada-panel.open{display:flex}
.ada-panel-head{background:#0D7EC4;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.ada-panel-title{color:#fff;font-size:14px;font-weight:700;letter-spacing:.04em;display:flex;align-items:center;gap:8px}
.ada-panel-title i{font-size:15px}
.ada-close{background:none;border:none;color:rgba(255,255,255,.7);font-size:22px;cursor:pointer;line-height:1;padding:0 2px;transition:.15s;font-family:inherit}
.ada-close:hover{color:#fff}
.ada-panel-body{padding:16px}
.ada-section-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--s400);margin-bottom:8px}
.ada-size-row{display:flex;gap:6px}
.ada-size-btn{flex:1;padding:8px 4px;border:1.5px solid var(--s100);border-radius:6px;background:#fff;cursor:pointer;font-family:inherit;color:var(--s600);font-weight:700;transition:.15s}
.ada-size-btn:hover{border-color:#0D7EC4;color:#0D7EC4;background:#EAF4FB}
.ada-size-btn.ada-active{border-color:#0D7EC4;background:#EAF4FB;color:#0D7EC4}
.ada-toggle-btn{width:100%;padding:9px 12px;border:1.5px solid var(--s100);border-radius:6px;background:#fff;cursor:pointer;font-family:inherit;color:var(--s600);font-weight:600;font-size:13px;display:flex;align-items:center;gap:8px;transition:.15s;text-align:left;margin-top:8px}
.ada-toggle-btn:hover{border-color:#0D7EC4;color:#0D7EC4;background:#EAF4FB}
.ada-toggle-btn.ada-active{border-color:#0D7EC4;background:#EAF4FB;color:#0D7EC4}
.ada-toggle-btn i{font-size:14px;width:16px;text-align:center}
html.ada-hc #alertBar,html.ada-hc nav.main,html.ada-hc .mobile-menu,html.ada-hc main#main-content,html.ada-hc footer{filter:contrast(1.6) brightness(.92)}
/* ada-hc: explicit card borders so info-card/qa-card don't blend with background */
html.ada-hc .info-card,html.ada-hc .qa-card{border-width:2px!important;border-color:var(--s400)!important}
/* ada-hc: avatar circle — more contrast */
html.ada-hc .team-card .avatar{background:var(--p200)!important;color:var(--p700)!important;border:2px solid var(--p400)!important}
/* ada-hc: month header and document separators — more visible */
html.ada-hc .cal-month-head{border-bottom-width:3px!important;border-bottom-color:var(--p400)!important}
html.ada-hc .doc-item{border-bottom-color:var(--s400)!important}
body.ada-text-1{zoom:1.08}
body.ada-text-2{zoom:1.16}
/* ── Chatbot ── */
.chatbot-fab{position:fixed;bottom:28px;right:28px;z-index:9999;width:46px;height:46px;border-radius:50%;background:var(--p600);border:none;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;transition:.2s}
.chatbot-fab:hover{background:var(--p700);transform:scale(1.07)}
.chatbot-fab i{font-size:21px;color:#fff}
/* ── Feedback FAB ── */
.feedback-fab{position:fixed;bottom:84px;right:28px;z-index:9999;width:46px;height:46px;border-radius:50%;background:var(--c500);border:none;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;transition:.2s}
.feedback-fab:hover{background:var(--c600);transform:scale(1.07)}
.feedback-fab i{font-size:20px;color:#fff}
.feedback-panel{position:fixed;bottom:138px;right:28px;z-index:9998;width:300px;border-radius:16px;background:#fff;box-shadow:0 12px 40px rgba(0,0,0,.18);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--s100)}
.feedback-panel.open{display:flex}
.feedback-head{background:var(--c500);padding:12px 16px;display:flex;align-items:center;gap:10px}
.feedback-head-info{flex:1}
.feedback-head-title{font-size:14px;font-weight:900;color:#fff;letter-spacing:.03em}
.feedback-head-sub{font-size:12px;color:rgba(255,255,255,.65)}
.feedback-close{background:none;border:none;color:rgba(255,255,255,.55);cursor:pointer;font-size:20px;line-height:1;padding:0;transition:.15s}
.feedback-close:hover{color:#fff}
.feedback-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.feedback-body label{display:block;font-size:11px;font-weight:700;color:var(--s500);letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}
.feedback-body textarea,.feedback-body input[type=email]{width:100%;padding:10px 12px;border:1px solid var(--s200);border-radius:8px;font-size:14px;font-family:'Lato',sans-serif;color:var(--ch);background:#fff;transition:.15s}
.feedback-body textarea{min-height:88px;resize:vertical}
.feedback-body textarea:focus,.feedback-body input[type=email]:focus{outline:none;border-color:var(--c400);box-shadow:0 0 0 3px rgba(176,109,42,.14)}
.feedback-body .btn-copper{width:100%;padding:11px;font-size:13px;letter-spacing:.06em;margin-top:2px}
.feedback-success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 20px;text-align:center}
.feedback-success i{font-size:34px;color:var(--tmma-sage)}
.feedback-success p{font-size:14px;color:var(--s600);line-height:1.55;margin:0}
/* ── Feedback nudge bubble ── */
.feedback-nudge{position:fixed;bottom:94px;right:90px;z-index:9997;width:220px;background:#fff;border:1px solid var(--s100);border-radius:12px;padding:11px 14px;box-shadow:0 4px 18px rgba(0,0,0,.13);display:flex;align-items:center;gap:8px;transition:opacity .3s}

.feedback-nudge p{font-size:13px;color:var(--s700);line-height:1.45;margin:0;flex:1}
.feedback-nudge-close{background:none;border:none;color:var(--s500);cursor:pointer;font-size:16px;padding:0;line-height:1;flex-shrink:0}
.feedback-nudge-close:hover{color:var(--s600)}
.feedback-nudge.hidden{display:none}
.feedback-fab.chat-open{bottom:610px}
#back-to-top.chat-open{bottom:664px}
#back-to-top.feedback-open{bottom:468px}
.chatbot-panel{position:fixed;bottom:82px;right:28px;z-index:9998;width:320px;height:520px;border-radius:16px;background:#fff;box-shadow:0 12px 40px rgba(0,0,0,.18);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--s100)}
.chatbot-panel.open{display:flex}
.chat-head{background:var(--p600);padding:12px 16px;display:flex;align-items:center;gap:10px}
.chat-head-avatar{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.chat-head-avatar i{font-size:15px;color:#fff}
.chat-head-info{flex:1}
.chat-head-title{font-size:14px;font-weight:900;color:#fff;letter-spacing:.03em}
.chat-head-sub{font-size:12px;color:rgba(255,255,255,.6)}
.chat-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:20px;line-height:1;padding:0}
.chat-close:hover{color:#fff}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-bubble{max-width:82%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.5}
.chat-bubble.bot{background:var(--s50);color:var(--s700);border-bottom-left-radius:3px;align-self:flex-start;white-space:pre-line}
.chat-bubble.user{background:var(--p600);color:#fff;border-bottom-right-radius:3px;align-self:flex-end}
.chat-typing-dots span{display:inline-block;opacity:0;animation:dotPop 1.2s infinite;font-size:18px;line-height:1}
.chat-typing-dots span:nth-child(2){animation-delay:.2s}
.chat-typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes dotPop{0%,60%,100%{opacity:0;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes lgHintFade{0%,65%{opacity:1}100%{opacity:0}}
/* Suppress focus ring on headings that receive programmatic focus for screen-reader routing */
h1[tabindex="-1"]:focus,h1[tabindex="-1"]:focus-visible,
h2[tabindex="-1"]:focus,h2[tabindex="-1"]:focus-visible{outline:none}
/* ── Back-to-top button ─────────────────────────────────────────────── */
#back-to-top{position:fixed;bottom:140px;right:28px;z-index:8000;width:46px;height:46px;border-radius:50%;background:var(--p600);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 4px 14px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s,bottom .25s;transform:translateY(8px)}
#back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
#back-to-top:hover{background:var(--p700)}
/* ── Pool status badge ──────────────────────────────────────────────── */
.pool-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;letter-spacing:.04em;padding:4px 10px;border-radius:20px;margin:0 0 14px}
.pool-badge.open{background:#d4edda;color:#1a6a35;border:1px solid #a3d9b1}
.pool-badge.closed{background:#fde8e8;color:#b91c1c;border:1px solid #fca5a5}
.pool-badge.upcoming{background:var(--c50);color:var(--c700);border:1px solid var(--c200)}
/* ── Home events "this week" badge ──────────────────────────────────── */
.evt-this-week{font-size:10px;font-weight:700;letter-spacing:.05em;background:var(--c100);color:var(--c700);border-radius:10px;padding:2px 7px;margin-left:6px;vertical-align:middle;white-space:nowrap}
/* ── Add-to-calendar dropdown ───────────────────────────────────────── */
.cal-add-wrap{position:relative;display:inline-block;margin-top:8px}
.cal-add-btn{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--p600);background:var(--p50);border:1px solid var(--p200);border-radius:5px;padding:4px 9px;cursor:pointer;font-family:inherit}
.cal-add-btn:hover{background:var(--p100)}
.cal-add-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--s200);border-radius:8px;box-shadow:0 4px 14px rgba(0,0,0,.12);min-width:170px;z-index:1000;overflow:hidden}
.cal-add-menu.open{display:block}
.cal-add-menu a{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;color:var(--ch);text-decoration:none;white-space:nowrap}
.cal-add-menu a:hover{background:var(--p50)}
/* ── Resources document filter ─────────────────────────────────────── */
.doc-search-wrap{position:relative;margin-bottom:20px}
.doc-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--s400);font-size:14px;pointer-events:none}
#doc-search{width:100%;padding:10px 14px 10px 38px;border:1px solid var(--s200);border-radius:8px;font-size:14px;font-family:Lato,sans-serif;box-sizing:border-box;background:#fff}
#doc-search:focus{outline:none;border-color:var(--p400);box-shadow:0 0 0 3px rgba(75,108,65,.12)}
#doc-search-results{margin-top:10px;border:1px solid var(--s100);border-radius:10px;overflow:hidden}
#doc-search-results .doc-item:last-child{border-bottom:none}
.doc-no-results{padding:14px 16px;font-size:14px;color:var(--s400);text-align:center}
/* ── FAQ suggestion widget ──────────────────────────────────────────── */
#faq-suggestions{display:none;margin-top:14px;padding:14px 16px;background:var(--p50);border:1px solid var(--p200);border-radius:8px}
#faq-suggestions h5{font-size:11px;font-weight:900;letter-spacing:.08em;color:var(--p700);margin:0 0 10px;text-transform:uppercase}
.faq-sug-item{padding:9px 12px;background:#fff;border:1px solid var(--s100);border-radius:6px;margin-bottom:6px;cursor:pointer;transition:.15s}
.faq-sug-item:last-child{margin-bottom:0}
.faq-sug-item:hover{background:var(--p100);border-color:var(--p300)}
.faq-sug-q{font-size:13px;font-weight:700;color:var(--ch);margin-bottom:3px}
.faq-sug-a{font-size:12px;color:var(--s500);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--s100);align-items:flex-end}
.chat-input-row textarea{flex:1;padding:8px 11px;border-radius:8px;border:1px solid var(--s200);font-size:14px;font-family:inherit;outline:none;color:var(--ch);resize:none;min-height:36px;max-height:120px;overflow-y:auto;line-height:1.45}
.chat-input-row textarea:focus{border-color:var(--p400)}
.chat-input-row button{padding:8px 12px;border-radius:8px;background:var(--p600);border:none;color:#fff;cursor:pointer;font-size:15px;transition:.15s;flex-shrink:0;height:36px}
.chat-input-row button:hover{background:var(--p700)}
/* ── Chat nudge bubble ── */
.chat-nudge{position:fixed;bottom:28px;right:90px;z-index:9997;width:220px;background:#fff;border:1px solid var(--s100);border-radius:12px;padding:11px 14px;box-shadow:0 4px 18px rgba(0,0,0,.13);display:flex;align-items:center;gap:8px;transition:opacity .3s}

.chat-nudge p{font-size:13px;color:var(--s700);line-height:1.45;margin:0;flex:1}
.chat-nudge-close{background:none;border:none;color:var(--s500);cursor:pointer;font-size:16px;padding:0;line-height:1;flex-shrink:0}
.chat-nudge-close:hover{color:var(--s600)}
.chat-nudge.hidden{display:none}
/* Lift feedback fab above the chat panel when chat is open */
.feedback-fab.chat-open{bottom:610px}
/* ── Mobile FABs — larger touch targets ── */
@media(max-width:768px){
  .chatbot-fab,.feedback-fab,.ada-fab{width:62px;height:62px}
  .chatbot-fab i{font-size:27px}
  .feedback-fab i{font-size:25px}
  .ada-fab i{font-size:25px}
  .feedback-fab{bottom:108px}
  .feedback-panel{bottom:178px}
  .ada-panel{bottom:98px}
  .chatbot-panel{bottom:98px}
  .feedback-fab.chat-open{bottom:626px}
  #back-to-top{bottom:180px;width:62px;height:62px}
  #back-to-top.chat-open{bottom:696px}
  #back-to-top.feedback-open{bottom:512px}
  .feedback-nudge,.chat-nudge{display:none}
}
.chat-clear-btn{background:none;border:none;color:rgba(255,255,255,.5);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.04em;padding:4px 6px;transition:.15s;margin-right:4px}
.chat-clear-btn:hover{color:#fff}
.chat-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px 4px;border-top:1px solid var(--s100);max-height:175px;overflow-y:auto}
.chat-chips:empty{display:none}
.chat-chip{padding:5px 11px;border-radius:20px;font-size:13px;font-weight:700;border:1.5px solid var(--s200);background:#fff;color:var(--s600);cursor:pointer;transition:.15s;letter-spacing:.02em}
.chat-chip:hover{border-color:var(--p400);color:var(--p700);background:var(--p50)}
.chat-chip:disabled{opacity:.5;cursor:not-allowed}
.chat-chip.chip-primary{background:var(--tmma-sage);color:#fff;border-color:var(--tmma-sage)}
.chat-chip.chip-primary:hover{background:var(--p700);border-color:var(--p700);color:#fff}

/* Resident verification form (chat gate) */
.chat-verify-form{display:flex;flex-direction:column;gap:8px;padding:10px 14px;margin:4px 0;background:var(--s50);border:1px solid var(--s100);border-radius:12px;align-self:stretch}
.chat-verify-in{padding:8px 11px;border-radius:8px;border:1px solid var(--s200);font-size:14px;font-family:inherit;outline:none;color:var(--ch)}
.chat-verify-in:focus{border-color:var(--p400)}
.chat-verify-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.chat-verify-note{margin:2px 0 0;font-size:11.5px;color:var(--s500);line-height:1.4}
.chat-verify-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}

/* Clickable links inside bot bubbles — rendered as inline pill buttons */
.chat-link{display:inline-block;padding:2px 9px;margin:1px 2px;border-radius:14px;background:var(--p50);color:var(--p700);text-decoration:none;font-weight:600;font-size:13px;border:1px solid var(--p100);transition:.15s;line-height:1.4}
.chat-link:hover{background:var(--p100);border-color:var(--p400);color:var(--p700);text-decoration:none}
.chat-bubble.bot .chat-link{color:var(--p700)}

/* Markdown elements inside bot bubbles */
.chat-bubble.bot strong{font-weight:700;color:inherit}
.chat-bubble.bot em{font-style:italic}
.chat-md-code{font-family:Menlo,Consolas,monospace;font-size:12px;background:rgba(0,0,0,.06);padding:1px 5px;border-radius:4px}
.chat-md-list{margin:6px 0;padding-left:20px}
.chat-md-list li{margin:2px 0;line-height:1.45}

.chat-fb-row{display:flex;gap:5px;margin-top:4px;padding-left:2px}
.chat-fb-btn{background:none;border:1px solid var(--s200);border-radius:8px;font-size:13px;cursor:pointer;padding:2px 7px;color:var(--s400);transition:.15s;line-height:1.4}
.chat-fb-btn:hover{border-color:var(--p400);color:var(--p600);background:var(--p50)}

/* ── Typography improvements ── */
.page-body h2{line-height:1.2}
.page-body h3{line-height:1.25}
.page-body p,.about-card p{letter-spacing:.01em}
.page-body blockquote{border-left:3px solid var(--c400);padding:12px 18px;margin:18px 0;font-style:italic;color:var(--s500);background:var(--s50);border-radius:0 6px 6px 0;line-height:1.7}

/* ── Quick wins: focus, buttons, spinner, toast, forms, tables, modals, a11y ── */

/* Win 1 · Global focus ring (WCAG AA keyboard nav) */
:focus-visible{outline:2px solid var(--c500);outline-offset:2px;border-radius:3px}

/* Win 8 · Button size variants */
.btn-sm{padding:7px 16px;font-size:12px;font-weight:700;letter-spacing:.04em;border-radius:6px;border:none;cursor:pointer}
.btn-lg{padding:16px 36px;font-size:15px;font-weight:700;letter-spacing:.05em;border-radius:6px;border:none;cursor:pointer}

/* Buttons · Ghost/tertiary style */
.btn-ghost{padding:13px 30px;border-radius:6px;background:transparent;color:var(--c500);border:1.5px solid var(--c200);cursor:pointer;font-size:14px;font-weight:700;letter-spacing:.05em;transition:.15s;font-family:inherit}
.btn-ghost:hover{color:var(--c600);background:var(--c50);border-color:var(--c400)}
.btn-ghost:active{background:var(--c100)}

/* Buttons · Click feedback on primary/secondary buttons */
.btn-copper:active,.login-btn:active{opacity:.82;transform:scale(.99)}
.btn-outline:active{opacity:.82;transform:scale(.99)}

/* Buttons · Inline link style for in-body text actions */
.link{color:var(--c500);font-weight:700;cursor:pointer;text-decoration:none;background:none;border:none;padding:0;font-family:inherit;font-size:inherit}
.link:hover{color:var(--c600);text-decoration:underline;text-underline-offset:2px}

/* Win 5 · Loading spinner on submit buttons */
@keyframes btnSpin{to{transform:rotate(360deg)}}
.btn-loading{position:relative;color:transparent!important;pointer-events:none;opacity:.85}
.btn-loading::after{content:'';position:absolute;inset:0;margin:auto;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:btnSpin .6s linear infinite}

/* Win 6 · Form input focus ring + field error/success states */
input,select,textarea{transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--p400)!important;box-shadow:0 0 0 3px rgba(78,138,106,.12)}
.field-error input,.field-error select,.field-error textarea{border-color:var(--r)!important;box-shadow:0 0 0 3px rgba(185,58,46,.1)}
.field-error-msg{display:none;font-size:12px;color:var(--r);margin-top:3px;font-weight:700;letter-spacing:.02em}
.field-error .field-error-msg{display:block}

/* Win 12 · Toast notification */
@keyframes toastIn{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(14px) scale(.97)}}
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:99999;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{padding:11px 22px;border-radius:8px;font-size:14px;font-weight:700;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.22);animation:toastIn .25s cubic-bezier(.16,1,.3,1) both;pointer-events:auto;min-width:200px;text-align:center;letter-spacing:.02em}
.toast-success{background:var(--ok)}
.toast-error{background:var(--r)}
.toast-info{background:var(--info)}

/* Win 14 · Empty state for grids / lists with no content */
.empty-state{text-align:center;padding:44px 24px;color:var(--s400)}
.empty-state i{font-size:33px;opacity:.3;display:block;margin-bottom:12px}
.empty-state p{font-size:15px;margin:0;line-height:1.5}

/* Win 7 · Table striping + mobile scroll in page bodies */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;border:1px solid var(--s100);box-shadow:var(--shadow-1)}
.table-wrap table{border:none;border-radius:0;margin:0;min-width:480px}
.page-body table{border:1px solid var(--s100);border-radius:8px;overflow:hidden;margin:16px 0;width:100%;box-shadow:var(--shadow-1)}
.page-body table th{color:var(--ch);font-weight:700;text-align:left;padding:12px 16px;border-bottom:2px solid var(--s100);font-size:13px;letter-spacing:.04em;text-transform:uppercase;background:var(--s50)}
.page-body table td{padding:12px 16px;border-bottom:1px solid var(--s100);font-size:15px;color:var(--s600)}
.page-body table tbody tr:last-child td{border-bottom:none}
.page-body table tbody tr:nth-child(even){background:var(--s50)}
.page-body table tbody tr:hover{background:var(--p50)}

/* Win 10 · Modal open animation */
@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes backdropIn{from{opacity:0}to{opacity:1}}

/* Forms · Placeholder color */
::placeholder{color:var(--s300);opacity:1}
:-ms-input-placeholder{color:var(--s300)}

/* Forms · Label standardization (applies to <form> elements; inline styles take precedence where set) */
form label{display:block;font-size:12px;font-weight:700;color:var(--s400);letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}

/* Forms · Required field indicator */
.req{color:var(--r);font-weight:900;margin-left:1px;font-style:normal}
.required-note{font-size:12px;color:var(--s400);margin-bottom:14px}
.required-note .req{font-style:normal}
.tt-form{border:1px solid var(--s100);border-radius:14px;padding:28px;background:linear-gradient(180deg,#fff,#fcfaf7);box-shadow:var(--shadow-1)}
.tt-section{margin-top:22px;padding:20px;border:1px solid var(--s100);border-radius:12px;background:#fff}
.tt-section h4{margin:0 0 16px;font-size:18px;font-weight:900;letter-spacing:.03em;color:var(--ch)}
.tt-subtitle{font-size:14px;color:var(--s400);margin:-6px 0 16px;line-height:1.6}
.tt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.tt-field label{display:block;font-size:12px;font-weight:700;color:var(--s500);letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}
.tt-field input,.tt-field textarea{width:100%;padding:11px 14px;border:1px solid var(--s200);border-radius:8px;font-size:15px;font-family:Lato,sans-serif;background:#fff;color:var(--s700)}
.tt-field input[readonly],.tt-field textarea[readonly],.tt-field input[disabled]{background:var(--s50);color:var(--s600);cursor:default}
.tt-field textarea{min-height:120px;resize:vertical}
.tt-note{font-size:12px;color:var(--s400);line-height:1.5;margin-top:6px}
.tt-inline{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.tt-check{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--s100);border-radius:10px;background:var(--s50)}
.tt-check input{margin-top:4px}
.tt-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:18px 0 0}
.tt-summary-card{padding:16px 18px;border-radius:12px;border:1px solid rgba(166,116,79,.18);background:#f6efe7}
.tt-summary-card strong{display:block;font-size:13px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--s500);margin-bottom:8px}
.tt-summary-amount{font-size:26px;font-weight:900;color:var(--ch);line-height:1.1}
.tt-summary-copy{font-size:13px;color:var(--s500);line-height:1.5;margin-top:8px}
.tt-callout{margin-top:16px;padding:12px 16px;background:var(--p50);border-left:3px solid var(--p400);border-radius:0 8px 8px 0;font-size:14px;color:var(--p700);line-height:1.6}
.tt-docs{font-size:15px;color:var(--s500);line-height:1.7;margin-bottom:20px}
.tt-docs a{color:var(--c500);font-weight:700}
.tt-success{display:none;margin-top:18px;padding:14px 16px;background:#EEF8F2;border:1px solid var(--p300);border-radius:10px;font-size:14px;color:var(--p700);font-weight:700}

/* Color · Higher-contrast form input borders (WCAG 1.4.11 non-text contrast) */
form input[type=text],form input[type=email],form select,form textarea{border-color:var(--s300)!important}
form input[type=text]:focus,form input[type=email]:focus,form select:focus,form textarea:focus{border-color:var(--p400)!important}

/* Color · Status row indicators for tables */
.row-ok{border-left:3px solid var(--ok)}
.row-warn{border-left:3px solid var(--warn)}
.row-risk{border-left:3px solid var(--risk)}

/* Win 11 · Minimum 44px touch targets on mobile */
@media(max-width:768px){
  .btn-copper,.btn-outline,.login-btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .di-eye,.di-dl-btn{min-height:44px;padding:8px 12px;display:inline-flex;align-items:center;justify-content:center}
  .chat-chip{padding:10px 14px;font-size:14px}
  .doc-item{padding:14px 16px}
}

/* Win 3 · Dark mode */
@media(prefers-color-scheme:dark){
  :root{--ch:#F0EDE8;--emergency-bg:#3A1515;--emergency-border:#6B2020;--emergency-text:#F5A0A0}
  body{background:#141312}
  .site{background:#1A1816}
  .top{background:#1A1816;border-color:#2A2825}
  nav.main{background:var(--p800)}
  .dropdown{background:#1E1C19;border-color:#2A2825}
  .dropdown a{color:#C0BCB4}
  .dropdown a:hover{background:#252320;color:#fff}
  .dropdown .dd-head{color:#E0DDD8}
  .dropdown .dd-sub{color:#A0A09A}
  .mobile-menu{background:#1A1816;border-color:#2A2825}
  .mobile-menu .mm-sub{background:#141312}
  .mobile-menu .mm-sub a{border-color:#2A2825;color:#A0A09A}
  .news-card,.info-card,.act-card,.team-card{background:#1E1C19;border-color:#2A2825}
  .about-card{background:linear-gradient(135deg,#1E1811,#1E1C19);border-color:#2A2825}
  .contact-card,.events-panel{border-color:#2A2825}
  .events-header{background:var(--p800)}
  .evt-item:hover,.qa-card:hover,.acc-head:hover,.faq-q:hover{background:#252320}
  .acc-head{background:#141312;border-color:#2A2825}
  .acc-body{background:#1A1816}
  .faq-q,.faq-a{background:#1A1816}
  .faq-q.open,.faq-a.open{background:#1E1C19}
  .hours-block,.doc-list{border-color:#2A2825}
  .hours-row{border-color:#2A2825}
  .hours-row:nth-child(even){background:#141312}
  .swim-alt{background:#141312!important}
  .cal-nav{background:var(--p800)}
  .cal-grid-wrap,.cal-month-events{border-color:#2A2825}
  .cal-dow{background:#141312;border-color:#2A2825}
  .cal-cell{border-color:#2A2825}
  .cal-cell.other-month{background:#141312}
  .cal-cell.other-month .cal-cell-num{color:#3A3835}
  .cal-dot.open{background:#0D2B1A;color:var(--p200)}
  .cal-dot.board{background:#3A332B;color:#D3C7B8}
  .cal-dot.required{background:#281A08;color:var(--c200)}
  .cal-no-events{background:#1A1816}
  .chatbot-panel{background:#1A1816;border-color:#2A2825}
  .feedback-panel{background:#1A1816;border-color:#2A2825}
  .feedback-body textarea,.feedback-body input[type=email]{background:#252320;color:#D0CCC8;border-color:#3A3835}
  .chat-bubble.bot{background:#252320;color:#D0CCC8}
  .chat-verify-form{background:#1E1C19;border-color:#2A2825}
  .chat-verify-in{background:#141312;color:var(--s200);border-color:#3A3835}
  .chat-verify-note{color:var(--s400)}
  .chat-link{background:rgba(255,255,255,.05);border-color:#3A3835;color:#D0CCC8}
  .chat-link:hover{background:rgba(255,255,255,.10);border-color:var(--p400);color:#fff}
  #legal-modal-box{background:#1A1816}
  #legal-modal-head{border-color:#2A2825}
  #legal-modal-head h2,#legal-modal-body h3{color:#F0EDE8}
  #legal-modal-body{color:#C0BCB4}
  #legal-modal-close{color:#7D7972}
  #legal-modal-close:hover{color:#fff;background:rgba(255,255,255,.08)}
  input,select,textarea{background:#252320!important;color:var(--ch)!important;border-color:#3A3835!important}
  .page-body table tbody tr:nth-child(even){background:#141312}
  .footer-bottom,.footer-col a,.footer-brand .addr{color:rgba(255,255,255,.65)}
  .page-body blockquote{background:#1E1C19;border-color:var(--c600);color:var(--s400)}
  .tt-form,.tt-section,.tt-check{background:#1E1C19;border-color:#2A2825}
  .tt-field input,.tt-field textarea{background:#141312!important;border-color:#2A2825;color:var(--s200)!important}
  .tt-field input[readonly],.tt-field textarea[readonly],.tt-field input[disabled]{background:#171614!important;color:var(--s400)!important}
  .tt-summary-card{background:#241e18;border-color:#3A3026}
  .tt-callout{background:#1A2128;border-left-color:var(--p500);color:var(--s200)}
  .tt-success{background:#102117;border-color:#22543d;color:#A7F3C0}
  /* Amenity detail panels — base rule at line ~866 is later in source, needs !important */
  .amen-detail-panel{background:#1E1C19!important;border-color:#2A2825!important}
  /* Community center / clubhouse cards */
  .csb-card{background:#1E1C19;border-color:#2A2825}
  /* Year-at-a-glance box */
  .yag-box{background:#1E1C19;border-color:#2A2825}
  /* Nudge bubbles */
  .feedback-nudge,.chat-nudge{background:#1E1C19;border-color:#2A2825}
  /* Chat quick-reply chips */
  .chat-chip{background:#252320;color:var(--s500);border-color:#3A3835}
  .chat-chip:hover{background:#2E2B28;border-color:var(--s400);color:var(--s700)}
  /* Contact card avatar circles — visible on dark bg */
  .team-card .avatar{background:#243A2A;color:#9AB89A;border-color:#3A5835}
  /* Document list and month separators — more visible on dark backgrounds */
  .qa-card{border-color:#3A3835}
  .cal-month-head{border-bottom-color:#3A5035}
  .doc-item{border-bottom-color:#3A3835}
  /* Calendar filter / month-nav buttons */
  .cal-btn{background:#252320;color:var(--s600);border-color:#3A3835}
  .cal-btn:hover{background:#2E2B28;border-color:var(--s400)}
  /* Community map overlay */
  .community-map-controls{background:rgba(26,24,22,.96);color:var(--s600)}
  .community-map-shell{background:#1A1816}
}

/* Win 15 · Reduced motion — respects user OS preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal.visible{opacity:1;transform:none;transition:none}
  .page.active{animation:none}
}

/* ── Page fade-in on SPA navigation ── */
@keyframes pageFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page.active{animation:pageFade .22s ease forwards}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.reveal.visible{opacity:1;transform:none}

/* ── Tablet: 2-col layouts (769px–1100px) ── */
@media(max-width:1100px) and (min-width:769px){
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
}

/* ── Grid calendar ── */
.event-cal{margin:20px 0}
.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--p600);border-radius:10px 10px 0 0;color:#fff}
.cal-nav h4{font-size:15px;font-weight:700;letter-spacing:.06em;margin:0}
.cal-nav-btn{background:none;border:none;color:rgba(255,255,255,.7);font-size:18px;cursor:pointer;padding:6px 10px;border-radius:4px;transition:.15s;display:flex;align-items:center;font-family:inherit}
.cal-nav-btn:hover{color:#fff;background:rgba(255,255,255,.12)}
.cal-grid-wrap{border:1px solid var(--s100);border-top:none;overflow:hidden}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);background:var(--s50);border-bottom:1px solid var(--s100)}
.cal-dow span{text-align:center;font-size:11px;font-weight:700;letter-spacing:.05em;color:var(--s400);padding:7px 0}
.cal-cells{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-cell{min-height:80px;padding:6px;border-right:1px solid var(--s100);border-top:1px solid var(--s100)}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell.other-month{background:var(--s50)}
.cal-cell.other-month .cal-cell-num{color:var(--s200)}
.cal-cell-num{font-size:13px;font-weight:700;color:var(--s600);margin-bottom:3px;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.cal-cell.today .cal-cell-num{background:var(--c500);color:#fff;border-radius:50%}
.cal-dot{display:block;font-size:10px;font-weight:700;padding:2px 5px;border-radius:3px;margin-bottom:2px;overflow:hidden;cursor:default;line-height:1.4}
.cal-dot-title{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-dot-meta{display:block;font-size:9px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.75;margin-top:1px}
.cal-dot.open{background:var(--p50);color:var(--p700)}
.cal-dot.required{background:var(--c50);color:var(--c700)}
.cal-dot.members{background:var(--emergency-bg);color:var(--emergency-text)}
.cal-dot.tbd{background:var(--s100);color:var(--s500)}
.cal-dot.board{background:#D3C7B8;color:var(--s700)}
.cal-dot.past{opacity:.35}
.cal-note{font-size:13px;color:var(--s600);margin-top:6px;line-height:1.6}
.cal-month-events{border:1px solid var(--s100);border-top:none;border-radius:0 0 10px 10px;overflow:hidden}
.cal-month-events .cal-event{padding:14px 20px}
.cal-no-events{padding:24px;text-align:center;color:var(--s400);font-size:14px}
@media(max-width:768px){
  .cal-cell{aspect-ratio:1;height:auto;min-height:0;overflow:hidden;padding:3px 2px}
  .cal-dow span{font-size:9px;padding:6px 0;letter-spacing:0}
  .cal-cell-num{font-size:12px;width:18px;height:18px}
  .cal-dot{font-size:0;width:9px;height:9px;border-radius:50%;padding:0;display:inline-block;margin:0 1px 2px;vertical-align:middle}
  .cal-dot.open{background:var(--p400)}
  .cal-dot.required{background:var(--c400)}
  .cal-dot.members{background:var(--r)}
  .cal-dot.tbd{background:var(--s400)}
  .cal-dot.board{background:#D3C7B8}
  .cal-dot-title,.cal-dot-meta{display:none}
}
@media(prefers-color-scheme:dark){
  .cal-cell.other-month{background:#141312}
  .cal-cell.other-month .cal-cell-num{color:#3A3835}
}

/* ── Badge utility system ── */
.badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;padding:3px 8px;border-radius:4px;text-transform:uppercase;white-space:nowrap;vertical-align:middle}
.badge-pine{background:var(--p50);color:var(--p700);border:1px solid var(--p100)}
.badge-copper{background:var(--c50);color:var(--c700);border:1px solid var(--c100)}
.badge-stone{background:var(--s100);color:var(--s600);border:1px solid var(--s200)}
.badge-ok{background:#eaf5f0;color:var(--ok);border:1px solid #b5ddc8}
.badge-warn{background:#fef8e8;color:var(--warn);border:1px solid #f5da8a}
.badge-risk{background:var(--emergency-bg);color:var(--emergency-text);border:1px solid var(--emergency-border)}

/* ── Search bar (expanding header) ── */
#search-bar{flex:0 0 100%;order:100;max-height:0;overflow:hidden;background:var(--p600);border-top:1px solid rgba(255,255,255,.08);transition:max-height .35s cubic-bezier(.16,1,.3,1)}
nav.main.search-open #search-bar{max-height:600px}
#search-bar-inner{width:100%;margin:0 auto;padding:22px var(--mx) 26px}
#search-bar-row{display:flex;align-items:center;gap:14px;border-bottom:2px solid rgba(255,255,255,.15);padding-bottom:16px;margin-bottom:20px}
#search-bar-icon{font-size:20px;color:rgba(255,255,255,.5);flex-shrink:0}
#search-input{flex:1;border:none;outline:none;font-size:24px;font-family:inherit;color:#fff;background:transparent;min-width:0}
#search-input::placeholder{color:rgba(255,255,255,.35);font-weight:300}
#search-cancel{font-size:15px;font-weight:600;color:rgba(255,255,255,.7);background:none;border:none;cursor:pointer;padding:4px 0;font-family:inherit;transition:.15s;flex-shrink:0;white-space:nowrap}
#search-cancel:hover{color:#fff}
.search-ql-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:10px}
.search-ql-grid{display:flex;flex-wrap:wrap;gap:8px}
.search-ql{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit}
.search-ql:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
.search-ql i{font-size:13px;opacity:.75}
#search-results{max-height:360px;overflow-y:auto}
.sr-empty{padding:20px 0;text-align:center;color:rgba(255,255,255,.5);font-size:14px}
.sr-item{display:flex;align-items:center;gap:14px;padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.07);border-radius:6px;transition:background .1s}
.sr-item:last-child{border-bottom:none}
.sr-item:hover,.sr-item.sr-active{background:rgba(255,255,255,.08)}
.sr-icon{width:30px;height:30px;border-radius:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(255,255,255,.75);flex-shrink:0}
.sr-icon.doc{background:rgba(220,80,40,.2);border-color:rgba(220,80,40,.3);color:#FF8870}
.sr-body{flex:1;min-width:0}
.sr-title{font-size:15px;font-weight:700;color:#fff;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-title mark{background:transparent;color:#9FD4B0;font-weight:900}
.sr-meta{display:flex;align-items:center;gap:6px;margin-top:2px}
.sr-sub{font-size:13px;color:rgba(255,255,255,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.sr-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:3px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.7);text-transform:uppercase;flex-shrink:0}
.nav-search-box.search-active{background:rgba(255,255,255,.22);color:#fff}
#search-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s ease}
#search-backdrop.open{opacity:1;pointer-events:auto}
@media(max-width:768px){
  #search-bar-inner{padding:14px 16px 18px}
  #search-input{font-size:20px}
  .search-ql-grid{gap:6px}
  .search-ql{font-size:13px;padding:6px 12px}
  #search-results{max-height:280px}
}
@media(prefers-color-scheme:dark){
  .sr-title mark{color:var(--p300)}
}


.amen-detail-panel {
  margin: 28px 0;
  background: #fff;
  border: 1px solid var(--s100);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  scroll-margin-top: 80px;
}

.amen-detail-media {
  position: relative;
  height: 420px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* On small phones the 420px container plus the narrow viewport rendered
   portrait (~310×420), which aggressively cropped landscape photos. Drop to
   220px so the image stays landscape on phones. */
@media (max-width: 600px) {
  .amen-detail-media { height: 220px; }
}

/* ── Pool Concessions ─────────────────────────────────────────────────────
   Category grid renders as 5 columns on desktop, collapsing to 3 then 2 then
   1 on smaller viewports. Each card mirrors the menu structure: category
   title, one or more groups with optional title+price, and a list of items
   each with an optional per-item price override. */
.conc-hero {
  margin: 16px 0 20px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-1);
  background-size: cover;
  background-position: center;
  height: 240px;
}
.conc-hero[data-img=""] { display: none; }
@media (max-width: 768px) { .conc-hero { height: 160px; } }
.conc-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0 24px;
  align-items: start;
}
@media (max-width: 1100px) { .conc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .conc-grid { grid-template-columns: 1fr; } }

.conc-cat {
  background: #fff;
  border: 1px solid var(--s100);
  border-radius: 12px;
  padding: 16px 18px 18px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.conc-cat-title {
  font-size: 16px;
  font-weight: 900;
  letter-spacing: .08em;
  color: var(--p700);
  text-transform: uppercase;
  margin: 0 0 4px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--p100);
}
.conc-group { margin: 0; }
.conc-group + .conc-group { margin-top: 4px; }
.conc-group-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 4px;
}
.conc-group-title {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
  color: var(--c600, #a0722a);
  text-transform: uppercase;
}
.conc-group-price {
  font-size: 13px;
  font-weight: 700;
  color: var(--c500);
}
.conc-items {
  list-style: none;
  margin: 0;
  padding: 0 0 0 4px;
}
/* Once a group has 6+ items (CHIPS, CANDY), flow them into two columns inside
   the card. Halves the vertical footprint of the snacks card, which was the
   main source of card-height imbalance across the desktop grid. */
.conc-items:has(li:nth-child(6)) {
  columns: 2;
  column-gap: 16px;
}
.conc-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  font-size: 13.5px;
  color: var(--s600);
  line-height: 1.55;
  padding: 1px 0;
  /* Don't let the 2-column flow split a single name across columns. */
  break-inside: avoid;
}
.conc-item-name { flex: 1; }
.conc-item-price {
  font-size: 12px;
  font-weight: 700;
  color: var(--c500);
  white-space: nowrap;
}

.conc-footer-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 14px;
  margin: 12px 0 16px;
}
@media (max-width: 768px) { .conc-footer-grid { grid-template-columns: 1fr; } }
.conc-hours-block {
  background: #fff;
  border: 1px solid var(--s100);
  border-radius: 12px;
  padding: 12px 16px;
  box-shadow: var(--shadow-1);
}
.conc-hours-block .conc-cat-title { font-size: 14px; margin-bottom: 6px; padding-bottom: 6px; }
.conc-hours-list {
  list-style: none;
  margin: 0 0 8px;
  padding: 0;
}
.conc-hours-list li {
  font-size: 13px;
  font-weight: 700;
  color: var(--c500);
  padding: 1px 0;
}
.conc-payment-note {
  font-size: 11px;
  color: var(--s500);
  font-style: italic;
  margin: 4px 0 0;
  line-height: 1.45;
}
.conc-footer-message {
  background: var(--p50);
  border: 1px solid var(--p100);
  border-radius: 12px;
  padding: 14px 18px;
  font-size: 15px;
  font-weight: 800;
  color: var(--p700);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: .02em;
}

.amen-detail-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.62) 0%, rgba(0,0,0,.22) 45%, transparent 72%);
  border-radius: 0;
  pointer-events: none;
}

.amen-detail-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 26px 30px;
  z-index: 1;
}

.amen-detail-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  margin-bottom: 8px;
}

.amen-detail-overlay h3 {
  margin: 0;
  font-size: 34px;
  line-height: 1.05;
  color: #fff;
  text-shadow: 0 1px 6px rgba(0,0,0,.35);
}

.amen-detail-body {
  padding: 28px 32px 32px;
}

.amen-detail-desc {
  margin: 0 0 14px;
  font-size: 18px;
  line-height: 1.65;
  color: var(--s700);
  font-weight: 500;
}

.amen-detail-copy {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: var(--s500);
}

.amen-card.active {
  outline: 3px solid var(--c500);
  outline-offset: 3px;
  animation: amenOutlineFade 3s ease forwards;
}
@keyframes amenOutlineFade {
  0%, 45% { outline-color: var(--c500); }
  100%     { outline-color: transparent; }
}

.amen-highlight {
  animation: amenHighlight 1.2s ease;
}

@keyframes amenHighlight {
  0% {
    box-shadow: 0 0 0 0 rgba(160, 114, 42, 0.35);
  }
  100% {
    box-shadow: 0 0 0 18px rgba(160, 114, 42, 0);
  }
}

@media (max-width: 900px) {
  .amen-detail-panel {
    scroll-margin-top: 96px;
  }

  .amen-detail-media {
    height: 300px;
  }

  .amen-detail-overlay {
    padding: 20px 20px;
  }

  .amen-detail-overlay h3 {
    font-size: 26px;
  }

  .amen-detail-body {
    padding: 20px 20px 24px;
  }

  .amen-detail-desc {
    font-size: 16px;
  }
}

.community-map-wrapper {
  position: relative;
}

.community-map-shell {
  position: relative;
  width: 100%;
  min-height: 680px;
  border-radius: 12px;
  overflow: hidden;
  background: #f3f3f3;
}

.community-google-map {
  width: 100%;
  height: 100%;
}

.community-map-controls {
  position: absolute;
  top: 60px;
  left: 16px;
  /* Above Leaflet panes (tile 200, overlay/map 400, marker 600, tooltip 650,
     popup 700). At z-index 5 the map tiles painted over the legend, leaving it
     invisible and only flashing through during zoom redraws. */
  z-index: 1000;
  display: grid;
  gap: 8px;
  max-width: 260px;
  max-height: calc(100% - 80px);
  overflow-y: auto;
  padding: 14px 16px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.16);
  font-size: 14px;
  font-weight: 600;
}

.community-map-controls label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.cal-btn {
  padding: 2px 7px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.6;
  border: 1px solid var(--s400);
  border-radius: 4px;
  background: var(--s50);
  cursor: pointer;
  color: var(--s700);
}
.cal-btn:active { background: var(--s200); }

@media (max-width: 768px) {
  .community-map-shell { min-height: 480px; }
  .community-map-controls {
    position: static;
    max-width: none;
    border-radius: 0 0 12px 12px;
    font-size: 13px;
    padding: 10px 14px;
    gap: 6px;
  }
}


/* ── Member Services ──────────────────────────────────────────────────────
   Service entries on Resources page reuse the .acc-group / .acc-head /
   .acc-body chrome from the documents list, so toggling and chevron
   behaviour come for free. The inner .ms-body block adds structured
   formatting for schedule/location/rules/contact fields. */
.ms-section-intro {
  font-size: 15px;
  color: var(--s500);
  margin-bottom: 16px;
}
.ms-list .acc-group { margin-bottom: 12px; }
.ms-body { padding: 18px 20px 20px; }
.ms-item-intro {
  font-size: 15px;
  color: var(--s600);
  line-height: 1.65;
  margin: 0 0 16px;
}
.ms-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 16px;
}
@media (max-width: 680px) { .ms-grid { grid-template-columns: 1fr; } }
.ms-field {
  background: var(--s50);
  border: 1px solid var(--s100);
  border-radius: 8px;
  padding: 12px 14px;
}
.ms-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--p600);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.ms-label i { margin-right: 6px; }
.ms-field-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 6px;
}
.ms-field-head .ms-label { margin-bottom: 0; }
.ms-field-head .ms-map-link { margin-top: 0; font-size: 12px; }
.ms-value {
  font-size: 14px;
  color: var(--s700, #2a2a2a);
  line-height: 1.5;
}
.ms-map-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--c500);
  text-decoration: none;
}
.ms-map-link:hover { text-decoration: underline; }
.ms-important {
  background: rgba(255, 250, 235, 0.7);
  border-left: 3px solid #d97706;
  border-radius: 0 8px 8px 0;
  padding: 12px 16px;
  margin-bottom: 14px;
}
.ms-important .ms-label { color: #9a3412; }
.ms-important p {
  font-size: 14px;
  color: var(--s600);
  line-height: 1.6;
  margin: 0 0 8px;
}
.ms-important p:last-child { margin-bottom: 0; }
.ms-prohibited {
  background: rgba(220, 38, 38, 0.06);
  border-radius: 6px;
  padding: 10px 14px;
  color: #7f1d1d !important;
}
.ms-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--s100);
  font-size: 14px;
}
.ms-contact { color: var(--s600); }
.ms-contact a { color: var(--c500); text-decoration: none; font-weight: 700; }
.ms-contact a:hover { text-decoration: underline; }
.ms-flyer-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--c500);
  font-weight: 700;
  text-decoration: none;
  font-size: 13px;
}
.ms-flyer-link i { font-size: 16px; }
.ms-flyer-link:hover { text-decoration: underline; }
@media (max-width: 600px) {
  .ms-footer { flex-direction: column; align-items: flex-start; }
}
