/*
  ============================================================
  POLEN STUDIOS — responsive.css
  Link this AFTER your existing styles on every page:
  <link rel="stylesheet" href="responsive.css">
  ============================================================

  Breakpoints:
    1024px  — tablet landscape
     768px  — tablet portrait / large mobile
     480px  — mobile
*/


/* ============================================================
   1. GLOBAL SPACING & TYPOGRAPHY
   ============================================================ */

@media (max-width: 1024px) {
  /* Reduce the 60px gutters on tablet */
  nav,
  #hero,
  .hero-content,
  .page-hero-content,
  .page-hero-inner,
  #services, #specialisms,
  #portfolio, #preview,
  #works,
  #why, #philosophy,
  #testimonials, #testimonial,
  #clients,
  #numbers,
  #team,
  #process,
  #included,
  #types, #demo,
  #pricing,
  #tech,
  #faqs-main,
  #still-questions,
  #related,
  #cta,
  footer {
    padding-left: 40px;
    padding-right: 40px;
  }
}

@media (max-width: 768px) {
  /* Tighter gutters on mobile */
  nav,
  #hero,
  .hero-content,
  .page-hero-content,
  .page-hero-inner,
  #services, #specialisms,
  #portfolio, #preview,
  #works,
  #why, #philosophy,
  #testimonials, #testimonial,
  #clients,
  #numbers,
  #team,
  #process,
  #included,
  #types, #demo,
  #pricing,
  #tech,
  #faqs-main,
  #still-questions,
  #related,
  #cta,
  footer {
    padding-left: 24px;
    padding-right: 24px;
  }

  /* Reduce vertical padding on all sections */
  #specialisms, #portfolio, #works, #why, #philosophy,
  #testimonials, #team, #process, #included, #types,
  #pricing, #tech, #testimonial, #related, #numbers,
  #still-questions, #demo { padding-top: 72px; padding-bottom: 60px; }

  #cta { padding-top: 80px; padding-bottom: 80px; }
}

@media (max-width: 480px) {
  nav,
  #hero, .hero-content, .page-hero-content, .page-hero-inner,
  #services, #specialisms, #portfolio, #works, #why, #philosophy,
  #testimonials, #testimonial, #clients, #numbers, #team,
  #process, #included, #types, #demo, #pricing, #tech,
  #faqs-main, #still-questions, #related, #cta, footer {
    padding-left: 20px;
    padding-right: 20px;
  }
}


/* ============================================================
   2. NAVIGATION — hamburger handled separately in nav-mobile.js
   ============================================================ */

@media (max-width: 768px) {
  nav { padding: 0 24px; height: 64px; }

  .nav-links { display: none; } /* replaced by mobile menu */

  .nav-cta { display: none; } /* moved into mobile menu */

  /* Keep logo visible */
  .nav-logo { font-size: 20px; }
}


/* ============================================================
   3. HERO — HOMEPAGE
   ============================================================ */

@media (max-width: 1024px) {
  #hero { min-height: 90vh; }
  .hero-headline { font-size: clamp(72px, 12vw, 130px); }
  .hero-sub-row { flex-direction: column; align-items: flex-start; gap: 28px; }
  .hero-actions { flex-direction: row; }
  .hero-circle { width: 500px; height: 500px; top: -160px; right: -160px; }
}

@media (max-width: 768px) {
  #hero { min-height: 100svh; padding-bottom: 60px; }
  .hero-headline { font-size: clamp(64px, 15vw, 100px); line-height: 0.88; }
  .hero-sub { font-size: 16px; max-width: 100%; }
  .hero-circle { display: none; }
  .hero-grid { background-size: 60px 60px; }
  .hero-scroll { display: none; }
  .hero-actions { flex-wrap: wrap; gap: 16px; }
}

@media (max-width: 480px) {
  .hero-headline { font-size: clamp(56px, 18vw, 80px); }
  .hero-sub { font-size: 15px; }
  .btn-primary, .btn-gold, .btn-black { padding: 14px 28px; font-size: 11px; }
  .btn-ghost { font-size: 11px; }
}


/* ============================================================
   4. PAGE HERO (About, FAQs, service pages)
   ============================================================ */

@media (max-width: 1024px) {
  .page-hero-content,
  .page-hero-inner { grid-template-columns: 1fr; gap: 32px; }

  .page-hero-right,
  .hero-statement,
  .hero-right { padding-bottom: 0; }

  .hero-stat { display: inline-block; margin-right: 32px; }
  .hero-divider { display: none; }
  .hero-stat:last-child { margin-right: 0; }

  .page-title { font-size: clamp(60px, 12vw, 110px); }
  .hero-bracket { display: none; }
  .hero-qmark { font-size: 240px; right: 0; }
}

@media (max-width: 768px) {
  .page-title { font-size: clamp(52px, 14vw, 90px); }
  #page-hero { min-height: 48vh; }
  .page-hero-content,
  .page-hero-inner { padding-bottom: 48px; }
  .hero-right-meta { gap: 20px; }
  .hero-meta-num { font-size: 26px; }
  .hero-pill { font-size: 10px; padding: 7px 14px; }
}

@media (max-width: 480px) {
  .page-title { font-size: clamp(48px, 16vw, 72px); }
  .hero-desc, .hero-right p { font-size: 15px; }
}


/* ============================================================
   5. SERVICES SECTION (Homepage)
   ============================================================ */

@media (max-width: 1024px) {
  .services-header { flex-direction: column; align-items: flex-start; gap: 20px; margin-bottom: 52px; }
  .services-intro { max-width: 100%; }
  .service-item { grid-template-columns: 60px 1fr; gap: 0 24px; }
  .service-link { grid-column: 2; margin-top: 12px; }
  .service-name { font-size: clamp(28px, 5vw, 44px); }
}

@media (max-width: 768px) {
  .service-item { grid-template-columns: 48px 1fr; gap: 0 16px; padding: 32px 0; }
  .service-name { font-size: clamp(24px, 6vw, 36px); }
  .service-desc { font-size: 13px; }
  .services-title { font-size: clamp(40px, 10vw, 64px); }
}

@media (max-width: 480px) {
  .service-item { grid-template-columns: 1fr; }
  .service-num { margin-bottom: 8px; }
  .service-link { margin-top: 14px; }
}


/* ============================================================
   6. PORTFOLIO GRID (Homepage)
   ============================================================ */

@media (max-width: 1024px) {
  .portfolio-grid { gap: 10px; }
  .project-card:nth-child(1) { grid-column: span 7; }
  .project-card:nth-child(2) { grid-column: span 5; }
  .project-card:nth-child(3),
  .project-card:nth-child(4),
  .project-card:nth-child(5) { grid-column: span 4; }
}

@media (max-width: 768px) {
  .portfolio-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .project-card:nth-child(n) { grid-column: span 1; }
  .project-card:nth-child(1) { grid-column: span 2; }
  .portfolio-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .portfolio-title, .portfolio-link { }
  .project-overlay { opacity: 1; } /* always show on mobile — no hover */
}

@media (max-width: 480px) {
  .portfolio-grid { grid-template-columns: 1fr; gap: 8px; }
  .project-card:nth-child(n) { grid-column: span 1; }
}


/* ============================================================
   7. WHY POLEN (Homepage)
   ============================================================ */

@media (max-width: 1024px) {
  .why-grid { grid-template-columns: 1fr; gap: 52px; }
  .why-title { font-size: clamp(40px, 8vw, 64px); margin-bottom: 28px; }
  .why-item { padding: 28px 0; }
}

@media (max-width: 768px) {
  #why::before { font-size: 200px; }
  .why-text h3 { font-size: 22px; }
}


/* ============================================================
   8. TESTIMONIALS (Homepage)
   ============================================================ */

@media (max-width: 1024px) {
  .testimonials-grid { grid-template-columns: 1fr; gap: 1px; }
}

@media (max-width: 768px) {
  .testimonials-title { font-size: clamp(40px, 8vw, 60px); }
  .testimonial-card { padding: 36px 28px; }
  .quote-mark { font-size: 80px; }
  .testimonial-text { font-size: 15px; }
}


/* ============================================================
   9. CLIENT LOGOS
   ============================================================ */

@media (max-width: 768px) {
  .logos-strip { gap: 0; }
  .logo-item { padding: 16px 20px; border-right: none; border-bottom: 0.5px solid rgba(255,255,255,0.06); width: 50%; }
  .logo-item:nth-child(odd) { border-right: 0.5px solid rgba(255,255,255,0.06); }
  .logo-text { font-size: 12px; }
}

@media (max-width: 480px) {
  .logo-item { width: 100%; border-right: none; }
  .logo-item:nth-child(odd) { border-right: none; }
}


/* ============================================================
   10. CTA SECTION (all pages)
   ============================================================ */

@media (max-width: 1024px) {
  .cta-content { flex-direction: column; align-items: flex-start; gap: 36px; }
  .cta-right { align-items: flex-start; }
  .cta-title { font-size: clamp(48px, 9vw, 80px); }
}

@media (max-width: 768px) {
  .cta-title { font-size: clamp(40px, 11vw, 64px); margin-bottom: 16px; }
  .cta-sub { font-size: 15px; }
  #cta::before { font-size: 140px; bottom: -20px; }
}

@media (max-width: 480px) {
  .btn-black { padding: 16px 32px; width: 100%; text-align: center; }
  .cta-right { width: 100%; }
}


/* ============================================================
   11. FOOTER
   ============================================================ */

@media (max-width: 1024px) {
  footer { grid-template-columns: 1fr 1fr; gap: 40px; padding-top: 48px; padding-bottom: 48px; }
  .footer-contact { text-align: left; grid-column: span 2; }
}

@media (max-width: 768px) {
  footer { grid-template-columns: 1fr; gap: 32px; }
  .footer-contact { text-align: left; grid-column: span 1; }
  .footer-links { flex-direction: row; flex-wrap: wrap; gap: 12px 24px; }
}


/* ============================================================
   12. WORK PAGE — filter bar & grid
   ============================================================ */

@media (max-width: 1024px) {
  #works { padding: 40px 40px 80px; }
  .works-grid { gap: 10px; }
  .work-card[data-span="7"]  { grid-column: span 7; }
  .work-card[data-span="5"]  { grid-column: span 5; }
  .work-card[data-span="8"]  { grid-column: span 12; }
  .work-card[data-span="12"] { grid-column: span 12; }
}

@media (max-width: 768px) {
  #works { padding: 32px 24px 72px; }
  .works-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .work-card[data-span] { grid-column: span 1; }
  .work-card[data-span="12"],
  .work-card[data-span="7"],
  .work-card[data-span="8"] { grid-column: span 2; }

  /* Always show overlay on mobile */
  .card-content { opacity: 1; transform: none; }
  .card-arrow { opacity: 1; transform: none; }

  /* Case banner — stack vertically */
  .case-banner { grid-template-columns: 1fr; }
  .case-divider { display: none; }
  .case-meta { padding: 0 32px 40px; }
  .case-stats { grid-template-columns: 1fr 1fr; }

  /* Filter bar */
  #filter-bar { padding: 0 24px; overflow-x: auto; }
  .filter-inner { justify-content: flex-start; }
  .filter-tabs { gap: 0; flex-shrink: 0; }
  .filter-tab { padding: 0 16px; font-size: 10px; white-space: nowrap; }
  .filter-view { flex-shrink: 0; margin-left: auto; }

  /* Process strip */
  .process-steps { grid-template-columns: 1fr 1fr; gap: 2px; }
  .process-steps::before { display: none; }
}

@media (max-width: 480px) {
  .works-grid { grid-template-columns: 1fr; gap: 8px; }
  .work-card[data-span] { grid-column: span 1; }
  .filter-tab .count { display: none; }
}


/* ============================================================
   13. ABOUT PAGE
   ============================================================ */

@media (max-width: 1024px) {
  /* Story — unstick and stack */
  #story { grid-template-columns: 1fr; gap: 52px; padding-top: 80px; }
  .story-left { position: static; }
  .story-img-placeholder { aspect-ratio: 16/9; max-width: 560px; }
  .story-pull { font-size: 19px; }

  /* Numbers */
  .numbers-grid { grid-template-columns: 1fr 1fr; gap: 0; }
  .number-item { padding: 40px 32px; border-right: none; border-bottom: 1px solid rgba(0,0,0,0.12); }
  .number-item:nth-child(odd) { border-right: 1px solid rgba(0,0,0,0.12); }
  .num-value { font-size: 56px; }

  /* Team */
  .team-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
  .team-grid { grid-template-columns: 1fr 1fr; gap: 24px; }

  /* Philosophy — unstick and stack */
  .phil-grid { grid-template-columns: 1fr; gap: 48px; }
  .phil-left { position: static; }
}

@media (max-width: 768px) {
  .story-values { grid-template-columns: 1fr; gap: 12px; }
  .team-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .numbers-grid { grid-template-columns: 1fr 1fr; }
  .num-value { font-size: 48px; }
  .phil-item { grid-template-columns: 36px 1fr; gap: 16px; padding: 32px 0; }
  .story-title { font-size: clamp(38px, 9vw, 60px); }
}

@media (max-width: 480px) {
  .numbers-grid { grid-template-columns: 1fr; }
  .number-item { border-right: none !important; border-bottom: 1px solid rgba(0,0,0,0.12); }
  .team-grid { max-width: 100%; }
}


/* ============================================================
   14. FAQ PAGE
   ============================================================ */

@media (max-width: 1024px) {
  /* Stack sidebar above content */
  #faqs-main { grid-template-columns: 1fr; }

  .faq-sidebar {
    position: static;
    height: auto;
    border-right: none;
    border-bottom: 0.5px solid rgba(255,255,255,0.07);
    padding: 32px 0;
  }

  .sidebar-nav { display: flex; flex-wrap: wrap; padding: 0 40px; gap: 4px; }
  .sidebar-btn { height: 36px; border-left: none; border-bottom: 2px solid transparent; padding: 0 16px; white-space: nowrap; }
  .sidebar-btn.active { border-bottom-color: #f1c40f; border-left-color: transparent; background: none; }
  .sidebar-label { padding: 0 40px; margin-bottom: 12px; }
  .sidebar-divider { display: none; }
  .sidebar-contact { display: none; }

  .faq-content { padding: 48px 40px 80px; }
}

@media (max-width: 768px) {
  .sidebar-nav { padding: 0 24px; }
  .sidebar-label { padding: 0 24px; }
  .faq-content { padding: 40px 24px 72px; }
  .faq-answer { padding-right: 0; }
  .cat-header { flex-wrap: wrap; gap: 8px; }
  .cat-count { margin-left: 0; }

  #still-questions { grid-template-columns: 1fr; gap: 36px; padding-top: 60px; padding-bottom: 60px; }
  .sq-title { font-size: clamp(36px, 9vw, 56px); }
}


/* ============================================================
   15. PHOTOGRAPHY PAGE
   ============================================================ */

@media (max-width: 1024px) {
  /* Spec grid */
  .spec-grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .spec-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }

  /* Gallery masonry — simplified */
  .gallery-masonry { grid-auto-rows: 50px; gap: 6px; }
  .g-item:nth-child(1)  { grid-column: span 6; grid-row: span 5; }
  .g-item:nth-child(2)  { grid-column: span 6; grid-row: span 3; }
  .g-item:nth-child(3)  { grid-column: span 4; grid-row: span 4; }
  .g-item:nth-child(4)  { grid-column: span 4; grid-row: span 4; }
  .g-item:nth-child(5)  { grid-column: span 4; grid-row: span 4; }
  .g-item:nth-child(6)  { grid-column: span 6; grid-row: span 3; }
  .g-item:nth-child(7)  { grid-column: span 6; grid-row: span 3; }
  .g-item:nth-child(8)  { grid-column: span 12; grid-row: span 3; }

  /* Process */
  .process-steps { grid-template-columns: 1fr 1fr; gap: 2px; }
  .process-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }

  /* Pricing */
  .pricing-cards { grid-template-columns: 1fr; gap: 2px; }
  .pricing-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }
  .price-card.featured { order: -1; }

  /* Testimonial */
  #testimonial { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
  /* Hero canvas */
  .hero-canvas { opacity: 0.35; }

  /* Spec grid → single col */
  .spec-grid { grid-template-columns: 1fr; }

  /* Gallery → simple 2 col */
  .gallery-masonry { display: grid; grid-template-columns: 1fr 1fr; grid-auto-rows: 180px; gap: 6px; }
  .g-item:nth-child(n) { grid-column: span 1; grid-row: span 1; }
  .g-item:nth-child(1) { grid-column: span 2; grid-row: span 1; }

  /* Gallery always show overlay */
  .g-overlay { opacity: 1; }

  .gallery-header { flex-direction: column; align-items: flex-start; gap: 16px; }

  /* Process → single col */
  .process-steps { grid-template-columns: 1fr; }

  /* Pricing */
  .pricing-cards { grid-template-columns: 1fr; }

  /* Related */
  .related-grid { grid-template-columns: 1fr; }
}


/* ============================================================
   16. WEBSITE DESIGN PAGE
   ============================================================ */

@media (max-width: 1024px) {
  /* Hide the floating browser mockup on tablet */
  .browser-mockup { display: none; }
  .code-snippet { display: none; }
  .hero-title { max-width: 100%; }

  /* Included grid */
  .included-grid { grid-template-columns: 1fr; gap: 2px; }
  .included-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }

  /* Project strip */
  .project-strip { grid-template-columns: 1fr 1fr; gap: 8px; }
  .proj-thumb:nth-child(3) { grid-column: span 2; }

  /* Steps list */
  .step-row { grid-template-columns: 48px 1fr; gap: 20px; }
  .step-row .step-desc { grid-column: 2; }

  /* Tech */
  .tech-inner { grid-template-columns: 1fr; gap: 40px; }
  .tech-grid { grid-template-columns: repeat(3, 1fr); }

  /* Testimonial */
  #testimonial { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
  .project-strip { grid-template-columns: 1fr; gap: 8px; }
  .proj-thumb:nth-child(n) { grid-column: span 1; }
  .proj-info { opacity: 1; transform: none; } /* always show */

  .step-row { grid-template-columns: 1fr; gap: 8px; padding: 24px 0; }
  .step-num { display: none; }

  .tech-grid { grid-template-columns: 1fr 1fr; }

  .related-grid { grid-template-columns: 1fr; }
  .preview-header { flex-direction: column; align-items: flex-start; gap: 16px; }
}

@media (max-width: 480px) {
  .included-item { grid-template-columns: 1fr; gap: 16px; }
  .included-icon { width: 40px; height: 40px; font-size: 16px; }
  .tech-grid { grid-template-columns: 1fr; }
}


/* ============================================================
   17. VIRTUAL TOURS PAGE
   ============================================================ */

@media (max-width: 1024px) {
  /* Reposition sphere so it doesn't cover text */
  .hero-sphere { width: 360px; height: 360px; right: -60px; top: 60%; transform: translateY(-50%); opacity: 0.4; }

  /* Why section */
  .impact-grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .why-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }
  .why-statement { grid-template-columns: 1fr; gap: 20px; padding: 36px 32px; }
  .ws-tag { align-self: flex-start; }

  /* Tour types */
  .types-grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .types-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }

  /* Process */
  .process-steps { grid-template-columns: 1fr 1fr; gap: 2px; }
  .process-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }

  /* Pricing */
  .pricing-cards { grid-template-columns: 1fr; gap: 2px; }
  .pricing-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 52px; }
  .price-card.featured { order: -1; }

  /* Testimonial */
  #testimonial { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
  /* Sphere — push behind content or hide */
  .hero-sphere { display: none; }

  /* Types → single col */
  .types-grid { grid-template-columns: 1fr; }

  /* Demo UI buttons — wrap */
  .demo-ui { flex-wrap: wrap; justify-content: center; gap: 6px; bottom: 16px; }
  .demo-ui-btn { font-size: 10px; padding: 6px 10px; }

  /* Related */
  .related-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .impact-grid { grid-template-columns: 1fr 1fr; }
  .impact-num { font-size: 40px; }
  .process-steps { grid-template-columns: 1fr; }
}


/* ============================================================
   18. SECTION HEADERS (shared across pages)
   ============================================================ */

@media (max-width: 768px) {
  .services-header,
  .portfolio-header,
  .gallery-header,
  .process-header,
  .pricing-header,
  .included-header,
  .why-header,
  .types-header,
  .demo-header,
  .spec-header,
  .team-header,
  .phil-grid > .phil-left,
  .story-left { }

  /* All two-column headers collapse */
  .services-header { flex-direction: column; }
  .portfolio-header { flex-direction: column; align-items: flex-start; gap: 16px; }

  .section-label { margin-bottom: 36px; }

  /* Section title sizes */
  .services-title,
  .portfolio-title,
  .gallery-title,
  .process-title,
  .pricing-title,
  .included-title,
  .why-title,
  .types-title,
  .spec-title,
  .team-title,
  .sq-title,
  .related-title,
  .demo-title,
  .testimonials-title { font-size: clamp(38px, 9vw, 60px); }
}


/* ============================================================
   19. MISC FIXES
   ============================================================ */

/* Prevent horizontal scroll from oversized elements */
@media (max-width: 768px) {
  html, body { overflow-x: hidden; }

  /* Ghost background words that bleed off screen */
  #why::before,
  #process::before,
  #philosophy::before,
  #cta::before,
  #numbers::before { display: none; }

  /* Scroll indicator */
  .hero-scroll { display: none; }

  /* Filter bar horizontal scroll on mobile */
  #filter-bar { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  #filter-bar::-webkit-scrollbar { display: none; }
}

@media (max-width: 480px) {
  /* Make sure images in cards don't overflow */
  .project-card,
  .work-card,
  .spec-card,
  .team-card,
  .type-card,
  .price-card { overflow: hidden; }

  /* Touch-friendly tap targets */
  .nav-dropdown-item { padding: 18px 20px; }
  .filter-tab { height: 52px; }
}
