/* ============================================================
   Texas Nursing Home Guide — Global Stylesheet
   Mobile-first, performance-optimised
   ============================================================ */

/* --- Reset & base ------------------------------------------ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:18px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  background:#f5f5f3;color:#222;line-height:1.55;min-height:100vh}
img{max-width:100%;height:auto;display:block}
a{color:#185FA5;text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer;font-family:inherit}

/* --- Utility ----------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 16px}

/* --- Nav --------------------------------------------------- */
.site-nav{background:#fff;border-bottom:1px solid #e8e8e4;position:sticky;top:0;z-index:100}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:52px;gap:12px}
.nav-brand{display:flex;align-items:center;gap:9px;text-decoration:none}
.nav-logo{width:30px;height:30px;background:#1B4F72;border-radius:7px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-logo svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.brand-text .brand-name{font-size:15px;font-weight:700;color:#1B4F72;line-height:1.1}
.brand-text .brand-sub{font-size:11px;color:#999;display:none}
.nav-links{display:none;align-items:center;gap:20px}
.nav-links a{font-size:14px;color:#555;transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:#1B4F72;text-decoration:none}
.nav-cta{background:#1B4F72;color:#fff!important;padding:7px 14px;
  border-radius:7px;font-size:14px;font-weight:600;white-space:nowrap}
.nav-cta:hover{background:#154060;text-decoration:none}
.nav-hamburger{background:none;border:none;padding:4px;display:flex;flex-direction:column;
  gap:5px;width:30px}
.nav-hamburger span{display:block;height:2px;background:#333;border-radius:2px;transition:.2s}

/* Mobile nav drawer */
.nav-drawer{display:none;flex-direction:column;background:#fff;
  border-top:1px solid #e8e8e4;padding:12px 16px 16px}
.nav-drawer.open{display:flex}
.nav-drawer a{font-size:14px;color:#333;padding:10px 0;
  border-bottom:1px solid #f0f0ec;text-decoration:none}
.nav-drawer a:last-child{border:none}
.nav-drawer .nav-cta{margin-top:8px;text-align:center;padding:10px}

/* --- Hero -------------------------------------------------- */
.hero{background:#0D3349;position:relative;overflow:hidden}
.hero-inner{display:flex;align-items:flex-end;justify-content:space-between;
  padding:28px 16px 0;position:relative;z-index:2;gap:16px}
.hero-content{flex:1;padding-bottom:28px;min-width:0}
.hero-photo{flex-shrink:0;align-self:flex-end;display:none}
.hero-photo img{width:260px;object-fit:contain;object-position:bottom}

.lone-star{position:absolute;top:-20px;right:-20px;opacity:.06;pointer-events:none;
  width:260px;height:auto}

.tag-pill{display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.12);padding:4px 11px;border-radius:20px;margin-bottom:12px}
.tag-pill svg{width:10px;height:10px;fill:#7EC8A4;flex-shrink:0}
.tag-pill span{font-size:12px;color:#A8D8C4;font-weight:500}

.hero h1{font-size:24px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:10px}
.hero-sub{font-size:15px;color:rgba(255,255,255,.65);line-height:1.65;margin-bottom:20px;
  max-width:400px}

.search-wrap{display:flex;gap:8px;margin-bottom:12px}
.search-box{flex:1;background:rgba(255,255,255,.94);border-radius:8px;
  display:flex;align-items:center;gap:8px;padding:0 11px;height:42px;min-width:0}
.search-box svg{width:15px;height:15px;flex-shrink:0;stroke:#aaa;fill:none;stroke-width:2}
.search-box input{border:none;background:transparent;font-size:15px;color:#333;
  outline:none;flex:1;min-width:0;width:100%}
.search-box input::placeholder{color:#aaa}
.search-btn{background:#2EBD82;color:#fff;border:none;padding:0 16px;
  border-radius:8px;font-size:15px;font-weight:600;height:42px;white-space:nowrap;
  transition:background .15s}
.search-btn:hover{background:#25a870}

.filter-chips{display:flex;gap:6px;flex-wrap:wrap}
.fchip{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  padding:4px 10px;border-radius:20px;font-size:12px;color:rgba(255,255,255,.78);
  cursor:pointer;transition:.15s;white-space:nowrap}
.fchip:hover,.fchip.active{background:rgba(255,255,255,.22)}

/* --- Stats bar --------------------------------------------- */
.stats-bar{background:#0A2436;border-bottom:1px solid rgba(255,255,255,.06);padding:16px 0}
.stats-row{display:grid;grid-template-columns:repeat(5,1fr);text-align:center}
.stat{padding:0 4px}
.stat+.stat{border-left:1px solid rgba(255,255,255,.08)}
.stat-val{font-size:26px;font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.02em}
.stat-val.warn{color:#FFAA2B}
.stat-val.good{color:#3ECFA0}
.stat-lbl{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px;
  text-transform:uppercase;letter-spacing:.04em}

/* --- Attorney banners -------------------------------------- */
.atty-banner{background:#FFF8EC;border-bottom:1px solid #F0D080;padding:10px 0}
.atty-banner-inner{display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap}
.atty-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.atty-icon{width:36px;height:36px;border-radius:50%;background:#1B4F72;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.atty-icon svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.atty-eyebrow{font-size:12px;color:#8A6800;text-transform:uppercase;
  letter-spacing:.04em;margin-bottom:1px}
.atty-name{font-size:15px;font-weight:700;color:#1B4F72}
.atty-sub{font-size:13px;color:#666}
.atty-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.atty-dots{display:flex;gap:4px;align-items:center}
.dot{width:7px;height:7px;border-radius:50%;cursor:pointer;
  transition:background .2s;border:none;padding:0}
.dot.active{background:#1B4F72}
.dot.inactive{background:#ccc}

.atty-bottom{background:#0D2E42;border-top:1px solid #1A4A6A;padding:14px 0}
.atty-bottom-inner{display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap}
.atty-b-icon{width:44px;height:44px;border-radius:50%;background:#C0392B;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.atty-b-icon svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.8}
.atty-b-eyebrow{font-size:12px;color:#7EC8A4;text-transform:uppercase;
  letter-spacing:.04em;margin-bottom:2px}
.atty-b-name{font-size:16px;font-weight:700;color:#fff;margin-bottom:1px}
.atty-b-sub{font-size:13px;color:rgba(255,255,255,.5)}
.atty-b-btns{display:flex;gap:8px;align-items:center;flex-shrink:0;flex-wrap:wrap}
.b-dots .dot.active{background:#fff}
.b-dots .dot.inactive{background:rgba(255,255,255,.3)}

/* --- Buttons ----------------------------------------------- */
.btn-outline{font-size:13px;font-weight:500;color:#1B4F72;
  border:1px solid #1B4F72;padding:6px 13px;border-radius:7px;
  background:transparent;white-space:nowrap;transition:.15s}
.btn-outline:hover{background:#e8f0f7}
.btn-red{font-size:13px;font-weight:600;color:#fff;background:#C0392B;
  padding:6px 13px;border-radius:7px;border:none;white-space:nowrap;transition:.15s}
.btn-red:hover{background:#a52e23}
.btn-ghost{font-size:13px;font-weight:500;color:#fff;
  border:1px solid rgba(255,255,255,.3);padding:7px 14px;
  border-radius:7px;background:transparent;white-space:nowrap;transition:.15s}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-red-solid{font-size:13px;font-weight:600;color:#fff;background:#C0392B;
  padding:7px 14px;border-radius:7px;border:none;white-space:nowrap;transition:.15s}
.btn-red-solid:hover{background:#a52e23}

/* --- Main layout ------------------------------------------- */
.main-layout{display:flex;flex-direction:column;gap:18px;padding:18px 0}

/* --- Tabs -------------------------------------------------- */
.tabs{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.tab{padding:7px 16px;border-radius:7px;font-size:14px;cursor:pointer;
  border:1px solid transparent;color:#666;background:transparent;transition:.15s}
.tab.active{background:#fff;border-color:#ddd;color:#1B4F72;font-weight:600}
.tab:hover:not(.active){background:#f0f0ec}

.featured-note{background:#FFF3E0;border:1px solid #F0C060;border-radius:7px;
  padding:8px 12px;margin-bottom:12px;font-size:13px;color:#92620A;line-height:1.5}

/* --- Facility cards ---------------------------------------- */
.cards{display:flex;flex-direction:column;gap:12px}
.card{background:#fff;border:1px solid #e4e4e0;border-radius:12px;
  padding:14px;cursor:pointer;transition:border-color .15s,transform .1s;
  position:relative;text-decoration:none;display:block;color:inherit}
.card:hover{border-color:#aaa;text-decoration:none;transform:translateY(-1px)}
.card.sponsored{border:2px solid #F0C060}
.card.flagged{border-color:#E24B4A}
.sponsored-tag{position:absolute;top:11px;right:11px;background:#FFF3E0;
  color:#B45309;border:1px solid #F0C060;border-radius:4px;
  font-size:9px;font-weight:700;padding:2px 7px;letter-spacing:.06em}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;
  gap:10px;margin-bottom:10px}
.card-meta{flex:1;min-width:0}
.badges{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:5px}
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;
  border-radius:20px;font-size:12px;font-weight:600}
.badge.green{background:#EAF3DE;color:#27500A;border:1px solid #97C459}
.badge.blue{background:#E6F1FB;color:#0C447C;border:1px solid #85B7EB}
.badge.red{background:#FCEBEB;color:#791F1F;border:1px solid #F09595}
.badge.amber{background:#FAEEDA;color:#633806;border:1px solid #EF9F27}
.card-name{font-size:16px;font-weight:700;color:#1a1a1a;margin-bottom:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-loc{font-size:13px;color:#888}
.card-rating{text-align:right;flex-shrink:0}
.rating-num{font-size:24px;font-weight:700;line-height:1}
.rating-num.g{color:#27500A}
.rating-num.b{color:#185FA5}
.rating-num.r{color:#A32D2D}
.rating-num.na{color:#aaa;font-size:16px}
.stars{font-size:13px;letter-spacing:1px;margin:2px 0}
.star-on{color:#E8A838}
.star-off{color:#ddd}
.rating-lbl{font-size:11px;color:#aaa;text-transform:uppercase;letter-spacing:.04em}
.card-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:#f8f8f5;border-radius:8px;overflow:hidden}
.cs-item{text-align:center;padding:8px 4px}
.cs-item+.cs-item{border-left:1px solid #efefeb}
.cs-val{font-size:15px;font-weight:700}
.cs-val.g{color:#27500A}
.cs-val.b{color:#185FA5}
.cs-val.r{color:#A32D2D}
.cs-val.na{color:#aaa}
.cs-lbl{font-size:11px;color:#aaa;text-transform:uppercase;letter-spacing:.02em;margin-top:1px}
.alert-bar{margin-top:9px;padding:6px 10px;background:#FCEBEB;border-radius:6px;
  border:1px solid #F09595;font-size:13px;color:#791F1F;line-height:1.4}
.view-all{text-align:center;margin-top:14px;font-size:14px;
  color:#185FA5;cursor:pointer;padding:8px}
.view-all:hover{text-decoration:underline}

/* --- Sidebar ----------------------------------------------- */
.sidebar{display:flex;flex-direction:column;gap:12px}
.side-card{background:#fff;border:1px solid #e4e4e0;border-radius:12px;padding:14px}
.side-title{font-size:12px;font-weight:700;color:#aaa;text-transform:uppercase;
  letter-spacing:.07em;margin-bottom:10px}
.county-row{display:flex;justify-content:space-between;align-items:center;
  padding:6px 0;border-bottom:1px solid #f4f4f0;cursor:pointer;
  font-size:14px;color:#333;transition:color .1s}
.county-row:last-child{border:none}
.county-row:hover{color:#185FA5}
.county-count{background:#f5f5f3;padding:2px 8px;border-radius:20px;
  font-size:12px;color:#888}
.bar-row{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.bar-stars{font-size:13px;color:#E8A838;width:80px;flex-shrink:0}
.bar-track{flex:1;height:7px;background:#f0f0ec;border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px}
.bar-count{font-size:12px;color:#aaa;width:26px;text-align:right;flex-shrink:0}
.guide-row{display:flex;align-items:center;gap:9px;margin-bottom:10px;cursor:pointer}
.guide-row:last-child{margin-bottom:0}
.guide-icon{width:28px;height:28px;border-radius:7px;display:flex;
  align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.guide-name{font-size:14px;font-weight:600;color:#333}
.guide-time{font-size:12px;color:#aaa}

/* --- Site map cards ---------------------------------------- */
.sitemap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:10px}
.sm-card{background:#fff;border:1px solid #e4e4e0;border-radius:10px;padding:12px;
  font-size:12px}
.sm-icon{font-size:16px;margin-bottom:6px}
.sm-name{font-weight:700;color:#333;margin-bottom:3px}
.sm-desc{font-size:10px;color:#aaa;line-height:1.4}

/* --- Footer ------------------------------------------------ */
.site-footer{background:#fff;border-top:1px solid #e8e8e4;padding:12px 0;margin-top:0}
.footer-inner{display:flex;flex-direction:column;gap:4px;align-items:center;
  text-align:center;font-size:13px;color:#aaa}

/* ============================================================
   RESPONSIVE — tablet and up (≥640px)
   ============================================================ */
@media(min-width:640px){
  .container{padding:0 24px}
  .brand-text .brand-sub{display:block}
  .hero h1{font-size:26px}
  .hero-photo{display:flex}
  .stat-val{font-size:19px}
  .stat-lbl{font-size:10px}
  .atty-banner-inner{flex-wrap:nowrap}
  .main-layout{flex-direction:row;align-items:flex-start}
  .main-col{flex:1;min-width:0}
  .sidebar{width:260px;flex-shrink:0}
  .sitemap-grid{grid-template-columns:repeat(3,1fr)}
  .footer-inner{flex-direction:row;justify-content:space-between}
}

/* ============================================================
   RESPONSIVE — desktop (≥900px)
   ============================================================ */
@media(min-width:900px){
  .container{padding:0 32px}
  .nav-links{display:flex}
  .nav-hamburger{display:none}
  .hero-inner{padding:36px 0 0}
  .hero-photo img{width:240px}
  .hero h1{font-size:28px}
  .stats-row{padding:0 4px}
  .sitemap-grid{grid-template-columns:repeat(3,1fr)}
}

.panel-hidden{display:none!important}
