/* assets/css/style.min.css — UstaPro Yapı */
/* Kritik CSS header.php inline'da. Burası async yüklenir. */

/* ── YARDIMCI ── */
.container { max-width:1200px; margin:0 auto; padding:0 1.5rem; }
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; }
img { max-width:100%; display:block; }
a { color:inherit; }

/* ── BUTONLAR ── */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-head); font-weight:700; font-size:.95rem;
  letter-spacing:.03em; text-decoration:none; cursor:pointer; border:none;
  padding:.75rem 1.75rem; border-radius:var(--radius);
  transition:background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn:active { transform:scale(.97); }
.btn-primary {
  background:var(--orange); color:#fff;
  box-shadow:0 4px 14px rgba(244,123,32,.4);
  /* Kontrast: #fff on #F47B20 = 3.1:1 — WCAG AA için metin gölgesi */
  text-shadow: 0 1px 2px rgba(0,0,0,.2);
}
.btn-primary:hover { background:var(--orange-dk); box-shadow:0 6px 20px rgba(244,123,32,.5); }
.btn-outline {
  background:transparent; color:var(--white);
  border:2px solid rgba(255,255,255,.7);
}
.btn-outline:hover { background:rgba(255,255,255,.12); border-color:var(--white); }
.btn-navy { background:var(--navy); color:var(--white); }
.btn-navy:hover { background:var(--navy-dark); }

/* ── SECTION BAŞLIK ── */
.section-header { text-align:center; margin-bottom:3.5rem; }
.section-label {
  display:inline-block; background:var(--orange); color:#fff;
  font-family:var(--font-head); font-size:.78rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:.35rem 1rem; border-radius:50px; margin-bottom:.9rem;
  /* WCAG AA: #fff on #F47B20 = 3.1:1 — border ile güçlendiriyoruz */
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.1);
}
/* Beyaz bg üzerindeki section-label için koyu varyant */
.services-home .section-label,
.why-us .section-label,
.gallery-section .section-label,
.about-intro .section-label,
.team-values .section-label,
.services-detail .section-label {
  background: var(--navy); color: #fff;
}
.section-title {
  font-family:var(--font-head); font-size:clamp(1.7rem,4vw,2.4rem);
  font-weight:900; color:var(--navy); line-height:1.2;
}
.section-desc { color:#374151; margin-top:.75rem; font-size:1.05rem; max-width:600px; margin-inline:auto; }
/* gray-600 → #374151 (WCAG AA 7:1 ratio on white) */

/* ══════════════════════════════════
   ANA SAYFA
══════════════════════════════════ */

/* Hero */
.hero {
  position:relative; overflow:hidden; min-height:92vh;
  display:flex; align-items:center;
  background:linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 60%, #1f3a6e 100%);
}
.hero-bg-pattern {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(circle at 70% 50%, rgba(244,123,32,.18) 0%, transparent 55%),
    repeating-linear-gradient(45deg, transparent, transparent 40px, rgba(255,255,255,.015) 40px, rgba(255,255,255,.015) 41px);
}
.hero-inner {
  position:relative; z-index:1; max-width:1200px; margin:0 auto;
  padding:5rem 1.5rem; display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(244,123,32,.2); color:var(--orange);
  border:1px solid rgba(244,123,32,.4);
  font-size:.8rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:.35rem .9rem; border-radius:50px; margin-bottom:1.25rem;
}
.hero-badge span { width:6px; height:6px; background:var(--orange); border-radius:50%; display:inline-block; animation:pulse 1.8s ease infinite; }
.hero h1 {
  font-family:var(--font-head); font-size:clamp(2rem,5vw,3.2rem);
  font-weight:900; color:var(--white); line-height:1.15; margin-bottom:1.25rem;
}
.hero h1 em { font-style:normal; color:var(--orange); }
.hero-desc { color:rgba(255,255,255,.8); font-size:1.1rem; line-height:1.7; margin-bottom:2rem; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; }
.hero-stats {
  display:flex; gap:2rem; margin-top:2.5rem; padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.12); flex-wrap:wrap;
}
.hero-stat-num {
  font-family:var(--font-head); font-size:2rem; font-weight:900; color:var(--orange);
  line-height:1;
}
.hero-stat-label { font-size:.85rem; color:rgba(255,255,255,.65); margin-top:.2rem; }
.hero-image { position:relative; }
.hero-img-wrap {
  border-radius:16px; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  aspect-ratio:4/3;
  background:linear-gradient(135deg,#2d4a7a,#1B2A4A);
  display:flex; align-items:center; justify-content:center;
  /* aspect-ratio ile width+height olmadan da CLS = 0 */
  contain: layout;
}
.hero-img-wrap img { width:100%; height:100%; object-fit:cover; }
.hero-img-badge {
  position:absolute; bottom:1rem; left:1rem;
  background:var(--orange); color:var(--white);
  font-family:var(--font-head); font-weight:700;
  padding:.75rem 1.25rem; border-radius:12px;
  box-shadow:0 8px 24px rgba(244,123,32,.45);
  font-size:.85rem; line-height:1.3;
  max-width:calc(100% - 2rem);
}

/* Services Home */
.services-home { padding:5rem 0; background:var(--gray-50); }
.services-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:1.5rem;
}
.service-card {
  background:var(--white); border-radius:12px; padding:2rem;
  box-shadow:var(--shadow-sm); border:1px solid var(--gray-100);
  transition:transform var(--transition), box-shadow var(--transition);
  text-decoration:none; color:inherit; display:block;
}
.service-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.service-icon {
  width:56px; height:56px; border-radius:12px;
  background:rgba(244,123,32,.12); color:var(--orange);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem;
}
.service-icon svg { width:28px; height:28px; }
.service-card h3 {
  font-family:var(--font-head); font-size:1.1rem; font-weight:700;
  color:var(--navy); margin-bottom:.5rem;
}
.service-card p { color:var(--gray-600); font-size:.95rem; line-height:1.6; }
.service-card .card-arrow {
  display:inline-flex; align-items:center; gap:.35rem;
  color:var(--orange); font-weight:700; font-size:.9rem; margin-top:1rem;
}

/* Why Us */
.why-us { padding:5rem 0; }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.why-image-wrap { position:relative; }
/* aspect-ratio ile CLS = 0 (tarayıcı boyutu önceden ayırır) */
.why-image-wrap img { width:100%; border-radius:16px; box-shadow:var(--shadow-md); aspect-ratio:4/3; object-fit:cover; }
.why-badge-float {
  position:absolute; top:2rem; right:-2rem;
  background:var(--navy); color:var(--white);
  font-family:var(--font-head); font-weight:700;
  padding:1rem 1.5rem; border-radius:12px;
  box-shadow:var(--shadow-md); text-align:center;
  font-size:.85rem;
}
.why-badge-float strong { display:block; font-size:1.8rem; color:var(--orange); }
.why-features { list-style:none; margin:2rem 0; display:flex; flex-direction:column; gap:1.1rem; }
.why-features li { display:flex; gap:1rem; align-items:flex-start; }
.why-check {
  width:28px; height:28px; min-width:28px; border-radius:50%;
  background:var(--orange); color:var(--white);
  display:flex; align-items:center; justify-content:center; margin-top:.1rem;
}
.why-check svg { width:14px; height:14px; }
.why-features strong { font-family:var(--font-head); font-size:.95rem; color:var(--navy); display:block; }
.why-features span { font-size:.9rem; color:var(--gray-600); }

/* Testimonials */
.testimonials { padding:5rem 0; background:var(--navy); }
.testimonials .section-title { color:var(--white); }
.testimonials .section-label { background:rgba(255,255,255,.15); color:rgba(255,255,255,.9); }
.testimonials-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.testimonial-card {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:12px; padding:1.75rem; color:var(--white);
}
.testimonial-stars { color:var(--orange); font-size:1.1rem; margin-bottom:.9rem; }
.testimonial-card blockquote { font-size:.95rem; line-height:1.7; color:rgba(255,255,255,.85); margin:0 0 1.25rem; }
.testimonial-author { display:flex; align-items:center; gap:.75rem; }
.testimonial-avatar {
  width:44px; height:44px; border-radius:50%;
  background:var(--orange); color:var(--white);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-head); font-weight:700; font-size:1.1rem;
}
.testimonial-name { font-family:var(--font-head); font-weight:700; font-size:.9rem; }
.testimonial-loc { font-size:.8rem; color:rgba(255,255,255,.55); }

/* CTA Banner */
.cta-banner {
  padding:5rem 0;
  background:linear-gradient(135deg, var(--orange) 0%, var(--orange-dk) 100%);
  text-align:center;
}
.cta-banner h2 {
  font-family:var(--font-head); font-size:clamp(1.6rem,4vw,2.2rem);
  font-weight:900; color:var(--white); margin-bottom:1rem;
}
.cta-banner p { color:rgba(255,255,255,.9); font-size:1.1rem; margin-bottom:2rem; }
.cta-banner .btn-outline { border-color:rgba(255,255,255,.6); }

/* ══════════════════════════════════
   HAKKIMIZDA
══════════════════════════════════ */
.page-hero {
  background:linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 100%);
  padding:4rem 0; text-align:center; color:var(--white);
}
.page-hero h1 {
  font-family:var(--font-head); font-size:clamp(1.8rem,4vw,2.6rem);
  font-weight:900; margin-bottom:.75rem;
}
.page-hero p { color:rgba(255,255,255,.75); font-size:1.1rem; }

.about-intro { padding:5rem 0; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.about-image img { width:100%; border-radius:16px; box-shadow:var(--shadow-md); }
.about-content .section-label { text-align:left; }
.about-content h2 {
  font-family:var(--font-head); font-size:clamp(1.5rem,3vw,2rem);
  font-weight:900; color:var(--navy); margin-bottom:1rem;
}
.about-content p { color:var(--gray-600); line-height:1.8; margin-bottom:1rem; }

.team-values { padding:5rem 0; background:var(--gray-50); }
.values-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem; }
.value-card { background:var(--white); border-radius:12px; padding:2rem; box-shadow:var(--shadow-sm); text-align:center; }
.value-num {
  font-family:var(--font-head); font-size:2.5rem; font-weight:900;
  color:var(--orange); line-height:1;
}
.value-card h3 { font-family:var(--font-head); font-size:1rem; font-weight:700; color:var(--navy); margin:.5rem 0; }
.value-card p { font-size:.9rem; color:var(--gray-600); }

/* ══════════════════════════════════
   HİZMETLER
══════════════════════════════════ */
.services-detail { padding:5rem 0; }
.service-detail-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:2rem; }
.service-detail-card {
  background:var(--white); border-radius:16px; overflow:hidden;
  box-shadow:var(--shadow-sm); border:1px solid var(--gray-100);
  transition:transform var(--transition), box-shadow var(--transition);
}
.service-detail-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.service-detail-img {
  height:200px; background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  display:flex; align-items:center; justify-content:center;
}
.service-detail-img svg { width:64px; height:64px; color:var(--orange); }
.service-detail-body { padding:1.75rem; }
.service-detail-body h2 { font-family:var(--font-head); font-size:1.25rem; font-weight:800; color:var(--navy); margin-bottom:.75rem; }
.service-detail-body p { color:var(--gray-600); font-size:.95rem; line-height:1.7; margin-bottom:1rem; }
.service-detail-body ul { list-style:none; }
.service-detail-body ul li {
  display:flex; gap:.6rem; align-items:center;
  font-size:.9rem; color:var(--gray-600); padding:.3rem 0;
}
.service-detail-body ul li::before { content:'✓'; color:var(--orange); font-weight:700; }

/* ══════════════════════════════════
   GALERİ
══════════════════════════════════ */
.gallery-section { padding:5rem 0; }

/* Gallery Cards Grid (ana galeri sayfası) */
.gallery-cards-grid {
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem;
}
.gallery-card-link {
  text-decoration:none; color:inherit; display:block;
}
.gallery-card {
  position:relative; border-radius:12px; overflow:hidden;
  box-shadow:var(--shadow-sm); aspect-ratio:4/3;
  background:var(--navy-dark);
  transition:transform var(--transition), box-shadow var(--transition);
}
.gallery-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.gallery-card img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s ease;
}
.gallery-card:hover img { transform:scale(1.05); }
.gallery-card-badge {
  position:absolute; top:1rem; left:1rem;
  color:#fff; font-family:var(--font-head); font-size:.72rem;
  font-weight:700; letter-spacing:.05em;
  padding:.3rem .8rem; border-radius:50px;
  z-index:2;
}
.gallery-card-info {
  position:absolute; bottom:0; left:0; right:0;
  padding:1.25rem; z-index:2; text-align:center;
  background:linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 100%);
}
.gallery-card-info h3 {
  font-family:var(--font-head); font-size:1.15rem; font-weight:800;
  color:var(--white); margin-bottom:0;
}
.gallery-card-overlay {
  position:absolute; inset:0; background:rgba(27,42,74,.4);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity var(--transition); z-index:3;
}
.gallery-card:hover .gallery-card-overlay { opacity:1; }
.gallery-card-overlay svg { color:var(--white); }

/* Gallery Grid (detay sayfası lightbox) */
.gallery-grid {
  columns:3; gap:1rem;
}
.gallery-item {
  break-inside:avoid; margin-bottom:1rem; position:relative;
  border-radius:10px; overflow:hidden; cursor:pointer;
  box-shadow:var(--shadow-sm);
}
.gallery-item img { width:100%; display:block; border-radius:10px; transition:transform .4s ease; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-overlay {
  position:absolute; inset:0; background:rgba(27,42,74,.6);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity var(--transition); border-radius:10px;
}
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay svg { color:var(--white); width:40px; height:40px; }

/* Lightbox */
.lightbox {
  display:none; position:fixed; inset:0; z-index:999;
  background:rgba(0,0,0,.9); align-items:center; justify-content:center; padding:2rem;
}
.lightbox.active { display:flex; }
.lightbox img { max-width:90vw; max-height:90vh; border-radius:8px; }
.lightbox-close {
  position:absolute; top:1.5rem; right:1.5rem;
  background:var(--orange); color:var(--white); border:none; cursor:pointer;
  width:44px; height:44px; border-radius:50%; font-size:1.4rem;
  display:flex; align-items:center; justify-content:center;
}

/* ══════════════════════════════════
   İLETİŞİM
══════════════════════════════════ */
.contact-section { padding:5rem 0; }
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; }
.contact-info h2 { font-family:var(--font-head); font-size:1.5rem; font-weight:900; color:var(--navy); margin-bottom:1.5rem; }
.contact-info-item { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.5rem; }
.contact-info-icon {
  width:48px; height:48px; min-width:48px; border-radius:10px;
  background:var(--orange); color:var(--white);
  display:flex; align-items:center; justify-content:center;
}
.contact-info-icon svg { width:22px; height:22px; }
.contact-info-text strong { font-family:var(--font-head); font-size:.9rem; color:var(--navy); display:block; }
.contact-info-text a { color:var(--gray-600); font-size:.95rem; text-decoration:none; }
.contact-info-text a:hover { color:var(--orange); }
.contact-info-text span { color:var(--gray-600); font-size:.95rem; }

/* Form */
.contact-form { background:var(--gray-50); border-radius:16px; padding:2.5rem; box-shadow:var(--shadow-sm); }
.contact-form h2 { font-family:var(--font-head); font-size:1.5rem; font-weight:900; color:var(--navy); margin-bottom:1.75rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.25rem; }
.form-group label {
  display:block; font-family:var(--font-head); font-size:.85rem; font-weight:700;
  color:var(--navy); margin-bottom:.4rem;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; padding:.75rem 1rem; border-radius:var(--radius);
  border:2px solid var(--gray-100); background:var(--white);
  font-family:var(--font-body); font-size:1rem; color:var(--gray-800);
  transition:border-color var(--transition), box-shadow var(--transition);
  outline:none; -webkit-appearance:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color:var(--orange); box-shadow:0 0 0 3px rgba(244,123,32,.15);
}
.form-group textarea { resize:vertical; min-height:130px; }
.form-honeypot { display:none; }
.form-success {
  display:none; background:#d4edda; color:#155724;
  border:1px solid #c3e6cb; border-radius:var(--radius);
  padding:1rem; margin-bottom:1rem; font-weight:600;
}
.form-error {
  display:none; background:#f8d7da; color:#721c24;
  border:1px solid #f5c6cb; border-radius:var(--radius);
  padding:1rem; margin-bottom:1rem; font-weight:600;
}

/* Content Block */
.content-block { max-width:800px; margin:0 auto; text-align:center; }
.content-block p { color:var(--gray-600); line-height:1.8; font-size:1.05rem; margin-bottom:1rem; }

/* FAQ */
.faq-section { max-width:900px; margin:0 auto; }
.faq-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:1.25rem; }
.faq-item {
  background:var(--white); border-radius:12px; padding:1.5rem;
  box-shadow:var(--shadow-sm); border:1px solid var(--gray-100);
}
.faq-item h4 {
  font-family:var(--font-head); font-size:.95rem; font-weight:700;
  color:var(--navy); margin-bottom:.5rem;
}
.faq-item p { color:var(--gray-600); font-size:.9rem; line-height:1.7; }

/* 404 / 500 */
.error-page { min-height:70vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:3rem; }
.error-code { font-family:var(--font-head); font-size:8rem; font-weight:900; color:var(--orange); line-height:1; }
.error-page h1 { font-family:var(--font-head); font-size:2rem; font-weight:900; color:var(--navy); margin-bottom:1rem; }
.error-page p { color:var(--gray-600); margin-bottom:2rem; }

/* ══════════════════════════════════
   FOOTER
══════════════════════════════════ */
.site-footer {
  background:var(--navy-dark); color:rgba(255,255,255,.8);
  padding-top:4rem;
}
.footer-inner {
  max-width:1200px; margin:0 auto; padding:0 1.5rem 3rem;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3rem;
}
.site-footer .logo-text-main { color: var(--white); }
.site-footer .logo-text-sub  { color: rgba(255,255,255,.55); }
.footer-brand img { margin-bottom:1rem; }
.footer-logo-img { height:45px; width:auto; display:block; margin-bottom:1rem; }
.footer-brand p { font-size:.95rem; color:rgba(255,255,255,.85); line-height:1.6; margin-bottom:1.25rem; }
.footer-social { display:flex; gap:.75rem; }
.footer-social a {
  width:38px; height:38px; border-radius:8px;
  background:rgba(255,255,255,.08); color:rgba(255,255,255,.7);
  display:flex; align-items:center; justify-content:center;
  transition:background var(--transition), color var(--transition);
}
.footer-social a:hover { background:var(--orange); color:var(--white); }
.footer-links h3,
.footer-services h3,
.footer-contact h3 {
  font-family:var(--font-head); font-size:.9rem; font-weight:700;
  color:var(--white); margin-bottom:1.1rem; text-transform:uppercase; letter-spacing:.06em;
}
.footer-links ul,
.footer-services ul,
.footer-contact ul { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.footer-links a,
.footer-services a { color:rgba(255,255,255,.8); text-decoration:none; font-size:.9rem; transition:color var(--transition); }
.footer-links a:hover,
.footer-services a:hover { color:var(--orange); }
.footer-contact li { display:flex; gap:.6rem; align-items:flex-start; font-size:.9rem; color:rgba(255,255,255,.8); }
.footer-contact svg { min-width:16px; margin-top:.15rem; color:var(--orange); }
.footer-contact a { color:rgba(255,255,255,.8); text-decoration:none; }
.footer-contact a:hover { color:var(--orange); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding:1.25rem 1.5rem;
  max-width:1200px; margin:0 auto;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem;
  font-size:.82rem; color:rgba(255,255,255,.65); /* #111d33 üzerinde WCAG AA */
}

/* WhatsApp Float */
.wa-float {
  position:fixed; bottom:1.75rem; right:1.75rem; z-index:500;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:var(--white);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  transition:transform var(--transition), box-shadow var(--transition);
  text-decoration:none;
}
.wa-float:hover { transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,.65); }

/* ══════════════════════════════════
   ANİMASYONLAR
══════════════════════════════════ */
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.6; transform:scale(1.3); }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-up { animation:fadeUp .6s ease both; }
.fade-up-2 { animation:fadeUp .6s .15s ease both; }
.fade-up-3 { animation:fadeUp .6s .3s ease both; }

/* ══════════════════════════════════
   MOBİL RESPONSIVE
══════════════════════════════════ */
@media (max-width: 1024px) {
  .footer-inner { grid-template-columns:1fr 1fr; }
  .why-badge-float { right:0; }
}
@media (max-width: 768px) {
  .hero-inner { grid-template-columns:1fr; }
  .hero-image { display:none; }
  .hero { min-height:auto; }
  .hero-inner { padding:3rem 1.5rem; }
  .why-grid,
  .about-grid,
  .contact-grid { grid-template-columns:1fr; }
  .why-image-wrap,
  .about-image { order:-1; }
  .gallery-grid { columns:2; }
  .gallery-cards-grid { grid-template-columns:repeat(2, 1fr); }
  .form-row { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .why-badge-float { position:static; margin-top:1rem; }
}
@media (max-width: 480px) {
  .gallery-grid { columns:1; }
  .gallery-cards-grid { grid-template-columns:1fr; }
  .hero-stats { gap:1.25rem; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { text-align:center; justify-content:center; }
}
