/**
 * Tax Sales Property - Main Stylesheet
 *
 * Custom CSS extracted from stitch_past_tax_sale_results design files
 * Use alongside Tailwind CSS CDN or compiled Tailwind
 */

/* ============================================
   1. CSS Variables (Design Tokens)
   ============================================ */
:root {
  /* Primary Colors */
  --color-primary: #1e3a8a;
  --color-primary-light: #2b7cee;
  --color-secondary: #ef4444;

  /* Background Colors */
  --color-bg-light: #f8fafc;
  --color-bg-dark: #0f172a;

  /* Text Colors */
  --color-text-primary: #0f172a;
  --color-text-secondary: #64748b;
  --color-text-muted: #94a3b8;

  /* Border Colors */
  --color-border-light: #e2e8f0;
  --color-border-dark: #334155;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
}

/* Dark mode overrides - Enhanced Premium Dark Theme */
.dark {
  /* Text Colors - Improved contrast and readability */
  --color-text-primary: #f1f5f9;
  --color-text-secondary: #cbd5e1;
  --color-text-muted: #94a3b8;
  --color-border-light: #334155;
  
  /* Enhanced Dark Background Palette */
  --color-bg-dark: #0c1222;
  --color-bg-card: #111827;
  --color-bg-elevated: #1e293b;
  --color-bg-hover: #1e3a5f;
  
  /* Accent Colors for Dark Mode */
  --color-primary-dark: #3b82f6;
  --color-accent-glow: rgba(59, 130, 246, 0.15);
}

/* ============================================
   2. Base Styles
   ============================================ */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background-color: var(--color-bg-light);
  color: var(--color-text-primary);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.dark body {
  background-color: var(--color-bg-dark);
}

/* ============================================
   3. Component Styles
   ============================================ */

/* Property Card Shadow */
.property-card-shadow {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.property-card-shadow:hover {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

/* Hero Gradient Background */
.hero-gradient {
  background: linear-gradient(rgba(30, 58, 138, 0.8), rgba(30, 58, 138, 0.4)),
              url('/static/images/hero-bg.jpg');
  background-size: cover;
  background-position: center;
}

.hero-gradient-dark {
  background: linear-gradient(rgba(15, 23, 42, 0.9), rgba(15, 23, 42, 0.7)),
              url('/static/images/hero-bg.jpg');
  background-size: cover;
  background-position: center;
}

/* CTA Section Gradient */
.cta-gradient {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
}

/* ============================================
   4. Material Icons Styles
   ============================================ */
.material-icons,
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
}

.material-icons.filled,
.material-symbols-outlined.filled {
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* ============================================
   5. Animation Classes
   ============================================ */
.animate-fade-in {
  animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.hover-scale {
  transition: transform 0.3s ease;
}

.hover-scale:hover {
  transform: scale(1.02);
}

/* Image hover zoom effect for property cards */
.group:hover .group-hover\:scale-110 {
  transform: scale(1.1);
}

/* Toast notification animation */
.animate-fade-in-up {
  animation: fadeInUp 0.3s ease-out;
}

@keyframes fadeInUp {
  from { 
    opacity: 0; 
    transform: translateY(20px); 
  }
  to { 
    opacity: 1; 
    transform: translateY(0); 
  }
}

/* ============================================
   6. Form Styles
   ============================================ */
.form-input,
.form-select,
.form-textarea {
  border-color: var(--color-border-light);
  border-radius: 0.5rem;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(30, 58, 138, 0.1);
  outline: none;
}

.dark .form-input,
.dark .form-select,
.dark .form-textarea {
  background-color: #1e293b;
  border-color: var(--color-border-dark);
  color: var(--color-text-primary);
}

/* ============================================
   7. Button Styles
   ============================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1rem;
  font-weight: 600;
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.btn-primary {
  background-color: var(--color-primary);
  color: white;
}

.btn-primary:hover {
  background-color: #1e40af;
}

.btn-secondary {
  background-color: var(--color-secondary);
  color: white;
}

.btn-secondary:hover {
  background-color: #dc2626;
}

.btn-outline {
  background-color: transparent;
  border: 2px solid var(--color-border-light);
  color: var(--color-text-primary);
}

.btn-outline:hover {
  background-color: #f1f5f9;
}

.dark .btn-outline {
  border-color: var(--color-border-dark);
  color: var(--color-text-primary);
}

.dark .btn-outline:hover {
  background-color: #1e293b;
}

/* ============================================
   8. Card Styles
   ============================================ */
.card {
  background-color: white;
  border-radius: 0.75rem;
  border: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-sm);
}

.dark .card {
  background-color: #1e293b;
  border-color: var(--color-border-dark);
}

/* ============================================
   9. Badge/Tag Styles
   ============================================ */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  border-radius: 0.25rem;
}

.badge-success {
  background-color: #dcfce7;
  color: #166534;
}

.dark .badge-success {
  background-color: rgba(34, 197, 94, 0.2);
  color: #4ade80;
}

.badge-warning {
  background-color: #fef3c7;
  color: #92400e;
}

.dark .badge-warning {
  background-color: rgba(245, 158, 11, 0.2);
  color: #fbbf24;
}

.badge-danger {
  background-color: #fee2e2;
  color: #991b1b;
}

.dark .badge-danger {
  background-color: rgba(239, 68, 68, 0.2);
  color: #f87171;
}

/* ============================================
   10. Utility Classes
   ============================================ */
.text-balance {
  text-wrap: balance;
}

.line-clamp-1 {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Scrollbar styling */
.custom-scrollbar::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.custom-scrollbar::-webkit-scrollbar-track {
  background: transparent;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
  background-color: #cbd5e1;
  border-radius: 3px;
}

.dark .custom-scrollbar::-webkit-scrollbar-thumb {
  background-color: #475569;
}

/* ============================================
   12. Ad Container Styles
   ============================================ */
.ad-container {
  overflow: hidden;
  max-width: 100%;
  text-align: center;
}

/* Hide unfilled ad slots to avoid blank space */
.ad-container ins.adsbygoogle[data-ad-status="unfilled"] {
  display: none !important;
}

/* ============================================
   13. Responsive Utilities
   ============================================ */
@media (max-width: 1024px) {
  .property-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   14. Print Styles
   ============================================ */
@media print {
  .no-print,
  .ad-container {
    display: none !important;
  }

  body {
    background: white;
    color: black;
  }
}

/* ============================================
   13. Enhanced Dark Mode Styles
   ============================================ */

/* Dark Mode Header - Glass Effect */
.dark header,
.dark nav {
  background: rgba(15, 23, 42, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Dark Mode Cards - Elevated Design */
.dark .card,
.dark [class*="bg-white"],
.dark .bg-white {
  background-color: #111827 !important;
  border-color: #1e293b !important;
}

/* Dark Mode Cards - Subtle Glow on Hover */
.dark .card:hover,
.dark [class*="hover\\:shadow"]:hover {
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.1), 0 4px 15px rgba(0, 0, 0, 0.3);
}

/* Dark Mode Inputs - Better Visibility */
.dark input,
.dark select,
.dark textarea,
.dark [type="text"],
.dark [type="email"],
.dark [type="password"],
.dark [type="number"],
.dark [type="search"] {
  background-color: #1e293b !important;
  border-color: #334155 !important;
  color: #f1f5f9 !important;
}

.dark input:focus,
.dark select:focus,
.dark textarea:focus {
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2) !important;
}

.dark input::placeholder,
.dark textarea::placeholder {
  color: #64748b !important;
}

/* Dark Mode Tables */
.dark table {
  border-color: #1e293b;
}

.dark th {
  background-color: #0f172a !important;
  border-color: #1e293b !important;
  color: #94a3b8 !important;
}

.dark td {
  border-color: #1e293b !important;
}

.dark tr:nth-child(even) {
  background-color: rgba(30, 41, 59, 0.3);
}

.dark tr:hover {
  background-color: rgba(59, 130, 246, 0.05);
}

/* Dark Mode Buttons - Primary */
.dark .btn-primary,
.dark .bg-primary {
  background-color: #3b82f6 !important;
}

.dark .btn-primary:hover,
.dark .bg-primary:hover {
  background-color: #2563eb !important;
}

/* Dark Mode Dropdowns & Menus */
.dark [class*="dropdown"],
.dark [x-show] {
  border-color: #334155 !important;
}

/* Dark Mode Borders - Softer */
.dark [class*="border-slate-200"],
.dark [class*="border-gray-200"] {
  border-color: #1e293b !important;
}

/* Dark Mode Text Colors - Enhanced Contrast */
.dark [class*="text-slate-900"],
.dark [class*="text-gray-900"] {
  color: #f1f5f9 !important;
}

.dark [class*="text-slate-700"],
.dark [class*="text-gray-700"] {
  color: #cbd5e1 !important;
}

.dark [class*="text-slate-600"],
.dark [class*="text-gray-600"] {
  color: #94a3b8 !important;
}

.dark [class*="text-slate-500"],
.dark [class*="text-gray-500"] {
  color: #64748b !important;
}

/* Dark Mode Backgrounds - Consistent Palette */
.dark [class*="bg-slate-50"],
.dark [class*="bg-gray-50"] {
  background-color: #0f172a !important;
}

.dark [class*="bg-slate-100"],
.dark [class*="bg-gray-100"] {
  background-color: #1e293b !important;
}

/* Dark Mode Status Badges */
.dark .badge-success {
  background-color: rgba(34, 197, 94, 0.15) !important;
  color: #4ade80 !important;
  border: 1px solid rgba(34, 197, 94, 0.3);
}

.dark .badge-warning {
  background-color: rgba(245, 158, 11, 0.15) !important;
  color: #fbbf24 !important;
  border: 1px solid rgba(245, 158, 11, 0.3);
}

.dark .badge-danger {
  background-color: rgba(239, 68, 68, 0.15) !important;
  color: #f87171 !important;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

/* Dark Mode Links */
.dark a:not([class*="bg-"]):not([class*="btn"]) {
  color: inherit;
}

.dark a:hover:not([class*="bg-"]):not([class*="btn"]) {
  color: #3b82f6;
}

/* Dark Mode Shadows - Subtle Depth */
.dark [class*="shadow-sm"] {
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.3) !important;
}

.dark [class*="shadow-md"] {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -2px rgba(0, 0, 0, 0.3) !important;
}

.dark [class*="shadow-lg"] {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -4px rgba(0, 0, 0, 0.4) !important;
}

.dark [class*="shadow-xl"] {
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 8px 10px -6px rgba(0, 0, 0, 0.4) !important;
}

/* Dark Mode Dividers */
.dark hr,
.dark [class*="divide-"] > * + * {
  border-color: #1e293b !important;
}

/* Dark Mode Scrollbar */
.dark ::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

.dark ::-webkit-scrollbar-track {
  background: #0f172a;
}

.dark ::-webkit-scrollbar-thumb {
  background: #334155;
  border-radius: 4px;
}

.dark ::-webkit-scrollbar-thumb:hover {
  background: #475569;
}

/* Dark Mode Selection */
.dark ::selection {
  background-color: rgba(59, 130, 246, 0.3);
  color: #f1f5f9;
}

/* Dark Mode Focus States */
.dark *:focus-visible {
  outline-color: #3b82f6 !important;
}

/* Dark Mode Progress Bars */
.dark progress::-webkit-progress-bar {
  background-color: #1e293b;
}

.dark progress::-webkit-progress-value {
  background-color: #3b82f6;
}

/* Dark Mode Range Inputs */
.dark input[type="range"] {
  background: #1e293b;
}

.dark input[type="range"]::-webkit-slider-thumb {
  background: #3b82f6;
}
