/**
 * Responsive Styles - SQL ForgeMaster Theme
 * Mobile-first approach with breakpoints for tablet, mobile, and small mobile
 *
 * @package SQL_ForgeMaster
 */

/* ========================================
   TABLET (max-width: 1024px)
   ======================================== */
@media (max-width: 1024px) {
	:root {
		--text-7xl: 3rem;
		--text-6xl: 2.5rem;
		--text-5xl: 2.25rem;
		--text-4xl: 1.75rem;
	}

	.sqlfm-container {
		padding: 0 var(--space-4);
	}

	.sqlfm-section {
		padding: var(--space-16) 0;
	}

	/* Hero */
	.sqlfm-hero-l1,
	.sqlfm-hero-l3 {
		min-height: 70vh;
	}

	.sqlfm-hero-l2 {
		min-height: auto;
	}

	.sqlfm-hero-split {
		grid-template-columns: 1fr;
		gap: var(--space-8);
		padding: var(--space-12) 0;
	}

	.sqlfm-hero-split--reverse .sqlfm-hero-text,
	.sqlfm-hero-split--reverse .sqlfm-hero-image-wrap {
		order: unset;
	}

	.sqlfm-hero-image-wrap {
		order: -1;
	}

	.sqlfm-hero-image-frame-inner img {
		height: 340px;
	}

	.sqlfm-hero-image-badge {
		bottom: -12px;
		left: 12px;
	}

	.sqlfm-hero-stats-inner {
		gap: var(--space-6);
	}

	.sqlfm-hero-stats-sep {
		display: none;
	}

	/* About */
	.sqlfm-about-split {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	.sqlfm-about-image-secondary {
		right: 0;
		bottom: -20px;
	}

	.sqlfm-about-stats {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Services */
	.sqlfm-services-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-service-row {
		grid-template-columns: 1fr;
	}

	.sqlfm-service-row-reverse {
		direction: ltr;
	}

	.sqlfm-tab-panel-inner {
		grid-template-columns: 1fr;
	}

	/* Features */
	.sqlfm-features-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-features-split {
		grid-template-columns: 1fr;
	}

	.sqlfm-features-image {
		order: -1;
	}

	.sqlfm-features-horizontal {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Portfolio */
	.sqlfm-portfolio-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-portfolio-slide {
		flex: 0 0 calc(50% - 12px);
	}

	.sqlfm-portfolio-list-item {
		grid-template-columns: 200px 1fr;
	}

	/* Testimonials */
	.sqlfm-tl1-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-tl2-slider {
		padding: 0 var(--space-12);
	}

	.sqlfm-tl3-split {
		grid-template-columns: 1fr;
		gap: var(--space-10);
	}

	.sqlfm-tl3-left {
		position: static;
	}

	/* CTA */
	.sqlfm-cta-split {
		grid-template-columns: 1fr;
	}

	.sqlfm-cta-split-image {
		order: -1;
	}

	.sqlfm-cta-inline {
		flex-direction: column;
		text-align: center;
	}

	.sqlfm-cta-inline-actions {
		justify-content: center;
	}

	/* Contact */
	.sqlfm-ct1-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-ct1-form-row {
		grid-template-columns: 1fr;
	}

	.sqlfm-ct2-cards {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-ct2-form-row {
		grid-template-columns: 1fr 1fr;
	}

	.sqlfm-ct3-card {
		padding: var(--space-8) var(--space-8);
	}

	/* Clients */
	.sqlfm-clients-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	/* Services Detailed */
	.sqlfm-services-detailed-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-accordion-body-inner {
		grid-template-columns: 1fr;
	}

	.sqlfm-service-full-split {
		grid-template-columns: 1fr;
	}

	.sqlfm-service-full-row-reverse .sqlfm-service-full-split {
		direction: ltr;
	}

	.sqlfm-service-full-image img {
		height: 300px;
	}

	/* Services Layout 1 */
	.sqlfm-sv1-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Services Layout 2 */
	.sqlfm-sv2-row {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}

	.sqlfm-sv2-row--flip .sqlfm-sv2-image,
	.sqlfm-sv2-row--flip .sqlfm-sv2-content {
		order: unset;
	}

	.sqlfm-sv2-image-frame img {
		height: 260px;
	}

	/* Services Layout 3 */
	.sqlfm-sv3-panel-inner {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}

	.sqlfm-sv3-panel-image img {
		height: 260px;
	}

	/* CTA Layout 2 */
	.sqlfm-cta2-split {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	.sqlfm-cta2-split--flip .sqlfm-cta2-image,
	.sqlfm-cta2-split--flip .sqlfm-cta2-content {
		order: unset;
	}

	.sqlfm-cta2-image-frame img {
		height: 320px;
	}

	/* CTA Layout 3 */
	.sqlfm-cta3-bar {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--space-5);
	}

	.sqlfm-cta3-actions {
		width: 100%;
	}

	/* Footer */
	.sqlfm-footer-layout1 .sqlfm-footer-grid,
	.sqlfm-footer-layout2 .sqlfm-footer-grid,
	.sqlfm-footer-grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-footer-compact-inner {
		flex-direction: column;
		text-align: center;
		gap: var(--space-5);
	}

	.sqlfm-footer-brand {
		flex-direction: column;
		align-items: center;
	}

	.sqlfm-footer-brand .sqlfm-copyright {
		text-align: center;
	}

	.sqlfm-footer-nav {
		justify-content: center;
		width: 100%;
	}

	.sqlfm-footer-social {
		justify-content: center;
	}

	.sqlfm-footer-bottom-inner {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	/* Contact Page */
	.sqlfm-contact-page-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-post-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ========================================
   MOBILE (max-width: 768px)
   ======================================== */
@media (max-width: 768px) {
	:root {
		--text-7xl: 2.5rem;
		--text-6xl: 2rem;
		--text-5xl: 1.75rem;
		--text-4xl: 1.5rem;
		--text-3xl: 1.25rem;
		--text-2xl: 1.125rem;
		--space-20: 4rem;
		--space-16: 3rem;
		--space-12: 2rem;
	}

	/* Header */
	.sqlfm-header-inner {
		flex-wrap: wrap;
	}

	.main-navigation {
		display: none;
		width: 100%;
		order: 3;
	}

	.main-navigation.toggled {
		display: block;
	}

	.main-navigation ul {
		flex-direction: column;
		gap: 0;
	}

	.main-navigation ul ul {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border: none;
		padding-left: var(--space-4);
	}

	.menu-toggle {
		display: flex;
	}

	.sqlfm-header-actions {
		margin-left: auto;
	}

	/* Hide CTA text on small screens — keep icon-only if needed */
	.sqlfm-header-cta {
		padding: var(--space-3) var(--space-4);
		font-size: var(--text-xs);
		letter-spacing: 1px;
	}

	/* Hero */
	.sqlfm-hero-l1,
	.sqlfm-hero-l3 {
		min-height: 60vh;
	}

	.sqlfm-hero-actions {
		flex-direction: column;
		width: 100%;
	}

	.sqlfm-hero-actions .sqlfm-btn {
		width: 100%;
		justify-content: center;
	}

	.sqlfm-hero-align-center .sqlfm-hero-actions,
	.sqlfm-hero-align-left .sqlfm-hero-actions,
	.sqlfm-hero-align-right .sqlfm-hero-actions {
		align-items: stretch;
	}

	.sqlfm-hero-trust {
		gap: var(--space-4);
	}

	.sqlfm-hero-image-frame-inner img {
		height: 280px;
	}

	.sqlfm-hero-stats-strip {
		padding: var(--space-4) 0;
	}

	.sqlfm-hero-stats-inner {
		gap: var(--space-6);
		justify-content: space-around;
	}

	.sqlfm-hero-stat strong {
		font-size: var(--text-2xl);
	}

	/* Sections */
	.sqlfm-section {
		padding: var(--space-12) 0;
	}

	.sqlfm-section-subtitle {
		font-size: var(--text-xs);
		letter-spacing: 2px;
	}

	/* Services */
	.sqlfm-services-grid {
		grid-template-columns: 1fr;
	}

	/* Features */
	.sqlfm-features-grid,
	.sqlfm-features-horizontal {
		grid-template-columns: 1fr;
	}

	/* Portfolio */
	.sqlfm-portfolio-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-portfolio-slide {
		flex: 0 0 calc(80% - 12px);
	}

	.sqlfm-portfolio-list-item {
		grid-template-columns: 1fr;
	}

	.sqlfm-portfolio-filters {
		gap: var(--space-2);
	}

	.sqlfm-filter-btn {
		padding: var(--space-2) var(--space-4);
		font-size: var(--text-xs);
	}

	/* Testimonials */
	.sqlfm-tl1-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-tl2-slider {
		padding: 0 var(--space-10);
	}

	.sqlfm-tl2-card {
		padding: var(--space-8) var(--space-6) var(--space-6);
	}

	.sqlfm-tl2-text {
		font-size: var(--text-lg);
	}

	.sqlfm-tl2-prev,
	.sqlfm-tl2-next {
		width: 40px;
		height: 40px;
	}

	.sqlfm-tl3-stats {
		gap: var(--space-6);
	}

	/* Services Layout 1 */
	.sqlfm-sv1-grid {
		grid-template-columns: 1fr;
	}

	/* Services Layout 2 */
	.sqlfm-sv2-row {
		padding: var(--space-6);
	}

	/* Services Layout 3 */
	.sqlfm-sv3-nav {
		gap: var(--space-1);
		padding: var(--space-3) var(--space-4);
	}

	.sqlfm-sv3-tab {
		padding: var(--space-2) var(--space-4);
		font-size: var(--text-xs);
	}

	.sqlfm-sv3-panels {
		padding: var(--space-6) var(--space-5);
	}

	/* CTA Layout 1 */
	.sqlfm-cta1-inner {
		padding: var(--space-10) 0;
	}

	.sqlfm-cta1-actions {
		flex-direction: column;
		width: 100%;
	}

	.sqlfm-cta1-actions .sqlfm-btn {
		width: 100%;
		justify-content: center;
	}

	/* CTA Layout 2 */
	.sqlfm-cta2-image-frame img {
		height: 260px;
	}

	.sqlfm-cta2-actions {
		flex-direction: column;
		width: 100%;
	}

	.sqlfm-cta2-actions .sqlfm-btn {
		width: 100%;
		justify-content: center;
	}

	/* CTA Layout 3 */
	.sqlfm-cta3-bar {
		padding: var(--space-6) var(--space-6);
	}

	.sqlfm-cta3-actions .sqlfm-btn {
		width: 100%;
		justify-content: center;
	}

	/* CTA (old classes backward compat) */
	.sqlfm-cta-buttons {
		flex-direction: column;
	}

	.sqlfm-cta-buttons .sqlfm-btn {
		width: 100%;
	}

	.sqlfm-cta-inline-actions {
		flex-direction: column;
		width: 100%;
	}

	.sqlfm-cta-inline-actions .sqlfm-btn {
		width: 100%;
	}

	/* Contact */
	.sqlfm-form-row {
		grid-template-columns: 1fr;
	}

	/* Layout 1 */
	.sqlfm-ct1-form-wrap {
		padding: var(--space-6);
	}

	.sqlfm-ct1-form-row {
		grid-template-columns: 1fr;
	}

	/* Layout 2 */
	.sqlfm-ct2-cards {
		grid-template-columns: 1fr;
	}

	.sqlfm-ct2-form-row {
		grid-template-columns: 1fr;
	}

	.sqlfm-ct2-form-footer {
		justify-content: stretch;
	}

	.sqlfm-ct2-form-footer .sqlfm-btn {
		width: 100%;
		justify-content: center;
	}

	/* Layout 3 */
	.sqlfm-ct3-card {
		padding: var(--space-6) var(--space-6);
	}

	.sqlfm-ct3-form-row {
		grid-template-columns: 1fr;
	}

	.sqlfm-ct3-strip {
		flex-direction: column;
		gap: var(--space-4);
		text-align: center;
	}

	.sqlfm-ct3-strip-sep {
		width: 40px;
		height: 1px;
	}

	/* Clients */
	.sqlfm-clients-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Services Detailed */
	.sqlfm-services-detailed-grid {
		grid-template-columns: 1fr;
	}

	/* About */
	.sqlfm-about-stats {
		grid-template-columns: repeat(2, 1fr);
	}

	.sqlfm-about-image-secondary {
		display: none;
	}

	/* Footer */
	.sqlfm-footer-layout1 .sqlfm-footer-grid,
	.sqlfm-footer-layout2 .sqlfm-footer-grid,
	.sqlfm-footer-grid-4 {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	/* 404 */
	.sqlfm-404 {
		padding: var(--space-16) 0;
	}

	.sqlfm-404-title {
		font-size: var(--text-5xl);
	}

	.sqlfm-404-actions {
		flex-direction: column;
	}

	/* Posts */
	.sqlfm-post-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-single-meta {
		flex-wrap: wrap;
	}

	.sqlfm-single-post {
		padding: var(--space-8) 0;
	}

	/* Contact Page */
	.sqlfm-contact-page-hours li {
		flex-direction: column;
		gap: var(--space-1);
	}

	/* Back to top */
	.sqlfm-back-to-top {
		bottom: var(--space-4);
		right: var(--space-4);
		width: 44px;
		height: 44px;
	}

	/* Tabs */
	.sqlfm-services-tab-nav {
		flex-direction: column;
	}

	.sqlfm-tab-btn {
		flex-direction: row;
		justify-content: flex-start;
		padding: var(--space-4);
	}

	.sqlfm-tab-btn::after {
		left: 0;
		top: 0;
		bottom: 0;
		width: 3px;
		height: auto;
		right: auto;
	}
}

/* ========================================
   SMALL MOBILE (max-width: 480px)
   ======================================== */
@media (max-width: 480px) {
	:root {
		--text-7xl: 2rem;
		--text-6xl: 1.75rem;
		--text-5xl: 1.5rem;
	}

	.sqlfm-container {
		padding: 0 var(--space-3);
	}

	.sqlfm-header-inner {
		padding: var(--space-3) var(--space-4);
		gap: var(--space-3);
	}

	/* Hide header CTA button on very small screens */
	.sqlfm-header-cta {
		display: none;
	}

	.sqlfm-btn {
		padding: var(--space-3) var(--space-6);
		font-size: var(--text-xs);
	}

	.sqlfm-clients-grid {
		grid-template-columns: 1fr;
	}

	.sqlfm-about-stats {
		grid-template-columns: 1fr;
	}

	.sqlfm-hero-badge {
		font-size: var(--text-xs);
		letter-spacing: 2px;
	}

	.sqlfm-hero-trust {
		display: none;
	}

	/* Services L1 */
	.sqlfm-sv1-card-inner {
		padding: var(--space-6);
	}

	/* Services L2 */
	.sqlfm-sv2-row {
		padding: var(--space-5);
	}

	/* CTA L3 */
	.sqlfm-cta3-bar {
		padding: var(--space-5);
	}

	/* Footer compact */
	.sqlfm-footer-menu-inline {
		flex-direction: column;
		align-items: center;
		gap: var(--space-2);
	}

	.sqlfm-footer-menu-inline li + li::before {
		display: none;
	}

	.sqlfm-service-card {
		padding: var(--space-6);
	}

	.sqlfm-feature-card {
		padding: var(--space-6);
	}

	.sqlfm-tl1-card {
		padding: var(--space-6);
	}

	.sqlfm-tl3-card {
		padding: var(--space-5) var(--space-5);
	}

	.sqlfm-ct1-info-card {
		padding: var(--space-4);
	}

	.sqlfm-ct3-card {
		padding: var(--space-5) var(--space-4);
	}

	.sqlfm-ct3-strip {
		padding: var(--space-4);
	}
}

/* ========================================
   HEADER MOBILE — Layout 1 & 2
   ======================================== */
@media (max-width: 1024px) {
	.sqlfm-header-contact {
		display: none;
	}
}

@media (max-width: 768px) {
	.main-navigation > ul > li > a {
		padding: var(--space-3) var(--space-3);
		border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	}

	.main-navigation > ul > li > a::after {
		display: none;
	}
}

/* ========================================
   LARGE SCREENS (min-width: 1440px)
   ======================================== */
@media (min-width: 1440px) {
	:root {
		--container-normal: 1400px;
	}

	.sqlfm-services-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.sqlfm-features-grid {
		grid-template-columns: repeat(4, 1fr);
	}

	.sqlfm-portfolio-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
