/* Holy Nation Prophetic Church - Responsive Styles */

/* Mobile First Approach - Base styles are mobile-first in main.css */

/* ========================================
   MOBILE LAYOUTS (< 768px)
   ======================================== */

/* Extra Small Mobile (< 480px) */
@media (max-width: 479px) {
  /* Typography adjustments for very small screens */
  h1 {
    font-size: var(--font-size-2xl) !important;
    line-height: 1.2;
  }
  
  h2 {
    font-size: var(--font-size-xl) !important;
  }
  
  h3 {
    font-size: var(--font-size-lg) !important;
  }
  
  /* Container padding for small screens */
  .container {
    padding: 0 var(--space-3);
  }
  
  /* Hero section adjustments */
  .hero {
    padding: var(--space-8) var(--space-3);
  }
  
  .hero h1 {
    font-size: var(--font-size-2xl) !important;
  }
  
  .hero-subtitle {
    font-size: var(--font-size-base);
  }
  
  /* Button sizing */
  .btn {
    width: 100%;
    justify-content: center;
  }
  
  .btn-sm {
    padding: var(--space-2) var(--space-3);
  }
  
  /* Card adjustments */
  .card {
    padding: var(--space-4);
  }
  
  /* Form elements */
  .form-input,
  .form-textarea,
  .form-select {
    font-size: 16px; /* Prevents zoom on iOS */
  }
}

/* Small Mobile (320px+) */
@media (min-width: 320px) {
  .container {
    padding: 0 var(--space-4);
  }
}

/* Large Mobile (480px+) */
@media (min-width: 480px) {
  .hero h1 {
    font-size: var(--font-size-4xl);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-lg);
  }
  
  .hero-actions-secondary {
    flex-direction: row;
  }
  
  /* Allow buttons to be inline on larger mobile */
  .btn {
    width: auto;
  }
}

/* Mobile-specific optimizations (< 768px) */
@media (max-width: 767px) {
  /* Ensure all touch targets are minimum 44x44px */
  .btn,
  .nav-link,
  input[type="button"],
  input[type="submit"],
  .social-links a {
    min-height: 44px;
    min-width: 44px;
    padding: var(--space-3) var(--space-4);
  }
  
  /* Navigation optimizations */
  .site-header {
    position: sticky;
    top: 0;
    overflow-x: hidden;
  }
  
  .site-header .header-nav-row.container {
    padding: 0 var(--space-3);
  }
  
  .nav-menu {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  
  .nav-menu::-webkit-scrollbar {
    display: none;
  }
  
  .nav-list {
    gap: var(--space-1);
  }
  
  .nav-item {
    margin-left: 0;
    flex-shrink: 0;
  }
  
  .nav-brand {
    flex: 1;
  }
  
  /* Hero section mobile optimization */
  .hero {
    padding: var(--space-12) var(--space-4);
    text-align: center;
  }
  
  .hero-actions {
    flex-direction: column;
    width: 100%;
  }
  
  .hero-actions .btn {
    width: 100%;
    max-width: 320px;
  }
  
  /* Service times - stack vertically */
  .service-schedule {
    grid-template-columns: 1fr !important;
    gap: var(--space-4);
  }
  
  .service-item {
    padding: var(--space-5);
  }
  
  /* Events grid - single column */
  .events-grid {
    grid-template-columns: 1fr !important;
  }
  
  .event-card {
    padding: var(--space-5);
  }
  
  /* Sermon content - stack vertically */
  .sermon-content-wrapper {
    grid-template-columns: 1fr !important;
    gap: var(--space-6);
  }
  
  /* Featured blog - stack vertically */
  .featured-blog-card {
    grid-template-columns: 1fr !important;
  }
  
  .featured-blog-image {
    min-height: 200px;
  }
  
  /* About page content - stack vertically */
  .about-content {
    grid-template-columns: 1fr !important;
    gap: var(--space-6);
  }
  
  .about-content.reverse {
    direction: ltr !important;
  }
  
  /* Mission points - single column */
  .mission-points {
    grid-template-columns: 1fr !important;
  }
  
  /* Values grid - single column */
  .values-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Beliefs grid - single column */
  .beliefs-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Leadership grid - single column */
  .leadership-grid {
    grid-template-columns: 1fr !important;
  }

  .leader-card-presiding {
    grid-template-columns: 1fr !important;
  }

  .leadership-row {
    grid-template-columns: 1fr !important;
  }
  
  /* Ministries grid - single column */
  .ministries-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Visitor info grid - single column */
  .visitor-info-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Footer - stack columns */
  .footer-content {
    grid-template-columns: 1fr !important;
    gap: var(--space-6);
  }
  
  .footer-bottom-content {
    flex-direction: column;
    text-align: center;
    gap: var(--space-4);
  }
  
  .footer-bottom-links {
    flex-direction: column;
    gap: var(--space-2);
  }
  
  /* Forms - full width inputs */
  .form-input,
  .form-textarea,
  .form-select {
    width: 100%;
    font-size: 16px; /* Prevents iOS zoom */
  }
  
  .form-group {
    margin-bottom: var(--space-4);
  }
  
  /* Button groups - stack vertically */
  .btn-group,
  .form-actions,
  .cta-actions,
  .hero-actions,
  .sermon-actions,
  .event-actions,
  .visitor-actions {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }
  
  .btn-group .btn,
  .form-actions .btn,
  .cta-actions .btn {
    width: 100%;
  }
  
  /* Tables - make scrollable */
  table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  /* Images - ensure responsiveness */
  img {
    max-width: 100%;
    height: auto;
  }
  
  /* Video embeds - maintain aspect ratio */
  .video-wrapper,
  iframe[src*="youtube"],
  iframe[src*="vimeo"] {
    max-width: 100%;
  }
  
  /* Social links - adjust sizing */
  .social-links {
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .social-links a {
    width: 44px;
    height: 44px;
  }
  
  /* Page header adjustments */
  .page-header {
    padding: var(--space-8) var(--space-4);
  }
  
  .page-header-content h1 {
    font-size: var(--font-size-2xl);
  }
  
  .page-subtitle {
    font-size: var(--font-size-base);
  }
  
  /* Breadcrumb adjustments */
  .breadcrumb-bar .breadcrumb {
    font-size: var(--font-size-xs);
    flex-wrap: wrap;
  }
  
  /* Card grid - single column */
  .card-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Reduce spacing on mobile */
  section {
    padding: var(--space-8) 0;
  }
  
  .section-header {
    margin-bottom: var(--space-6);
  }
  
  .section-header h2 {
    font-size: var(--font-size-2xl);
  }
  
  /* Timeline adjustments */
  .timeline-item {
    gap: var(--space-3);
  }
  
  .timeline-year {
    width: 50px;
    height: 50px;
    font-size: var(--font-size-xs);
  }
  
  /* Newsletter form - stack vertically */
  .newsletter-form {
    flex-direction: column;
  }
  
  .newsletter-input {
    width: 100%;
  }
  
  /* Floating action buttons - adjust position */
  .floating-kids-corner-link,
  .floating-salvation-link {
    right: var(--space-4);
    bottom: var(--space-4);
  }
  
  .floating-salvation-link {
    bottom: calc(var(--space-4) + 56px + var(--space-3));
  }
  
  /* Hide tooltips on mobile (too small) */
  .floating-kids-corner-tooltip,
  .floating-salvation-tooltip {
    display: none;
  }
}

/* ========================================
   TABLET LAYOUTS (768px - 1024px)
   ======================================== */

/* Tablet Portrait (768px+) */
@media (min-width: 768px) {
  .container {
    padding: 0 var(--space-8);
  }
  
  .hero {
    padding: var(--space-24) 0;
  }
  
  .hero h1 {
    font-size: var(--font-size-5xl);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-xl);
  }
  
  .hero-actions {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
  }
  
  .hero-actions .btn-hero-primary {
    margin-right: 0.5rem;
  }
  
  .hero-actions-secondary {
    display: inline-flex;
  }
  
  /* Navigation responsive adjustments */
  .nav-item {
    margin-left: var(--space-6);
  }
  
  /* Footer responsive layout */
  .footer-content {
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
  }
  
  .footer-bottom-content {
    flex-direction: row;
    justify-content: space-between;
  }
  
  /* Card responsive layouts */
  .card-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }
  
  /* Service schedule - 2 columns on tablet */
  .service-schedule {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Events grid - 2 columns */
  .events-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* About content - 2 columns */
  .about-content {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
  
  /* Mission points - 2 columns */
  .mission-points {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Values grid - 2 columns */
  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Beliefs grid - 2 columns */
  .beliefs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Leadership grid - 2 columns */
  .leadership-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Ministries grid - 2 columns */
  .ministries-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Visitor info grid - 2 columns */
  .visitor-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Button groups - can be horizontal */
  .btn-group,
  .form-actions,
  .cta-actions {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .btn-group .btn,
  .form-actions .btn {
    width: auto;
    min-width: 120px;
  }
}

/* Tablet-specific optimizations (768px - 1024px) */
@media (min-width: 768px) and (max-width: 1023px) {
  /* Optimize spacing for tablet */
  .container {
    max-width: 100%;
    padding: 0 var(--space-6);
  }
  
  /* Typography adjustments */
  h1 {
    font-size: var(--font-size-4xl);
  }
  
  h2 {
    font-size: var(--font-size-3xl);
  }
  
  /* Touch targets still important on tablets */
  .btn,
  .nav-link,
  button,
  a.btn {
    min-height: 44px;
    padding: var(--space-3) var(--space-5);
  }
  
  /* Navigation - may still use hamburger menu */
  .nav-toggle {
    display: flex;
  }
  
  .nav-menu {
    position: fixed;
    width: min(360px, 85vw);
  }
  
  /* Sermon content - can be side by side */
  .sermon-content-wrapper {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }
  
  /* Featured blog - side by side */
  .featured-blog-card {
    grid-template-columns: 1fr 1fr;
  }
  
  /* Service schedule - 3 columns if space allows */
  .service-schedule {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }
  
  /* Adjust grid gaps */
  .card-grid,
  .events-grid,
  .ministries-grid,
  .leadership-grid {
    gap: var(--space-5);
  }
  
  /* Page header */
  .page-header {
    padding: var(--space-10) var(--space-6);
  }
  
  .page-header-content h1 {
    font-size: var(--font-size-3xl);
  }
  
  /* Footer - adjust columns */
  .footer-content {
    grid-template-columns: 1.5fr 1fr 1fr 1.5fr;
    gap: var(--space-5);
  }
  
  /* Forms - optimize width */
  .form-input,
  .form-textarea,
  .form-select {
    max-width: 100%;
  }
  
  /* Tables - may still need scroll */
  table {
    font-size: var(--font-size-sm);
  }
  
  /* Social media section */
  .social-feeds-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }
  
  /* Optimize image sizes */
  .leader-image,
  .ministry-image {
    height: 220px;
  }
  
  /* Timeline - adjust spacing */
  .timeline-item {
    gap: var(--space-5);
  }
  
  .timeline-year {
    width: 56px;
    height: 56px;
  }
}

/* Tablet Landscape (1024px+) */
@media (min-width: 1024px) {
  .container {
    padding: 0 var(--space-12);
  }
  
  .hero {
    padding: var(--space-32) 0;
  }
  
  .hero h1 {
    font-size: var(--font-size-6xl);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-2xl);
  }
  
  /* Navigation spacing */
  .nav-item {
    margin-left: var(--space-8);
  }
  
  /* Three column card layouts */
  .card-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  /* Typography responsive scaling */
  h2 {
    font-size: var(--font-size-5xl);
  }
  
  h3 {
    font-size: var(--font-size-4xl);
  }
}

/* Desktop (1200px+) */
@media (min-width: 1200px) {
  .container {
    padding: 0 var(--space-16);
    max-width: 1200px;
  }
  
  /* Four column layouts for larger screens */
  .card-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
}

/* Large Desktop (1440px+) */
@media (min-width: 1440px) {
  .container {
    padding: 0 var(--space-20);
    max-width: 1400px;
  }
  
  .hero h1 {
    font-size: 4rem;
  }
}

/* Ultra Wide (1920px+) */
@media (min-width: 1920px) {
  .container {
    max-width: 1600px;
  }
}

/* High DPI / Retina Displays */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  /* Optimize for high-DPI displays */
  .brand-logo {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}

/* Reduced Motion Preferences */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  
  .hero::before {
    animation: none;
  }
  
  .hero-content {
    animation: none;
  }
}

/* Dark Mode Support (Future Enhancement) */
@media (prefers-color-scheme: dark) {
  /* Dark mode styles would go here */
  /* Currently maintaining light theme as per design requirements */
}

/* Print Styles */
@media print {
  * {
    background: transparent !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  .nav-toggle,
  .social-links,
  .newsletter-form,
  .btn {
    display: none !important;
  }
  
  .site-header {
    position: static;
    box-shadow: none;
    border-bottom: 1px solid #ccc;
  }
  
  .site-footer {
    border-top: 1px solid #ccc;
    background: transparent;
    color: black;
  }
  
  /* Only show URL for external (http) links when printing */
  a[href^="http"]:after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
  }
  /* Never show path/URL for internal links (prevents /events, /resources, /give appearing as text) */
  a[href^="/"]::after {
    content: none !important;
  }
  /* Don't show URL on header/breadcrumb links when printing */
  .site-header a::after,
  .breadcrumb-bar .breadcrumb a::after {
    content: none !important;
  }
}

/* Focus Styles for Accessibility */
@media (prefers-reduced-motion: no-preference) {
  :focus-visible {
    outline: 2px solid var(--primary-blue);
    outline-offset: 2px;
    border-radius: var(--radius-base);
  }
}

/* Container Queries (Future Enhancement) */
/* When browser support improves, these can be used for component-level responsive design */

/* Utility Classes for Responsive Design */
.hidden-mobile {
  display: none;
}

.hidden-tablet {
  display: block;
}

.hidden-desktop {
  display: block;
}

@media (min-width: 768px) {
  .hidden-mobile {
    display: block;
  }
  
  .hidden-tablet {
    display: none;
  }
  
  .show-tablet {
    display: block;
  }
}

@media (min-width: 1024px) {
  .hidden-desktop {
    display: none;
  }
  
  .show-desktop {
    display: block;
  }
}

/* Responsive Text Alignment */
.text-center-mobile {
  text-align: center;
}

@media (min-width: 768px) {
  .text-left-tablet {
    text-align: left;
  }
  
  .text-center-mobile {
    text-align: left;
  }
}

/* Responsive Spacing */
.mb-mobile {
  margin-bottom: var(--space-4);
}

.mb-tablet {
  margin-bottom: var(--space-4);
}

@media (min-width: 768px) {
  .mb-mobile {
    margin-bottom: 0;
  }
  
  .mb-tablet {
    margin-bottom: var(--space-6);
  }
}

/* Page header & breadcrumb - mobile */
@media (max-width: 767px) {
  .page-header {
    padding: var(--space-8) 0 var(--space-6) 0;
  }
  
  .page-header-content h1 {
    font-size: var(--font-size-2xl);
    line-height: 1.2;
  }
  
  .page-subtitle {
    font-size: var(--font-size-base);
  }
  
  .breadcrumb-bar .breadcrumb {
    font-size: var(--font-size-xs);
    padding: var(--space-2) 0;
  }
  
  .breadcrumb-bar .breadcrumb-current {
    padding-left: var(--space-2);
    border-left-width: 2px;
  }
  
  .contact-grid {
    gap: var(--space-8);
  }
  
  .contact-info,
  .appointment-booking {
    padding: var(--space-6);
  }
  
  .contact-form-section .form-actions {
    flex-direction: column;
  }
  
  .contact-form-section .form-actions .btn {
    width: 100%;
  }
  
  .resource-filters .filter-controls {
    flex-direction: column;
    align-items: stretch;
  }
  
  .resource-filters .filter-select,
  .resource-filters .search-input {
    min-width: 100%;
  }
  
  /* Resources: stack content and download on small screens */
  .resources-content .resource-item {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  
  .resources-content .resource-item-actions {
    justify-self: start;
  }
  
  .resources-content .resource-item-actions .download-link {
    width: 100%;
    justify-content: center;
  }
  
  .resource-group-header,
  .resources-content .resource-item {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }
  
  .quick-access-grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   RESPONSIVE UTILITIES
   ======================================== */

/* Visibility utilities */
.hidden-mobile {
  display: none;
}

.hidden-tablet {
  display: block;
}

.hidden-desktop {
  display: block;
}

@media (min-width: 768px) {
  .hidden-mobile {
    display: block;
  }
  
  .hidden-tablet {
    display: none;
  }
  
  .show-tablet {
    display: block;
  }
}

@media (min-width: 1024px) {
  .hidden-desktop {
    display: none;
  }
  
  .show-desktop {
    display: block;
  }
  
  .hidden-tablet {
    display: block;
  }
}

/* Responsive Text Alignment */
.text-center-mobile {
  text-align: center;
}

@media (min-width: 768px) {
  .text-left-tablet {
    text-align: left;
  }
  
  .text-center-mobile {
    text-align: left;
  }
}

/* Responsive Spacing */
.mb-mobile {
  margin-bottom: var(--space-4);
}

.mb-tablet {
  margin-bottom: var(--space-4);
}

@media (min-width: 768px) {
  .mb-mobile {
    margin-bottom: 0;
  }
  
  .mb-tablet {
    margin-bottom: var(--space-6);
  }
}

/* Responsive Flex Direction */
.flex-column-mobile {
  flex-direction: column;
}

@media (min-width: 768px) {
  .flex-row-tablet {
    flex-direction: row;
  }
}

/* Responsive Width */
.full-width-mobile {
  width: 100%;
}

@media (min-width: 768px) {
  .auto-width-tablet {
    width: auto;
  }
}

/* ========================================
   TOUCH DEVICE OPTIMIZATIONS
   ======================================== */

/* Enhance touch targets on touch devices */
@media (hover: none) and (pointer: coarse) {
  /* Touch device detected */
  .btn,
  .nav-link,
  button,
  a.btn,
  input[type="button"],
  input[type="submit"],
  .social-links a,
  .card,
  .event-card,
  .ministry-card {
    min-height: 44px;
    min-width: 44px;
  }
  
  /* Increase tap area for links */
  a {
    padding: var(--space-1) 0;
  }
  
  /* Remove hover effects on touch devices */
  .btn:hover,
  .card:hover,
  .event-card:hover {
    transform: none;
  }
  
  /* Add active states instead */
  .btn:active {
    transform: scale(0.98);
  }
  
  .card:active,
  .event-card:active {
    transform: translateY(1px);
  }
}

/* ========================================
   LANDSCAPE ORIENTATION OPTIMIZATIONS
   ======================================== */

/* Mobile landscape */
@media (max-width: 767px) and (orientation: landscape) {
  .hero {
    padding: var(--space-8) var(--space-4);
  }
  
  .page-header {
    padding: var(--space-6) var(--space-4);
  }
  
  /* Reduce vertical spacing in landscape */
  section {
    padding: var(--space-6) 0;
  }
  
  .section-header {
    margin-bottom: var(--space-4);
  }
}

/* Tablet landscape */
@media (min-width: 768px) and (max-width: 1023px) and (orientation: landscape) {
  /* Optimize for landscape tablet viewing */
  .container {
    max-width: 100%;
  }
  
  .service-schedule {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .events-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ========================================
   PRINT OPTIMIZATIONS
   ======================================== */

@media print {
  /* Hide interactive elements */
  .nav-toggle,
  .floating-kids-corner-link,
  .floating-salvation-link,
  .social-links,
  .newsletter-form,
  .btn,
  button {
    display: none !important;
  }
  
  /* Optimize layout for print */
  .container {
    max-width: 100%;
    padding: 0;
  }
  
  /* Remove backgrounds */
  .hero,
  .page-header,
  .cta-section {
    background: none !important;
    color: black !important;
  }
  
  /* Ensure readability */
  body {
    font-size: 12pt;
    line-height: 1.5;
  }
  
  h1 { font-size: 24pt; }
  h2 { font-size: 20pt; }
  h3 { font-size: 16pt; }
  
  /* Page breaks */
  h1, h2, h3 {
    page-break-after: avoid;
  }
  
  .card,
  .event-card,
  .ministry-card {
    page-break-inside: avoid;
  }
}