/* =============================================================
   AZ Tiny Life — Theme CSS v1.0
   Sections:
   1. Reset & Base
   2. Typography
   3. Site Layout
   4. Header & Navigation
   5. Footer
   6. Blog styles
   7. Search / 404
   8. Breadcrumb
   9. Utility
   10. AZ Tiny Life Design System (global.css — aztl-* classes)
   11. Responsive
   ============================================================= */

/* ──────────────────────────────────────────────────────────────
   1. RESET & BASE
   ────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
  color: #334155;
  background: #fff;
  -webkit-font-smoothing: antialiased;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: #2d6a4f; }
a:hover { color: #1b4332; }
ul, ol { margin: 0; padding: 0; }
p { margin: 0 0 1rem; }
h1,h2,h3,h4,h5,h6 { margin: 0 0 .6rem; line-height: 1.25; color: #0f172a; font-weight: 700; }
h1 { font-size: clamp(1.6rem, 4vw, 2.6rem); }
h2 { font-size: clamp(1.3rem, 3vw, 2rem); }
h3 { font-size: 1.2rem; }
input, button, textarea, select { font: inherit; }

.skip-link { position: absolute; top: -40px; left: 6px; padding: 8px 16px; background: #1b4332; color: #fff; border-radius: 0 0 6px 6px; font-size: 14px; font-weight: 700; text-decoration: none; z-index: 9999; transition: top .15s; }
.skip-link:focus { top: 0; }

/* ──────────────────────────────────────────────────────────────
   2. TYPOGRAPHY
   ────────────────────────────────────────────────────────────── */
.entry-content h2,
.entry-content h3,
.entry-content h4 { margin: 1.8rem 0 .6rem; }
.entry-content ul,
.entry-content ol  { padding-left: 1.4rem; margin-bottom: 1rem; }
.entry-content li  { margin-bottom: .3rem; }
.entry-content blockquote {
  border-left: 4px solid #f59e0b; margin: 1.5rem 0; padding: .8rem 1.2rem;
  background: #f8fafc; border-radius: 0 8px 8px 0; font-style: italic; color: #334155;
}
.entry-content code {
  background: #f1f5f9; padding: 2px 6px; border-radius: 4px;
  font-size: .88em; font-family: 'SFMono-Regular', Consolas, monospace;
}
.entry-content pre { background: #0f172a; color: #e2e8f0; padding: 1.2rem; border-radius: 8px; overflow-x: auto; }
.entry-content pre code { background: none; color: inherit; padding: 0; }
.entry-content table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; font-size: .94rem; }
.entry-content th,
.entry-content td { padding: 10px 14px; border: 1px solid #e2e8f0; text-align: left; }
.entry-content th { background: #f8fafc; font-weight: 700; }
.entry-content img { border-radius: 8px; }
.entry-content a { color: #2d6a4f; font-weight: 500; }
.entry-content a:hover { color: #1b4332; }

/* ──────────────────────────────────────────────────────────────
   3. SITE LAYOUT
   ────────────────────────────────────────────────────────────── */
.site-main { min-height: 60vh; }

/* Page template — full width (no sidebar) */
.page-main  { max-width: 100%; }
.front-main { max-width: 100%; }

/* Single listing page — no entry-content wrapper, listing CSS handles everything */
.th-listing-main { max-width: 100%; padding-top: 28px; }

/* Blog layout: main + sidebar */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  margin-top: 40px;
}
.blog-layout .blog-main { min-width: 0; }

/* ──────────────────────────────────────────────────────────────
   4. HEADER & NAVIGATION
   ────────────────────────────────────────────────────────────── */
.site-header {
  background: #1b4332;
  position: sticky;
  top: 0;
  z-index: 200;
  transition: box-shadow .2s;
}
.site-header.is-scrolled { box-shadow: 0 2px 24px rgba(0,0,0,.25); }

.aztl-header-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  height: 68px;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* Logo */
.site-branding { flex-shrink: 0; }
.aztl-logo {
  color: #fff;
  font-size: 1.35rem;
  font-weight: 900;
  text-decoration: none;
  letter-spacing: -.5px;
  display: flex;
  align-items: center;
  gap: 2px;
}
.aztl-logo-mark { color: #f59e0b; }
.custom-logo-link img { height: 40px; width: auto; }

/* Nav */
.site-nav { flex: 1; }
.aztl-nav-list {
  list-style: none;
  display: flex;
  gap: 2px;
  align-items: center;
}
.aztl-nav-list li { position: relative; }
.aztl-nav-list > li > a {
  color: rgba(255,255,255,.85);
  text-decoration: none;
  font-size: .93rem;
  font-weight: 500;
  padding: 8px 12px;
  border-radius: 6px;
  display: block;
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.aztl-nav-list > li > a:hover,
.aztl-nav-list > li.current-menu-item > a,
.aztl-nav-list > li.is-focused > a { color: #fff; background: rgba(255,255,255,.1); }

/* Sub-menu */
.aztl-nav-list .sub-menu {
  list-style: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0,0,0,.14);
  padding: 6px 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s;
  z-index: 100;
}
.aztl-nav-list li:hover > .sub-menu,
.aztl-nav-list li.is-focused > .sub-menu { opacity: 1; pointer-events: auto; transform: translateY(0); }
.aztl-nav-list .sub-menu a { color: #334155; font-size: .88rem; font-weight: 500; padding: 9px 16px; display: block; text-decoration: none; }
.aztl-nav-list .sub-menu a:hover { background: #f8fafc; color: #1b4332; }

/* Header CTA button */
.aztl-header-cta {
  flex-shrink: 0;
  background: #f59e0b;
  color: #0f172a !important;
  font-weight: 800;
  font-size: .88rem;
  padding: 9px 18px;
  border-radius: 8px;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s, transform .15s;
}
.aztl-header-cta:hover { background: #d97706; transform: translateY(-1px); }

/* Mobile toggle */
.aztl-nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  padding: 6px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 6px;
  cursor: pointer;
  flex-shrink: 0;
}
.aztl-toggle-bar {
  display: block;
  height: 2px;
  background: rgba(255,255,255,.85);
  border-radius: 2px;
  transition: transform .25s, opacity .25s;
}
.aztl-nav-toggle.is-active .aztl-toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.aztl-nav-toggle.is-active .aztl-toggle-bar:nth-child(2) { opacity: 0; }
.aztl-nav-toggle.is-active .aztl-toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ──────────────────────────────────────────────────────────────
   5. FOOTER
   ────────────────────────────────────────────────────────────── */
.site-footer {
  background: #0d2b1e;
  color: rgba(255,255,255,.7);
  margin-top: 72px;
}
.aztl-footer-inner { max-width: 1280px; margin: 0 auto; padding: 60px 24px 28px; }

.aztl-footer-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.aztl-footer-logo {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  color: #fff;
  font-size: 1.25rem;
  font-weight: 900;
  text-decoration: none;
  margin-bottom: 14px;
}
.aztl-footer-tagline { font-size: .85rem; line-height: 1.6; margin-bottom: 16px; max-width: 280px; }

.aztl-footer-social { display: flex; gap: 8px; }
.aztl-social-link {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.8);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 800;
  text-decoration: none; transition: background .2s;
}
.aztl-social-link:hover { background: #f59e0b; color: #0f172a; }

.footer-widget-title { font-size: .8rem; font-weight: 800; color: #fff; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
.aztl-footer-links { list-style: none; }
.aztl-footer-links li { margin-bottom: 8px; }
.aztl-footer-links a { color: rgba(255,255,255,.65); font-size: .88rem; text-decoration: none; transition: color .15s; }
.aztl-footer-links a:hover { color: #f59e0b; }

/* Footer nav */
.aztl-footer-nav-wrap { margin-bottom: 20px; }
.aztl-footer-nav { list-style: none; display: flex; flex-wrap: wrap; gap: 6px 20px; }
.aztl-footer-nav a { color: rgba(255,255,255,.55); font-size: .82rem; text-decoration: none; }
.aztl-footer-nav a:hover { color: rgba(255,255,255,.9); }

/* Footer bottom */
.aztl-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 10px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.07);
}
.aztl-footer-copy { font-size: .8rem; margin: 0; }
.aztl-footer-copy a { color: rgba(255,255,255,.65); text-decoration: none; }
.aztl-footer-copy a:hover { color: #f59e0b; }
.aztl-footer-legal { list-style: none; display: flex; gap: 16px; }
.aztl-footer-legal a { color: rgba(255,255,255,.45); font-size: .78rem; text-decoration: none; }
.aztl-footer-legal a:hover { color: rgba(255,255,255,.8); }

/* ──────────────────────────────────────────────────────────────
   6. BLOG STYLES
   ────────────────────────────────────────────────────────────── */
.blog-archive-header { margin-bottom: 32px; }
.blog-archive-title { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 900; color: #1b4332; }
.blog-archive-desc  { color: #64748b; font-size: .95rem; margin-top: 6px; }

/* Post card grid */
.blog-post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 28px; }

.blog-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 14px rgba(0,0,0,.06);
  transition: transform .2s, box-shadow .2s;
  display: flex; flex-direction: column;
}
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 8px 32px rgba(0,0,0,.1); }
.blog-card-thumb { display: block; aspect-ratio: 16/9; overflow: hidden; }
.blog-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.blog-card:hover .blog-card-thumb img { transform: scale(1.04); }
.blog-card-body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.blog-card-meta { font-size: .78rem; color: #64748b; margin-bottom: 8px; }
.blog-card-meta a { color: #2d6a4f; text-decoration: none; font-weight: 600; }
.blog-card-title { font-size: 1.05rem; font-weight: 800; margin: 0 0 10px; line-height: 1.3; }
.blog-card-title a { color: #0f172a; text-decoration: none; }
.blog-card-title a:hover { color: #1b4332; }
.blog-card-excerpt { font-size: .88rem; color: #64748b; line-height: 1.6; margin-bottom: 16px; flex: 1; }
.blog-card-more { font-size: .88rem; font-weight: 700; color: #2d6a4f; text-decoration: none; }
.blog-card-more:hover { color: #1b4332; text-decoration: underline; }

/* Single post */
.blog-post-single { max-width: 780px; }
.post-header { margin-bottom: 28px; }
.post-title { font-size: clamp(1.5rem, 4vw, 2.4rem); font-weight: 900; color: #0f172a; margin: 10px 0 14px; line-height: 1.2; }
.post-meta { font-size: .82rem; color: #64748b; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.post-meta time { font-weight: 600; }
.post-meta .post-author a { color: #2d6a4f; text-decoration: none; font-weight: 600; }
.post-meta .post-cats a { background: #e8f5ef; color: #2d6a4f; padding: 2px 9px; border-radius: 20px; text-decoration: none; font-size: .75rem; font-weight: 700; }
.post-thumbnail { margin-bottom: 32px; border-radius: 12px; overflow: hidden; aspect-ratio: 16/9; }
.post-thumbnail img { width: 100%; height: 100%; object-fit: cover; }
.post-content { font-size: 1.025rem; line-height: 1.8; }
.post-tags { margin-top: 28px; font-size: .85rem; color: #64748b; }
.post-tags a { color: #2d6a4f; text-decoration: none; }

/* Post navigation */
.post-nav {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  margin-top: 40px; padding-top: 28px; border-top: 1px solid #e2e8f0;
  font-size: .88rem; font-weight: 600;
}
.post-nav a { color: #2d6a4f; text-decoration: none; }
.post-nav a:hover { color: #1b4332; }

/* Sidebar */
.blog-sidebar { font-size: .9rem; }
.widget { margin-bottom: 32px; }
.widget-title { font-size: .9rem; font-weight: 800; text-transform: uppercase; letter-spacing: .6px; color: #0f172a; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid #f59e0b; }
.widget ul { list-style: none; }
.widget ul li { padding: 5px 0; border-bottom: 1px solid #f1f5f9; font-size: .88rem; }
.widget ul li a { color: #334155; text-decoration: none; }
.widget ul li a:hover { color: #1b4332; }

/* Pagination */
.aztl-pagination { margin-top: 40px; }
.aztl-pagination .nav-links { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.aztl-pagination .page-numbers {
  padding: 8px 14px; border-radius: 6px; border: 1px solid #e2e8f0;
  color: #334155; text-decoration: none; font-size: .9rem; font-weight: 500;
}
.aztl-pagination .page-numbers.current { background: #1b4332; color: #fff; border-color: #1b4332; font-weight: 700; }
.aztl-pagination .page-numbers:hover:not(.current) { background: #f8fafc; }

/* ──────────────────────────────────────────────────────────────
   7. SEARCH / 404
   ────────────────────────────────────────────────────────────── */
.search-header { margin: 40px 0 28px; }
.search-title  { font-size: clamp(1.3rem, 3vw, 2rem); font-weight: 900; }
.search-title span { color: #2d6a4f; }

.error-404-page { text-align: center; padding: 60px 24px; }
.error-404-wrap { max-width: 540px; margin: 0 auto; }
.error-404-number { font-size: 120px; font-weight: 900; color: #e2e8f0; line-height: 1; margin-bottom: 8px; }
.error-404-title { font-size: 2rem; font-weight: 900; color: #1b4332; margin-bottom: 14px; }
.error-404-desc { color: #64748b; margin-bottom: 24px; font-size: 1.05rem; }
.error-404-links { margin-top: 36px; }
.error-404-links h2 { font-size: 1.1rem; font-weight: 700; color: #334155; margin-bottom: 14px; }

/* ──────────────────────────────────────────────────────────────
   8. BREADCRUMB (theme's breadcrumb above content)
   ────────────────────────────────────────────────────────────── */
.aztl-bc { font-size: .78rem; color: #64748b; margin-bottom: 12px; }
.aztl-bc ol { list-style: none; display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.aztl-bc li { display: flex; align-items: center; gap: 4px; }
.aztl-bc a { color: #2d6a4f; text-decoration: none; font-weight: 600; }
.aztl-bc a:hover { color: #1b4332; text-decoration: underline; }
.aztl-bc-sep { color: #cbd5e1; }
.aztl-bc [aria-current="page"] { color: #64748b; }

/* ──────────────────────────────────────────────────────────────
   9. UTILITY
   ────────────────────────────────────────────────────────────── */
.home-listings-section { background: #f8fafc; padding: 60px 0; margin-top: 0; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; clip: rect(1px,1px,1px,1px); overflow: hidden; }

/* Search form */
.search-form { display: flex; gap: 8px; max-width: 420px; }
.search-field {
  flex: 1; padding: 10px 14px; border: 1px solid #e2e8f0;
  border-radius: 8px; font-size: .94rem;
}
.search-field:focus { outline: 2px solid #2d6a4f; border-color: transparent; }
.search-submit {
  padding: 10px 18px; background: #1b4332; color: #fff;
  border: none; border-radius: 8px; font-size: .88rem; font-weight: 700; cursor: pointer;
  transition: background .2s;
}
.search-submit:hover { background: #2d6a4f; }

/* =============================================================
   10. AZ TINY LIFE DESIGN SYSTEM (global.css — aztl-* classes)
   Snippet #3478 replaced — now part of the theme.
   ============================================================= */

/* Box-sizing reset */
.aztl-page *,
.aztl-page *::before,
.aztl-page *::after { box-sizing: border-box; }

/* Root variables */
:root {
  --g:  #1b4332; --gm: #2d6a4f; --gl: #40916c;
  --gs: #e8f5ef; --a:  #f59e0b; --ah: #d97706;
  --b:  #0f172a; --bm: #334155; --bl: #64748b;
  --s:  #f8fafc; --w:  #ffffff; --br: #e2e8f0;
  --r:  12px;
  --sh:  0 4px 24px rgba(0,0,0,.08);
  --sh2: 0 8px 40px rgba(0,0,0,.14);
}

/* Page wrapper */
.aztl-page {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: var(--bm); line-height: 1.6;
  max-width: 1180px; margin: 0 auto; padding: 0 24px; width: 100%;
}

/* Intro grid */
.aztl-intro-grid { display:flex; flex-wrap:wrap; gap:28px; align-items:flex-start; margin-bottom:12px; }
.aztl-intro-text { flex:1 1 55%; min-width:260px; }
.aztl-intro-img  { flex:0 1 320px; min-width:220px; }
.aztl-intro-img img { width:100%; border-radius:var(--r); box-shadow:var(--sh); display:block; object-fit:cover; aspect-ratio:4/3; }

/* Hero */
.aztl-hero {
  background: linear-gradient(140deg,#0d2b1e 0%,var(--g) 45%,var(--gm) 100%);
  border-radius:var(--r); overflow:hidden; display:flex; flex-wrap:wrap;
  box-shadow:var(--sh2); margin-bottom:16px; position:relative;
}
.aztl-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 25% 60%,rgba(64,145,108,.22) 0%,transparent 55%);
  pointer-events:none;
}
.aztl-hero-left {
  flex:1 1 55%; min-width:280px; padding:52px 44px;
  display:flex; flex-direction:column; justify-content:center; position:relative; z-index:1;
}
.aztl-hero-form {
  flex:0 1 360px; min-width:280px; max-width:100%; background:white;
  display:flex; flex-direction:column; justify-content:center;
  padding:36px 30px; position:relative; z-index:1;
}
.aztl-hero-form::before {
  content:''; position:absolute; top:0; left:0; width:4px; height:100%; background:var(--a);
}
.aztl-breadcrumb { font-size:12px; color:rgba(255,255,255,.65); margin-bottom:14px; letter-spacing:.3px; }
.aztl-breadcrumb a { color:rgba(255,255,255,.8); text-decoration:none; }
.aztl-breadcrumb a:hover { color:white; }
.aztl-breadcrumb span { margin:0 5px; opacity:.5; }
.aztl-hero h1, .aztl-hero-h1 {
  font-size:clamp(22px,3.2vw,38px)!important; font-weight:900!important;
  color:white!important; margin:0 0 12px!important; line-height:1.18!important; letter-spacing:-.5px;
}
.aztl-hero-meta { color:rgba(255,255,255,.8); font-size:15px; margin:0 0 26px; display:flex; flex-wrap:wrap; gap:16px; align-items:center; }
.aztl-hero-meta span { display:flex; align-items:center; gap:5px; }
.aztl-trust-row { display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.aztl-stars { color:var(--a); font-size:18px; letter-spacing:1px; }
.aztl-trust-text { color:rgba(255,255,255,.75); font-size:13px; }
.aztl-form-label { font-size:11px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase; color:var(--gl); margin-bottom:10px; }
.aztl-form-title { font-size:20px!important; font-weight:800!important; color:var(--g)!important; margin:0 0 6px!important; line-height:1.3!important; }
.aztl-form-sub  { font-size:13px; color:var(--bl); margin:0 0 20px; }
.aztl-form-note { font-size:11px; color:var(--bl); text-align:center; margin-top:10px; }

/* Buttons */
.aztl-cta-primary {
  display:block; background:var(--a); color:var(--b)!important; font-weight:800; font-size:16px;
  padding:16px 24px; border-radius:8px; text-decoration:none!important; text-align:center;
  transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 14px rgba(245,158,11,.35); margin-bottom:10px;
}
.aztl-cta-primary:hover { background:var(--ah); transform:translateY(-2px); box-shadow:0 6px 20px rgba(245,158,11,.45); color:var(--b)!important; }
.aztl-cta-secondary {
  display:block; background:transparent; border:2px solid var(--gm); color:var(--gm)!important;
  font-weight:700; font-size:15px; padding:12px 24px; border-radius:8px;
  text-decoration:none!important; text-align:center; transition:all .2s;
}
.aztl-cta-secondary:hover { background:var(--gs); color:var(--g)!important; }

/* Trust bar */
.aztl-trust-bar { background:var(--g); color:white; display:flex; flex-wrap:nowrap; border-radius:var(--r); overflow:hidden; margin-bottom:44px; box-shadow:var(--sh); }
.aztl-trust-item { flex:1 1 0; min-width:0; padding:20px 14px; text-align:center; border-right:1px solid rgba(255,255,255,.1); transition:background .2s; }
.aztl-trust-item:last-child { border-right:none; }
.aztl-trust-item:hover { background:var(--gm); }
.aztl-trust-icon { font-size:26px; display:block; margin-bottom:6px; }
.aztl-trust-num  { font-size:22px; font-weight:900; display:block; line-height:1; margin-bottom:4px; }
.aztl-trust-desc { font-size:12px; opacity:.8; }

/* Sections */
.aztl-section { margin-bottom:54px; }
.aztl-section-header { display:flex; align-items:baseline; gap:12px; margin-bottom:22px; flex-wrap:wrap; }
.aztl-section-title { font-size:clamp(20px,2.6vw,28px)!important; font-weight:800!important; color:var(--g)!important; margin:0!important; line-height:1.2!important; }
.aztl-section-tag { background:var(--gs); color:var(--gl); font-size:11px; font-weight:700; padding:3px 10px; border-radius:20px; letter-spacing:.5px; text-transform:uppercase; white-space:nowrap; }
.aztl-divider-line { height:3px; background:linear-gradient(90deg,var(--a),transparent); border-radius:2px; margin-bottom:22px; }
.aztl-section > p { font-size:16px; line-height:1.8; color:var(--bm); margin-bottom:16px; }

/* Feature cards */
.aztl-grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.aztl-feat-card { background:var(--w); border:1px solid var(--br); border-radius:var(--r); padding:28px 22px; box-shadow:var(--sh); transition:transform .2s,box-shadow .2s,border-color .2s; position:relative; overflow:hidden; }
.aztl-feat-card::before { content:''; position:absolute; top:0; left:0; height:3px; width:100%; background:linear-gradient(90deg,var(--gl),var(--a)); opacity:0; transition:opacity .2s; }
.aztl-feat-card:hover { transform:translateY(-4px); box-shadow:var(--sh2); border-color:var(--gl); }
.aztl-feat-card:hover::before { opacity:1; }
.aztl-feat-icon { font-size:36px; display:block; margin-bottom:14px; }
.aztl-feat-card h3 { font-size:17px!important; font-weight:800!important; color:var(--g)!important; margin:0 0 9px!important; }
.aztl-feat-card p  { font-size:14px!important; color:var(--bl)!important; margin:0!important; line-height:1.65!important; }

/* Steps */
.aztl-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); counter-reset:steps; background:var(--s); border-radius:var(--r); overflow:hidden; border:1px solid var(--br); }
.aztl-step { padding:28px 22px; position:relative; counter-increment:steps; border-right:1px solid var(--br); }
.aztl-step:last-child { border-right:none; }
.aztl-step::before { content:counter(steps); display:block; width:44px; height:44px; background:var(--a); color:var(--b); font-size:20px; font-weight:900; border-radius:50%; line-height:44px; text-align:center; margin-bottom:14px; }
.aztl-step h3 { font-size:16px!important; font-weight:700!important; color:var(--g)!important; margin:0 0 8px!important; }
.aztl-step p  { font-size:14px!important; color:var(--bl)!important; margin:0!important; line-height:1.6!important; }

/* Inline CTA */
.aztl-cta-inline {
  background:linear-gradient(135deg,#0d2b1e 0%,var(--g) 60%,var(--gm) 100%);
  border-radius:var(--r); padding:40px 44px; display:flex; align-items:center;
  gap:30px; margin:48px 0; box-shadow:var(--sh2); flex-wrap:wrap; position:relative; overflow:hidden;
}
.aztl-cta-inline::before { content:'🏡'; position:absolute; right:140px; bottom:-12px; font-size:110px; opacity:.05; pointer-events:none; }
.aztl-cta-inline-text { flex:1 1 280px; min-width:0; }
.aztl-cta-inline-text h3 { font-size:clamp(18px,2.5vw,26px)!important; font-weight:900!important; color:white!important; margin:0 0 8px!important; }
.aztl-cta-inline-text p  { color:rgba(255,255,255,.82)!important; font-size:15px!important; margin:0!important; }
.aztl-cta-inline-actions { display:flex; flex-direction:column; gap:10px; min-width:200px; flex-shrink:0; }

/* City grid */
.aztl-city-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(165px,1fr)); gap:14px; margin-top:22px; }
.aztl-city-card { background:var(--w); border:1px solid var(--br); border-radius:var(--r); overflow:hidden; transition:all .2s; box-shadow:0 2px 10px rgba(0,0,0,.05); }
.aztl-city-card:hover { border-color:var(--gl); box-shadow:0 6px 22px rgba(27,67,50,.14); transform:translateY(-3px); }
.aztl-city-card-body { padding:16px 14px; }
.aztl-city-card a { text-decoration:none!important; color:var(--g)!important; font-weight:700; font-size:15px; display:block; margin-bottom:4px; }
.aztl-city-card a:hover { color:var(--gl)!important; }
.aztl-city-card-sub { font-size:12px; color:var(--bl); }

/* Nearby pills */
.aztl-nearby-grid { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.aztl-nearby-pill {
  display:inline-flex; align-items:center; gap:6px; background:var(--gs);
  color:var(--g)!important; border:1px solid #b7dfc8; border-radius:40px;
  padding:8px 18px; font-size:14px; font-weight:600; text-decoration:none!important; transition:all .18s;
}
.aztl-nearby-pill:hover { background:var(--g); color:white!important; border-color:var(--g); }
.aztl-nearby-pill::before { content:'📍'; font-size:12px; }

/* FAQ */
.aztl-faq-item { border:1px solid var(--br); border-radius:var(--r); margin-bottom:10px; overflow:hidden; background:var(--w); }
.aztl-faq-q { background:var(--s); font-size:15px!important; font-weight:700!important; color:var(--g)!important; padding:18px 20px!important; margin:0!important; border-bottom:1px solid var(--br); display:flex!important; align-items:center; gap:10px; }
.aztl-faq-q::before { content:'Q'; font-size:11px; font-weight:900; background:var(--a); color:var(--b); width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.aztl-faq-a { padding:16px 20px 16px 52px!important; margin:0!important; font-size:15px!important; line-height:1.75!important; color:var(--bm)!important; background:white; }

/* Testimonials */
.aztl-testimonials { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:18px; margin-top:20px; }
.aztl-testimonial { background:var(--w); border-radius:var(--r); padding:24px 22px; box-shadow:var(--sh); border:1px solid var(--br); position:relative; overflow:hidden; }
.aztl-testimonial::before { content:'"'; position:absolute; top:8px; left:16px; font-size:72px; color:var(--gs); font-family:Georgia,serif; line-height:1; pointer-events:none; }
.aztl-testimonial-stars  { color:var(--a); margin-bottom:10px; font-size:14px; }
.aztl-testimonial-text   { font-size:14px; color:var(--bm); line-height:1.75; font-style:italic; margin-bottom:16px; padding-top:8px; }
.aztl-testimonial-author { font-size:13px; font-weight:700; color:var(--g); display:flex; align-items:center; gap:10px; }
.aztl-testimonial-avatar { width:36px; height:36px; border-radius:50%; background:var(--g); color:white; font-size:13px; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; }

/* Updated badge */
.aztl-updated { font-size:12px; color:var(--bl); background:var(--s); border:1px solid var(--br); border-radius:20px; padding:4px 13px; display:inline-flex; align-items:center; gap:5px; margin-bottom:28px; }
.aztl-updated::before { content:'🔄'; font-size:11px; }

/* Highlight box */
.aztl-highlight { background:var(--gs); border-left:4px solid var(--a); border-radius:0 var(--r) var(--r) 0; padding:18px 22px; margin:22px 0; }
.aztl-highlight p { margin:0!important; font-size:15px!important; color:var(--g)!important; font-weight:500!important; }

/* Internal nav links */
.aztl-nav-links { background:var(--s); border:1px solid var(--br); border-radius:var(--r); padding:18px 22px; margin:30px 0; }
.aztl-nav-links h4 { font-size:12px!important; font-weight:700!important; color:var(--bl)!important; margin:0 0 12px!important; text-transform:uppercase; letter-spacing:.8px; }
.aztl-nav-links-row { display:flex; flex-wrap:wrap; gap:8px 16px; align-items:center; }
.aztl-nav-link { font-size:14px; color:var(--gm)!important; text-decoration:none!important; font-weight:600; transition:color .15s; }
.aztl-nav-link:hover { color:var(--g)!important; text-decoration:underline!important; }
.aztl-nav-sep { color:var(--br); font-size:12px; }

/* Sticky mobile bar */
.aztl-sticky-bar { display:none; position:fixed; bottom:0; left:0; right:0; background:var(--g); padding:12px 20px; z-index:9999; box-shadow:0 -4px 20px rgba(0,0,0,.2); justify-content:space-between; align-items:center; gap:12px; }
.aztl-sticky-bar-text { font-size:14px; color:white; font-weight:600; }
.aztl-sticky-bar a { background:var(--a); color:var(--b)!important; font-weight:800; font-size:14px; padding:10px 20px; border-radius:6px; text-decoration:none!important; white-space:nowrap; }

/* =============================================================
   10b. HOMEPAGE EXTRAS
   ============================================================= */

/* Center the "Browse All" link below listings */
.aztl-home-browse-link { text-align: center; margin-top: 32px; }

/* State pills on homepage */
.aztl-home-states-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.aztl-state-pill {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--w);
  border: 1px solid var(--br);
  border-radius: var(--r);
  padding: 12px 16px;
  min-width: 88px;
  text-decoration: none !important;
  transition: all .18s;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.aztl-state-pill:hover { border-color: var(--gl); background: var(--gs); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(27,67,50,.12); }
.aztl-state-pill-all { background: var(--g); border-color: var(--g); }
.aztl-state-pill-all:hover { background: var(--gm); border-color: var(--gm); }
.aztl-state-pill-all .aztl-state-abbr,
.aztl-state-pill-all .aztl-state-label { color: #fff !important; }
.aztl-state-abbr { font-size: 18px; font-weight: 900; color: var(--g); line-height: 1; }
.aztl-state-label { font-size: 11px; color: var(--bl); margin-top: 4px; text-align: center; line-height: 1.2; }

/* Hub page 50-state grid */
.aztl-hub-states-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.aztl-hub-state-card {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--w);
  border: 1px solid var(--br);
  border-radius: 8px;
  padding: 10px 14px;
  text-decoration: none !important;
  transition: all .18s;
  box-shadow: 0 1px 6px rgba(0,0,0,.04);
}
.aztl-hub-state-card:hover { border-color: var(--gl); background: var(--gs); transform: translateY(-2px); box-shadow: 0 4px 14px rgba(27,67,50,.1); }
.aztl-hub-state-abbr { font-size: 17px; font-weight: 900; color: var(--g); flex-shrink: 0; width: 32px; }
.aztl-hub-state-name { font-size: 12px; font-weight: 600; color: var(--bm); line-height: 1.25; }

/* Regular page content container */
.page-entry-inner {
  max-width: 900px;
  margin: 48px auto 60px;
  padding: 0 24px;
}

/* =============================================================
   11. RESPONSIVE
   ============================================================= */
@media (max-width: 1024px) {
  .aztl-footer-top { grid-template-columns: 1fr 1fr; gap: 28px; }
}

@media (max-width: 900px) {
  .blog-layout { grid-template-columns: 1fr; }
  .blog-sidebar { order: -1; }
}

@media (max-width: 768px) {
  /* Header */
  .aztl-nav-toggle { display: flex; }
  .site-nav {
    display: none;
    position: absolute;
    top: 68px; left: 0; right: 0;
    background: #1b4332;
    padding: 12px 20px 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,.3);
    z-index: 150;
  }
  .site-nav.is-open { display: block; }
  .aztl-nav-list { flex-direction: column; gap: 2px; }
  .aztl-nav-list > li > a { padding: 10px 12px; }
  .aztl-nav-list .sub-menu { position: static; opacity: 1; pointer-events: auto; transform: none; box-shadow: none; background: rgba(255,255,255,.08); border-radius: 6px; margin: 4px 0; }
  .aztl-nav-list .sub-menu a { color: rgba(255,255,255,.8); padding: 8px 20px; }
  .aztl-header-cta { display: none; }

  /* Trust bar */
  .aztl-trust-bar { flex-wrap: wrap; }
  .aztl-trust-item { flex: 1 1 45%; border-bottom: 1px solid rgba(255,255,255,.08); }
  .aztl-trust-item:nth-child(2) { border-right: none; }
  .aztl-hero-left { padding: 38px 30px; }

  /* Footer */
  .aztl-footer-top { grid-template-columns: 1fr 1fr; }
  .aztl-footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 600px) {
  .aztl-home-states-grid { gap: 8px; }
  .aztl-state-pill { min-width: 72px; padding: 10px 10px; }
  .aztl-hub-states-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
  .page-entry-inner { margin-top: 28px; padding: 0 16px; }
  .aztl-page { padding: 0 16px; }
  .aztl-hero-left { padding: 28px 20px 20px; }
  .aztl-hero-form { padding: 24px 20px; border-top: 3px solid var(--a); }
  .aztl-hero-form::before { display: none; }
  .aztl-trust-bar { flex-wrap: wrap; }
  .aztl-trust-item { flex: 1 1 45%; }
  .aztl-trust-item:nth-child(odd)  { border-right: 1px solid rgba(255,255,255,.1); }
  .aztl-trust-item:nth-child(even) { border-right: none; }
  .aztl-steps { grid-template-columns: 1fr; }
  .aztl-step { border-right: none; border-bottom: 1px solid var(--br); }
  .aztl-step:last-child { border-bottom: none; }
  .aztl-city-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .aztl-cta-inline { padding: 26px 20px; flex-direction: column; align-items: flex-start; }
  .aztl-cta-inline::before { display: none; }
  .aztl-cta-inline-actions { min-width: auto; width: 100%; }
  .aztl-sticky-bar { display: flex; }
  body { padding-bottom: 64px; }
  .blog-post-grid { grid-template-columns: 1fr; }
  .aztl-footer-top { grid-template-columns: 1fr; }
  .aztl-footer-bottom { flex-direction: column; align-items: flex-start; }
  .aztl-intro-img { flex: 1 1 100%; }
}

@media (min-width: 601px) {
  .aztl-sticky-bar { display: none !important; }
}
