/* =========================================================
   service.css – shared stylesheet for all JMFC service pages
   Covers: header, nav, hero, stats, sections, cards, footer,
           animations, responsive breakpoints.
   Page-specific component CSS lives in a <style> block on
   the individual page.
   ========================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* shadows — navy-tinted values differ from tokens.css (pure black); keep here */
  --shadow-sm:0 2px 8px rgba(13,31,60,0.08);
  --shadow-md:0 8px 32px rgba(13,31,60,0.12);
  --shadow-lg:0 20px 60px rgba(13,31,60,0.18);
  /* accent — service-page colour theming; override per page */
  --accent:var(--blue);
  --accent-hover:#1648c0;
  --accent-glow:rgba(26,86,219,0.4);
  --accent-soft:rgba(26,86,219,0.08);
  --accent-light:#90caf9;
}

/* ── Language ─────────────────────────────────── */
[data-lang="en"] .lang-pl{display:none}
[data-lang="pl"] .lang-en{display:none}

/* ── Base ─────────────────────────────────────── */
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--white);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:white;padding:8px 16px;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}

/* ── Header ───────────────────────────────────── */
header{position:sticky;top:0;z-index:100;background:var(--navy);border-bottom:1px solid rgba(255,255,255,0.08);box-shadow:0 2px 20px rgba(0,0,0,0.25)}
header .container{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:68px}
.logo img{height:42px;display:block}
.logo a{display:flex;align-items:center}

/* ── Nav ──────────────────────────────────────── */
.nav-links{list-style:none;display:flex;gap:4px;align-items:center}
.nav-links a{color:rgba(255,255,255,0.85);text-decoration:none;font-size:14px;font-weight:500;padding:8px 14px;border-radius:6px;transition:var(--transition);white-space:nowrap}
.nav-links a:hover{color:white;background:rgba(255,255,255,0.1)}
.dropdown{position:relative}
.dropdown-toggle{cursor:pointer}
.dropdown-toggle::after{content:' \25be';font-size:10px;opacity:.7}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);left:0;background:var(--navy-mid);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius);min-width:220px;box-shadow:var(--shadow-lg);padding:6px;z-index:200}
.dropdown-menu li a{display:block;padding:9px 14px;border-radius:6px;font-size:13.5px}
.dropdown-menu li a:hover{background:rgba(255,255,255,0.12);color:white}
.dropdown:hover .dropdown-menu{display:block}
.header-right{display:flex;align-items:center;gap:12px}
.language-switcher{display:flex;gap:4px}
.lang-btn{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.75);padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition)}
.lang-btn:hover,.lang-btn.active{background:var(--accent);border-color:var(--accent);color:white}
.header-cta{background:var(--accent);color:white;padding:9px 20px;border-radius:6px;text-decoration:none;font-weight:600;font-size:14px;transition:var(--transition);white-space:nowrap}
.header-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}
.hamburger{display:none;background:none;border:none;color:white;font-size:22px;cursor:pointer;padding:4px}

/* ── Breadcrumb ───────────────────────────────── */
.breadcrumb{background:var(--gray-100);border-bottom:1px solid var(--gray-300)}
.breadcrumb .container{max-width:1200px;margin:0 auto;padding:10px 24px;font-size:13px;color:var(--gray-500)}
.breadcrumb a{color:var(--accent);text-decoration:none}
.breadcrumb span{margin:0 6px}

/* ── Service Hero ─────────────────────────────── */
.service-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 60%,#1e4d8c 100%);position:relative;overflow:hidden;padding:72px 24px 80px}
.service-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.service-hero::after{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);border-radius:50%}
.hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:60px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,168,76,0.15);border:1px solid rgba(201,168,76,0.4);color:var(--gold-light);padding:6px 14px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:20px}
.hero-badge::before{content:'\2736';font-size:10px}
.service-hero h1{font-family:'Playfair Display',serif;font-size:clamp(32px,4.5vw,52px);font-weight:700;color:white;line-height:1.15;margin-bottom:20px;letter-spacing:-0.02em}
.service-hero h1 em{color:var(--gold-light);font-style:normal}
.hero-lead{font-size:18px;color:rgba(255,255,255,0.8);line-height:1.6;margin-bottom:32px;max-width:520px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.btn-primary{background:var(--accent);color:white;padding:14px 28px;border-radius:8px;font-weight:600;font-size:15px;text-decoration:none;transition:var(--transition);box-shadow:0 4px 16px var(--accent-glow);display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px)}
.btn-secondary{background:transparent;color:white;padding:14px 28px;border-radius:8px;border:1.5px solid rgba(255,255,255,0.35);font-weight:600;font-size:15px;text-decoration:none;transition:var(--transition);display:inline-flex;align-items:center;gap:8px}
.btn-secondary:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6)}
.cta-microcopy{width:100%;font-size:12px;line-height:1.4;margin-top:8px}
.hero-content .cta-microcopy,.mid-cta-inner .cta-microcopy,.hero-inner .cta-microcopy{color:rgba(255,255,255,0.68)}
.mid-cta-inner .cta-microcopy{text-align:center}
.hero-trust{display:flex;gap:20px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,0.65);font-size:13px}
.trust-item::before{content:'\2713';width:18px;height:18px;background:var(--accent-glow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--accent-light);flex-shrink:0}
.hero-image-box{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,0.4)}
.hero-image-box img{width:100%;height:300px;object-fit:cover;display:block}
.hero-image-caption{padding:16px 20px;color:rgba(255,255,255,0.7);font-size:13px;border-top:1px solid rgba(255,255,255,0.08)}

/* ── Stats Bar ────────────────────────────────── */
.stats-bar{background:white;border-bottom:1px solid var(--gray-100);box-shadow:var(--shadow-sm)}
.stats-bar .container{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:28px 24px;text-align:center;border-right:1px solid var(--gray-100);transition:var(--transition)}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:var(--off-white)}
.stat-num{font-family:'Playfair Display',serif;font-size:36px;font-weight:700;color:var(--navy);line-height:1;margin-bottom:4px}
.stat-num span{color:var(--accent)}
.stat-label{font-size:13px;color:var(--gray-500);font-weight:500}

/* ── Sections ─────────────────────────────────── */
.section{padding:80px 24px}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:block}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(26px,3vw,38px);font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:16px;letter-spacing:-0.02em}
.section-subtitle{font-size:17px;color:var(--gray-500);max-width:600px;line-height:1.6}
.section-header{margin-bottom:48px}
.section-alt{background:var(--off-white)}

/* ── Problem Grid ─────────────────────────────── */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.problem-card{background:white;border:1.5px solid var(--gray-100);border-radius:var(--radius);padding:24px;transition:var(--transition)}
.problem-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.problem-icon{width:44px;height:44px;background:var(--off-white);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px}
.problem-card h3{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:8px}
.problem-card p{font-size:14px;color:var(--gray-500);line-height:1.55}

/* ── Process Timeline ─────────────────────────── */
.process-timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process-timeline::before{content:'';position:absolute;top:32px;left:calc(12.5% + 16px);right:calc(12.5% + 16px);height:2px;background:linear-gradient(90deg,var(--accent),var(--navy));z-index:0}
.process-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.step-circle{width:64px;height:64px;background:var(--navy);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin:0 auto 20px;border:3px solid white;box-shadow:0 0 0 3px var(--accent),var(--shadow-sm);transition:var(--transition)}
.process-step:hover .step-circle{background:var(--accent);transform:scale(1.1)}
.step-title{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:8px}
.step-time{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:3px 10px;border-radius:100px;margin-bottom:10px}
.step-desc{font-size:13.5px;color:var(--gray-500);line-height:1.55}

/* ── Benefits Grid ────────────────────────────── */
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.benefit-card{display:flex;gap:18px;align-items:flex-start;background:white;border:1px solid var(--gray-100);border-radius:var(--radius);padding:24px;transition:var(--transition)}
.benefit-card:hover{box-shadow:var(--shadow-md);border-color:rgba(26,86,219,0.2);transform:translateY(-2px)}
.benefit-icon{width:48px;height:48px;flex-shrink:0;background:linear-gradient(135deg,var(--navy),var(--navy-light));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 12px rgba(13,31,60,0.2)}
.benefit-content h3{font-size:16px;font-weight:600;color:var(--navy);margin-bottom:6px}
.benefit-content p{font-size:14px;color:var(--gray-500);line-height:1.55}

/* ── Mid CTA ──────────────────────────────────── */
.mid-cta{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);padding:64px 24px;text-align:center;position:relative;overflow:hidden}
.mid-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,var(--accent-glow) 0%,transparent 70%)}
.mid-cta-inner{max-width:640px;margin:0 auto;position:relative;z-index:1}
.mid-cta h2{font-family:'Playfair Display',serif;font-size:clamp(26px,3vw,36px);color:white;margin-bottom:14px;font-weight:700}
.mid-cta p{color:rgba(255,255,255,0.75);font-size:17px;margin-bottom:32px;line-height:1.6}
.mid-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── Scope List ───────────────────────────────── */
.scope-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.scope-item{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;background:white;border:1px solid var(--gray-100);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;transition:var(--transition)}
.scope-item:hover{box-shadow:var(--shadow-sm);transform:translateX(3px)}
.scope-check{width:22px;height:22px;flex-shrink:0;background:var(--accent);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-top:1px}
.scope-item span{font-size:14.5px;color:var(--gray-700);line-height:1.5}

/* ── FAQ ──────────────────────────────────────── */
.faq-list{max-width:760px}
.faq-item{border:1px solid var(--gray-100);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;transition:var(--transition)}
.faq-item:hover{border-color:var(--accent)}
.faq-question{padding:18px 22px;font-weight:600;font-size:15px;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:white;user-select:none}
.faq-question:hover{background:var(--off-white)}
.faq-arrow{width:24px;height:24px;flex-shrink:0;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;transition:var(--transition)}
.faq-item.open .faq-arrow{background:var(--accent);color:white;transform:rotate(180deg)}
.faq-answer{display:none;padding:0 22px 18px;font-size:14.5px;color:var(--gray-500);line-height:1.65;background:white;border-top:1px solid var(--gray-100)}
.faq-item.open .faq-answer{display:block;padding-top:14px}

/* ── Services Grid (related) ──────────────────── */
.other-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.service-card{background:white;border:1.5px solid var(--gray-100);border-radius:var(--radius);padding:24px 22px;text-decoration:none;transition:var(--transition);display:flex;flex-direction:column;gap:10px}
.service-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.service-card-icon{font-size:28px}
.service-card-title{font-size:15px;font-weight:600;color:var(--navy)}
.service-card-desc{font-size:13px;color:var(--gray-500);line-height:1.5}
.service-card-link{font-size:13px;font-weight:600;color:var(--accent);margin-top:auto}

/* ── Case Studies ─────────────────────────────── */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.case-card{background:white;border:1.5px solid var(--gray-100);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.case-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--accent)}
.case-inner{display:grid;grid-template-columns:1fr 1fr 1fr}
.case-type-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:4px 10px;border-radius:100px;margin-bottom:12px}
.case-col-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-500);margin-bottom:6px}
.col-situation,.col-action,.col-result{padding:20px;font-size:13px;line-height:1.55;color:var(--gray-700)}
.col-situation{background:var(--off-white);border-bottom:1px solid var(--gray-100)}
.col-action{border-bottom:1px solid var(--gray-100)}
.col-result{background:var(--off-white);border-bottom:1px solid var(--gray-100)}
.result-highlight{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--navy);display:block;margin-top:8px}

/* ── Footer ───────────────────────────────────── */
footer{background:var(--navy);border-top:1px solid rgba(255,255,255,0.08);padding:32px 24px}
footer .container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
footer p{color:rgba(255,255,255,0.55);font-size:13.5px}
footer a{color:rgba(255,255,255,0.7)}
footer a:hover{color:white}

/* ── Animations ───────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.animate{opacity:0}
.animate.visible{animation:fadeUp .55s ease forwards}
.animate:nth-child(2){animation-delay:.1s}
.animate:nth-child(3){animation-delay:.2s}
.animate:nth-child(4){animation-delay:.3s}
.animate:nth-child(5){animation-delay:.4s}
.animate:nth-child(6){animation-delay:.5s}

/* ── Responsive ───────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .stats-bar .container{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid var(--gray-100)}
  .stat-item:nth-child(1),.stat-item:nth-child(2){border-right:1px solid var(--gray-100)}
  .problem-grid{grid-template-columns:1fr 1fr}
  .process-timeline{grid-template-columns:1fr 1fr;gap:32px}
  .process-timeline::before{display:none}
  .benefits-grid,.scope-list{grid-template-columns:1fr}
  .other-services-grid,.case-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .section{padding:56px 20px}
  .service-hero{padding:48px 20px 56px}
  .hero-ctas{flex-direction:column}
  .btn-primary,.btn-secondary{justify-content:center}
  .problem-grid,.process-timeline,.other-services-grid,.case-grid{grid-template-columns:1fr}
  .nav-menu{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--navy);flex-direction:column;padding:20px;overflow-y:auto;z-index:99}
  .nav-menu.active{display:flex}
  .nav-links{flex-direction:column;width:100%}
  .nav-links a{font-size:16px;padding:12px 16px}
  .dropdown-menu{position:static;box-shadow:none;border:none;background:rgba(255,255,255,0.05);margin-top:4px}
  .hamburger{display:block}
  .lang-btn{padding:3px 8px;font-size:11px}
  .mid-cta-btns{flex-direction:column;align-items:center}
  .case-inner{grid-template-columns:1fr}
}

/* ── Service List ─────────────────────────────── */
.service-list{list-style:none;padding:0}
.service-list li{padding:4px 0}
.service-list li::before{content:"⚡ ";color:var(--accent)}

/* ── CTA ──────────────────────────────────────── */
.cta{background:#3b82f6;color:white;padding:1rem 2rem;border-radius:6px;text-decoration:none;font-weight:600;display:inline-block;transition:var(--transition)}
.cta:hover{background:#1648c0;transform:translateY(-1px)}

/* ── Content Wrapper ──────────────────────────── */
main.content{max-width:900px;margin:0 auto;padding:2rem}
