/*
Theme Name: AI Property Tools
Theme URI: https://aipropertytools.com
Template: astra
Description: Custom dark blueprint aesthetic for AI Property Tools - AI real estate tool reviews
Author: AI Property Tools
Version: 1.2.0
Text Domain: aipt
*/

/* ============================================
   DESIGN SYSTEM: Editorial + Luxury Refined
   Aesthetic: Dark Blueprint with Amber Gold
   DFII Score: 15/15
   v1.1 — Fixed Astra specificity overrides
   ============================================ */

/* === CSS Variables === */
:root {
  /* Dominant: Deep Navy */
  --color-bg-primary: #0B1426;
  --color-bg-secondary: #111D35;
  --color-bg-card: #162040;
  --color-bg-card-hover: #1A2850;

  /* Accent: Amber Gold */
  --color-accent: #D4A84B;
  --color-accent-hover: #E8C06A;
  --color-accent-subtle: rgba(212, 168, 75, 0.12);
  --color-accent-glow: rgba(212, 168, 75, 0.25);

  /* Neutral System */
  --color-text-primary: #E8ECF4;
  --color-text-secondary: #8B95A8;
  --color-text-muted: #5A6577;
  --color-border: rgba(255, 255, 255, 0.08);
  --color-border-accent: rgba(212, 168, 75, 0.3);

  /* Semantic */
  --color-success: #4ADE80;
  --color-warning: #FBBF24;
  --color-danger: #F87171;

  /* Spacing - 8px base */
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-6: 48px;
  --space-8: 64px;
  --space-12: 96px;
  --space-16: 128px;

  /* Typography */
  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Source Serif 4', Georgia, serif;
  --font-mono: 'JetBrains Mono', monospace;

  /* Blueprint Grid */
  --blueprint-grid: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M60 0H0v60' fill='none' stroke='%23ffffff' stroke-opacity='0.03' stroke-width='0.5'/%3E%3C/svg%3E");

  /* Transitions */
  --transition-fast: 0.15s ease;
  --transition-base: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* === Global Reset === */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* === Body - FORCE dark background over Astra defaults === */
body,
body.flavor-flavor,
body.flavor-flavor .ast-container,
.flavor-flavor #page {
  background-color: var(--color-bg-primary) !important;
  background-image: var(--blueprint-grid) !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
  font-size: 17px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* FORCE: Override ALL Astra container backgrounds */
.ast-separate-container,
.ast-plain-container,
body .ast-separate-container,
body .ast-plain-container,
#content,
#primary,
#secondary,
.site-content,
.ast-container,
.content-area {
  background-color: transparent !important;
  background: transparent !important;
}

/* === Typography === */
h1, h2, h3, h4, h5, h6,
body h1, body h2, body h3, body h4 {
  font-family: var(--font-display) !important;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-text-primary) !important;
  letter-spacing: -0.02em;
}

h1 { font-size: clamp(2rem, 4vw, 3rem) !important; }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem) !important; }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem) !important; }

p, body p {
  color: var(--color-text-secondary) !important;
  margin-bottom: var(--space-3);
}

a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-accent-hover);
}

/* === Selection === */
::selection {
  background: var(--color-accent);
  color: var(--color-bg-primary);
}

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
.ast-header-stacked .main-header-bar,
.main-header-bar,
#masthead,
body .main-header-bar {
  background-color: rgba(11, 20, 38, 0.95) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border) !important;
  box-shadow: 0 1px 40px rgba(0, 0, 0, 0.3) !important;
}

.site-title,
.site-title a,
body .site-title a {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 1.4rem !important;
  color: var(--color-text-primary) !important;
  letter-spacing: -0.01em;
}

/* Gold diamond before site title */
.site-title a::before {
  content: '◆ ';
  color: var(--color-accent);
  font-size: 0.7em;
}

/* Navigation links */
.main-header-menu a,
.ast-header-sections-navigation a,
body .main-header-menu a {
  font-family: var(--font-display) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: all var(--transition-fast);
}

.main-header-menu a:hover,
.main-header-menu .current-menu-item > a {
  color: var(--color-accent) !important;
}

/* ============================================
   HERO SECTION (Homepage)
   ============================================ */
.home .entry-header,
.blog .page-header {
  text-align: center;
  padding: var(--space-16) var(--space-4) var(--space-8);
  position: relative;
}

.home .entry-title,
.blog .page-title {
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
  font-weight: 700;
  background: linear-gradient(135deg, var(--color-text-primary) 0%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-3);
}

/* ============================================
   CONTENT CARDS (Post Grid on homepage/archive)
   Force dark card backgrounds
   ============================================ */
.ast-separate-container .ast-article-post,
.ast-separate-container .ast-article-single:not(.ast-single-post .ast-article-single),
body .ast-separate-container .ast-article-post,
body article.post,
article.post {
  background: var(--color-bg-card) !important;
  background-color: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px !important;
  padding: var(--space-4) !important;
  margin-bottom: var(--space-4) !important;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

/* Hover glow effect */
.ast-separate-container .ast-article-post:hover,
body article.post:hover {
  border-color: var(--color-border-accent) !important;
  box-shadow: 0 0 30px var(--color-accent-glow), 0 8px 32px rgba(0, 0, 0, 0.3) !important;
  transform: translateY(-2px);
}

/* Top accent line on hover */
.ast-separate-container .ast-article-post::before,
body article.post::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.ast-separate-container .ast-article-post:hover::before,
body article.post:hover::before {
  opacity: 1;
}

/* Post titles on homepage — light text on dark cards */
.entry-title a,
body .entry-title a,
.ast-blog-single-element .entry-title,
body .ast-blog-single-element .entry-title {
  font-family: var(--font-display) !important;
  color: var(--color-text-primary) !important;
  font-weight: 600 !important;
  transition: color var(--transition-fast);
}

.entry-title a:hover,
body .entry-title a:hover {
  color: var(--color-accent) !important;
}

/* Post excerpt text */
.ast-excerpt-container,
.ast-excerpt-container p,
body .ast-excerpt-container p {
  color: var(--color-text-secondary) !important;
}

/* Post meta */
.entry-meta,
.entry-meta *,
body .entry-meta,
body .entry-meta * {
  font-family: var(--font-display) !important;
  font-size: 0.8rem !important;
  color: var(--color-text-muted) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.entry-meta a,
body .entry-meta a {
  color: var(--color-accent) !important;
}

/* Category badges */
.cat-links a,
body .cat-links a {
  color: var(--color-accent) !important;
  font-family: var(--font-display) !important;
  font-size: 0.75rem !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* Featured images */
.post-thumb-img-content img,
.wp-post-image {
  border-radius: 8px;
  border: 1px solid var(--color-border);
}

/* ============================================
   SINGLE ARTICLE - Reading Mode
   Warm light background for comfortable reading
   ============================================ */
.ast-single-post .ast-article-single,
body.single-post .ast-article-single,
.ast-separate-container.ast-single-post .ast-article-single {
  background: #F8F6F2 !important;
  background-color: #F8F6F2 !important;
  color: #1A1A2E !important;
  border: none !important;
  border-radius: 12px !important;
  padding: var(--space-6) var(--space-8) !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
}

/* Article headings in reading mode */
.ast-single-post .entry-content h2,
.ast-single-post .entry-content h3,
.ast-single-post .entry-content h4,
body.single-post .entry-content h2,
body.single-post .entry-content h3,
body.single-post .entry-content h4 {
  font-family: var(--font-display) !important;
  color: #0B1426 !important;
  margin-top: var(--space-6);
  margin-bottom: var(--space-2);
}

.ast-single-post .entry-content h2,
body.single-post .entry-content h2 {
  font-size: 1.65rem !important;
  padding-bottom: var(--space-2);
  border-bottom: 2px solid var(--color-accent);
}

.ast-single-post .entry-content h3,
body.single-post .entry-content h3 {
  font-size: 1.35rem !important;
  color: #2D3748 !important;
}

/* Article body text */
.ast-single-post .entry-content p,
.ast-single-post .entry-content li,
body.single-post .entry-content p,
body.single-post .entry-content li {
  color: #374151 !important;
  font-family: var(--font-body) !important;
  font-size: 1.05rem !important;
  line-height: 1.85;
}

/* Links in articles */
.ast-single-post .entry-content a,
body.single-post .entry-content a {
  color: #B8860B !important;
  text-decoration: underline;
  text-decoration-color: rgba(184, 134, 11, 0.3);
  text-underline-offset: 3px;
  transition: all var(--transition-fast);
}

.ast-single-post .entry-content a:hover,
body.single-post .entry-content a:hover {
  color: #996515 !important;
  text-decoration-color: #996515;
}

/* Article title on single page */
.ast-single-post .entry-title,
body.single-post .entry-title {
  font-family: var(--font-display) !important;
  font-size: clamp(1.8rem, 3.5vw, 2.5rem) !important;
  color: #0B1426 !important;
  -webkit-text-fill-color: #0B1426 !important;
  line-height: 1.3;
  margin-bottom: var(--space-3);
}

/* Article meta on single page */
.ast-single-post .entry-meta,
.ast-single-post .entry-meta *,
body.single-post .entry-meta,
body.single-post .entry-meta * {
  color: #6B7280 !important;
}

/* Blockquotes */
.ast-single-post .entry-content blockquote,
body.single-post .entry-content blockquote {
  border-left: 3px solid var(--color-accent) !important;
  background: rgba(212, 168, 75, 0.06) !important;
  padding: var(--space-3) var(--space-4);
  margin: var(--space-4) 0;
  border-radius: 0 8px 8px 0;
  font-style: italic;
  color: #4A5568 !important;
}

/* Code blocks */
.ast-single-post .entry-content code,
body.single-post .entry-content code {
  background: #E8E4DC;
  color: #744210 !important;
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--font-mono) !important;
  font-size: 0.88em;
}

.ast-single-post .entry-content pre,
body.single-post .entry-content pre {
  background: #1A1A2E !important;
  color: #E8ECF4 !important;
  border-radius: 8px;
  padding: var(--space-3);
  overflow-x: auto;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.ast-single-post .entry-content pre code,
body.single-post .entry-content pre code {
  background: transparent !important;
  color: inherit !important;
  padding: 0;
}

/* Tables in articles */
.ast-single-post .entry-content table,
body.single-post .entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-4) 0;
  font-size: 0.95rem;
}

.ast-single-post .entry-content th,
body.single-post .entry-content th {
  background: #0B1426 !important;
  color: var(--color-accent) !important;
  font-family: var(--font-display) !important;
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  text-align: left;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ast-single-post .entry-content td,
body.single-post .entry-content td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid #E5E1D8;
  color: #374151 !important;
}

.ast-single-post .entry-content tr:hover td,
body.single-post .entry-content tr:hover td {
  background: rgba(212, 168, 75, 0.05) !important;
}

/* Images in articles */
.ast-single-post .entry-content img,
body.single-post .entry-content img {
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  margin: var(--space-3) 0;
}

/* Lists */
.ast-single-post .entry-content ul,
.ast-single-post .entry-content ol,
body.single-post .entry-content ul,
body.single-post .entry-content ol {
  padding-left: var(--space-4);
  margin: var(--space-3) 0;
}

.ast-single-post .entry-content li,
body.single-post .entry-content li {
  margin-bottom: var(--space-1);
}

.ast-single-post .entry-content ul li::marker,
body.single-post .entry-content ul li::marker {
  color: var(--color-accent);
}

/* ============================================
   AUTHOR BIO BOX — Override GentlemanPro leak
   ============================================ */
.ast-single-post .ast-author-box,
.ast-author-box,
body .ast-author-box,
.about-author {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px !important;
  padding: var(--space-4) !important;
}

.ast-author-box .ast-author-name,
.ast-author-box .about-author__title,
body .ast-author-box .ast-author-name {
  color: var(--color-text-primary) !important;
  font-family: var(--font-display) !important;
}

.ast-author-box .ast-author-bio,
body .ast-author-box .ast-author-bio {
  color: var(--color-text-secondary) !important;
}

/* ============================================
   CTA BUTTONS
   ============================================ */
.entry-content a[href*="visit"],
.entry-content .wp-block-button__link,
.entry-content a.cta-button,
a.ast-custom-button,
body .entry-content .wp-block-button__link {
  display: inline-block;
  background: linear-gradient(135deg, var(--color-accent), #C49A3C) !important;
  color: #0B1426 !important;
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: all var(--transition-base) !important;
  box-shadow: 0 4px 15px rgba(212, 168, 75, 0.3);
  text-decoration: none !important;
  border: none !important;
}

.entry-content a[href*="visit"]:hover,
.entry-content .wp-block-button__link:hover,
a.ast-custom-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(212, 168, 75, 0.45) !important;
  background: linear-gradient(135deg, var(--color-accent-hover), #D4A84B) !important;
}

/* ============================================
   SIDEBAR / WIDGETS
   ============================================ */
.widget,
body .widget {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px;
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.widget-title,
body .widget-title {
  font-family: var(--font-display) !important;
  font-size: 0.85rem !important;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-accent) !important;
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-3) !important;
}

.widget a,
body .widget a {
  color: var(--color-text-secondary) !important;
}

.widget a:hover,
body .widget a:hover {
  color: var(--color-accent) !important;
}

/* ============================================
   FOOTER — comprehensive Astra overrides
   ============================================ */
.site-footer,
.ast-footer-overlay,
body .site-footer,
.ast-small-footer,
body .ast-small-footer,
.site-below-footer-wrap,
body .site-below-footer-wrap,
.ast-builder-footer-grid-columns,
.site-footer-above-section-1,
.site-footer-primary-section-1,
.site-footer-below-section-1,
footer.site-footer,
html body footer.site-footer,
.ast-footer-copyright,
body .ast-footer-copyright,
html body .site-below-footer-wrap {
  background-color: #070E1B !important;
  background: #070E1B !important;
  border-top: 1px solid var(--color-border) !important;
}

.site-footer .site-info,
body .site-footer .site-info,
.ast-small-footer .ast-footer-copyright,
.ast-builder-layout-element .ast-footer-copyright,
.ast-footer-copyright p,
body .ast-footer-copyright p {
  font-family: var(--font-display) !important;
  font-size: 0.8rem !important;
  color: var(--color-text-muted) !important;
  text-align: center;
  padding: var(--space-4) 0;
}

.site-footer a,
body .site-footer a,
.ast-footer-copyright a,
body .ast-footer-copyright a {
  color: var(--color-accent) !important;
}

/* ============================================
   PAGINATION
   ============================================ */
.ast-pagination .page-numbers,
.nav-links .page-numbers,
body .ast-pagination .page-numbers {
  font-family: var(--font-display) !important;
  background: var(--color-bg-card) !important;
  color: var(--color-text-secondary) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px;
  padding: var(--space-1) var(--space-2);
  margin: 0 4px;
  transition: all var(--transition-fast);
}

.ast-pagination .page-numbers.current,
body .ast-pagination .page-numbers.current {
  background: var(--color-accent) !important;
  color: var(--color-bg-primary) !important;
  border-color: var(--color-accent) !important;
}

.ast-pagination .page-numbers:hover,
body .ast-pagination .page-numbers:hover {
  border-color: var(--color-accent) !important;
  color: var(--color-accent) !important;
}

/* ============================================
   SEARCH FORM
   ============================================ */
.search-form .search-field,
body .search-form .search-field {
  background: var(--color-bg-secondary) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text-primary) !important;
  border-radius: 8px !important;
  padding: var(--space-2) !important;
  font-family: var(--font-body) !important;
}

.search-form .search-field:focus,
body .search-form .search-field:focus {
  border-color: var(--color-accent) !important;
  box-shadow: 0 0 0 3px var(--color-accent-subtle) !important;
  outline: none;
}

/* ============================================
   SCROLLBAR
   ============================================ */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-bg-primary);
}

::-webkit-scrollbar-thumb {
  background: var(--color-bg-card);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-muted);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 768px) {
  .ast-single-post .ast-article-single,
  body.single-post .ast-article-single {
    padding: var(--space-3) var(--space-3) !important;
  }

  .ast-single-post .entry-content h2,
  body.single-post .entry-content h2 {
    font-size: 1.4rem !important;
  }

  body {
    font-size: 16px !important;
  }
}

/* ============================================
   ANIMATION: Fade-Up Entrance (Hero only)
   ============================================ */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.home .entry-header,
.blog .page-header {
  animation: fadeUp 0.6s var(--transition-base) both;
}

.home .ast-article-post,
.blog .ast-article-post {
  animation: fadeUp 0.5s var(--transition-base) both;
}

.home .ast-article-post:nth-child(2) { animation-delay: 0.1s; }
.home .ast-article-post:nth-child(3) { animation-delay: 0.2s; }
.home .ast-article-post:nth-child(4) { animation-delay: 0.3s; }

/* ============================================
   CRITICAL FIX: Astra .ast-article-inner
   This inner div has white bg by default
   ============================================ */
.ast-article-inner,
.blog-layout-4,
.ast-article-inner.blog-layout-4,
body .ast-article-inner,
body .blog-layout-4,
body .ast-article-inner.blog-layout-4,
html body .ast-article-inner,
html body .ast-separate-container .ast-article-inner,
.ast-separate-container .ast-article-post .ast-article-inner {
  background: transparent !important;
  background-color: transparent !important;
}

/* But keep reading mode light for single posts */
body.single-post .ast-article-inner,
.ast-single-post .ast-article-inner {
  background: #F8F6F2 !important;
  background-color: #F8F6F2 !important;
}

/* ============================================
   FINAL OVERRIDE: Container backgrounds
   Astra uses very specific selectors,
   we need to be even more specific
   ============================================ */
html body.ast-separate-container,
html body.ast-plain-container,
html body {
  background-color: var(--color-bg-primary) !important;
  background-image: var(--blueprint-grid) !important;
}

html body .ast-container,
html body .site-content .ast-container {
  background: transparent !important;
}

/* Container max width */
.ast-container {
  max-width: 1100px;
}

/* "Read More" link */
.ast-read-more-container a,
body .ast-read-more-container a,
a.read-more,
body a.read-more {
  color: var(--color-accent) !important;
  font-family: var(--font-display) !important;
  font-size: 0.85rem !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600 !important;
  transition: color var(--transition-fast);
}

.ast-read-more-container a:hover,
body .ast-read-more-container a:hover {
  color: var(--color-accent-hover) !important;
}

/* Astra "scroll to top" button */
#ast-scroll-top,
body #ast-scroll-top {
  background: var(--color-accent) !important;
  color: var(--color-bg-primary) !important;
  border-radius: 8px !important;
}
