/*
 * AI-Assisted Legal Brief Summarizer Template
 * Responsive CSS - Mobile First Approach
 * Bootstrap 5 Breakpoints Integration
 */

/* ========================================
   BASE MOBILE STYLES (320px+)
   ======================================== */

/* Mobile Typography Adjustments */
:root {
  --font-size-mobile-small: 0.8rem;
  --font-size-mobile-base: 0.9rem;
  --font-size-mobile-lg: 1rem;
  --font-size-mobile-xl: 1.1rem;
  --font-size-mobile-2xl: 1.3rem;
  --font-size-mobile-3xl: 1.6rem;
}

/* Mobile Base Styles */
body {
  font-size: var(--font-size-mobile-base);
}

h1 { font-size: var(--font-size-mobile-3xl); }
h2 { font-size: var(--font-size-mobile-2xl); }
h3 { font-size: var(--font-size-mobile-xl); }
h4 { font-size: var(--font-size-mobile-lg); }
h5 { font-size: var(--font-size-mobile-base); }
h6 { font-size: var(--font-size-mobile-small); }

.navbar-brand {
  font-size: var(--font-size-mobile-lg);
}

/* Mobile Section Padding */
.section {
  padding: 2rem 0;
}

.hero-section {
  min-height: 70vh;
  padding: 2rem 0;
}

/* Mobile Hero Decorative Elements */
.hero-decorative {
  width: 100px;
  height: 100px;
}

/* Mobile Service Cards */
.service-card {
  margin-bottom: 1.58rem;
  padding: 1.5rem;
}

/* Mobile Team Photos */
.team-photo {
  width: 120px;
  height: 120px;
}

/* Mobile Contact Form */
.contact-form {
  padding: 1.5rem;
}

/* Mobile Gallery */
.gallery-item img {
  height: 200px;
}

/* Mobile Blog Cards */
.blog-card img {
  height: 150px;
}

/* ========================================
   SMALL DEVICES (576px+) - Bootstrap sm
   ======================================== */
@media (min-width: 576px) {
  /* Slightly larger typography for small tablets */
  h1 { font-size: 1.88rem; }
  h2 { font-size: 1.51rem; }
  h3 { font-size: 1.29rem; }
  
  .navbar-brand {
    font-size: 1.24rem;
  }
  
  /* Improved spacing */
  .section {
    padding: 3rem 0;
  }
  
  .hero-section {
    min-height: 80vh;
  }
  
  .hero-decorative {
    width: 150px;
    height: 150px;
  }
  
  .service-card {
    padding: 1.75rem;
  }
  
  .team-photo {
    width: 140px;
    height: 140px;
  }
  
  .gallery-item img {
    height: 220px;
  }
  
  .blog-card img {
    height: 180px;
  }
}

/* ========================================
   MEDIUM DEVICES (768px+) - Bootstrap md
   ======================================== */
@media (min-width: 768px) {
  /* Standard typography for tablets */
  body {
    font-size: var(--font-size-base);
  }
  
  h1 { font-size: var(--font-size-3xl); }
  h2 { font-size: var(--font-size-2xl); }
  h3 { font-size: var(--font-size-xl); }
  h4 { font-size: var(--font-size-lg); }
  h5 { font-size: var(--font-size-base); }
  h6 { font-size: var(--font-size-small); }
  
  .navbar-brand {
    font-size: var(--font-size-lg);
  }
  
  /* Full section padding */
  .section {
    padding: var(--section-padding);
  }
  
  .hero-section {
    min-height: 90vh;
  }
  
  .hero-decorative {
    width: 180px;
    height: 180px;
  }
  
  /* Two-column layouts */
  .service-card {
    padding: 2rem;
    margin-bottom: 2rem;
  }
  
  .team-photo {
    width: 150px;
    height: 150px;
  }
  
  .contact-form {
    padding: 2rem;
  }
  
  .gallery-item img {
    height: 240px;
  }
  
  .blog-card img {
    height: 200px;
  }
  
  /* FAQ Grid Layout */
  .faq-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
}

/* ========================================
   LARGE DEVICES (992px+) - Bootstrap lg
   ======================================== */
@media (min-width: 992px) {
  /* Desktop optimizations */
  .hero-section {
    min-height: 100vh;
  }
  
  .hero-decorative {
    width: 200px;
    height: 200px;
  }
  
  /* Three-column layouts where appropriate */
  .gallery-item img {
    height: 250px;
  }
  
  /* Enhanced hover effects for desktop */
  .service-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 17px 35px rgba(0, 0, 0, 0.15);
  }
  
  .blog-card:hover {
    transform: translateY(-3px);
  }
  
  /* Desktop spacing improvements */
  .team-member {
    padding: 2rem;
  }
}

/* ========================================
   EXTRA LARGE DEVICES (1200px+) - Bootstrap xl
   ======================================== */
@media (min-width: 1200px) {
  /* Maximum container width optimizations */
  .hero-decorative.top-right {
    top: 15%;
    right: 15%;
  }
  
  .hero-decorative.bottom-left {
    bottom: 15%;
    left: 15%;
  }
  
  /* Larger gallery images for desktop */
  .gallery-item img {
    height: 280px;
  }
  
  /* Enhanced desktop spacing */
  .service-card {
    padding: 2.5rem;
  }
  
  .contact-form {
    padding: 2.5rem;
  }
}

/* ========================================
   EXTRA EXTRA LARGE DEVICES (1400px+) - Bootstrap xxl
   ======================================== */
@media (min-width: 1400px) {
  /* Ultra-wide display optimizations */
  .hero-decorative {
    width: 250px;
    height: 250px;
  }
  
  .gallery-item img {
    height: 300px;
  }
  
  /* Maximum comfortable padding */
  .service-card {
    padding: 3rem;
  }
  
  .contact-form {
    padding: 3rem;
  }
}

/* ========================================
   PRINT STYLES
   ======================================== */
@media print {
  .hero-decorative,
  .navbar,
  .footer,
  .btn,
  .contact-form {
    display: none !important;
  }
  
  body {
    font-size: 12pt;
    line-height: 1.4;
    color: #000;
    background: #fff;
  }
  
  h1 { font-size: 18pt; }
  h2 { font-size: 16pt; }
  h3 { font-size: 14pt; }
  h4 { font-size: 13pt; }
  h5 { font-size: 12pt; }
  h6 { font-size: 11pt; }
  
  .service-card,
  .review-card,
  .faq-card,
  .blog-card {
    border: 1px solid #cdbcba;
    page-break-inside: avoid;
    margin-bottom: 1rem;
  }
}

/* ========================================
   ACCESSIBILITY IMPROVEMENTS
   ======================================== */

/* Focus indicators */
.btn:focus,
.form-control:focus,
.navbar-nav .nav-link:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .service-card,
  .review-card,
  .faq-card,
  .blog-card {
    border-width: 2px;
    border-color: #000;
  }
}

/* Reduced transparency for accessibility */
@media (prefers-reduced-transparency: reduce) {
  .hero-decorative {
    opacity: 0.05;
  }
}

/* ========================================
   LANDSCAPE MOBILE OPTIMIZATIONS
   ======================================== */
@media (max-height: 500px) and (orientation: landscape) {
  .hero-section {
    min-height: 100vh;
    padding: 1rem 0;
  }
  
  .hero-decorative {
    display: none;
  }
  
  .section {
    padding: 1.5rem 0;
  }
} 

.hero-section h1 {
    padding-top: 175px;
}