/* ===========================================================
   Future Consulting Group — style.css
   Paleta oparta na logo: granat #003867 + akcent #b90131
   =========================================================== */

:root{
  --navy:      #003867;
  --navy-deep: #002a48;
  --navy-800:  #003366;
  --accent:    #b90131;
  --accent-dk: #94012a;
  --ink:       #1c2733;
  --muted:     #5b6b78;
  --line:      #e2e7ec;
  --bg:        #ffffff;
  --bg-alt:    #f4f6f8;
  --white:     #ffffff;

  --font-display: "Barlow Condensed", "Arial Narrow", sans-serif;
  --font-body:    "Source Sans 3", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --wrap: 1140px;
  --radius: 4px;
  --shadow: 0 10px 30px rgba(0,42,72,.10);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; scroll-padding-top:92px; }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:var(--navy); text-decoration:none; }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 24px; }

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:600;
  font-size:.82rem;
  color:var(--accent);
  margin:0 0 .5rem;
}
.eyebrow--dark{ color:var(--accent); }
.eyebrow--light{ color:#7fb2d8; }
.eyebrow--center{ text-align:center; }

.section-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.05;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:var(--navy);
  margin:0 0 .6rem;
}
.section-title--light{ color:var(--white); }

.rule{ display:block; width:64px; height:4px; background:var(--accent); border-radius:2px; margin:.4rem 0 1.4rem; }
.rule--center{ margin-left:auto; margin-right:auto; }
.rule--light{ background:#7fb2d8; }

.section-sub{ color:var(--muted); max-width:640px; margin:.4rem auto 0; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; min-height:88px; gap:16px; }
.brand-logo{ height:60px; width:auto; }
.main-nav{ display:flex; align-items:center; gap:26px; }
.main-nav a{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:600;
  font-size:1rem;
  color:var(--navy);
  padding:6px 0;
  position:relative;
}
.main-nav a:not(.nav-cta)::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:2px;
  background:var(--accent); transition:width .25s ease;
}
.main-nav a:not(.nav-cta):hover::after{ width:100%; }
.nav-cta{
  background:var(--accent); color:#fff !important;
  padding:9px 18px !important; border-radius:var(--radius);
  transition:background .2s ease;
}
.nav-cta:hover{ background:var(--accent-dk); }

.nav-toggle{
  display:none; flex-direction:column; gap:5px;
  background:none; border:0; cursor:pointer; padding:8px;
}
.nav-toggle span{ width:26px; height:2px; background:var(--navy); transition:.3s; }

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(185,1,49,.20), transparent 60%),
    linear-gradient(160deg, var(--navy) 0%, var(--navy-deep) 100%);
  background-size:cover;
  background-position:center;
  color:#fff;
  padding:120px 0 128px;
}
.hero-inner{ max-width:820px; }
.hero .eyebrow{ color:#8fbfe4; }
.hero-title{
  font-family:var(--font-display);
  font-weight:700;
  text-transform:uppercase;
  font-size:clamp(2.8rem,7vw,5rem);
  line-height:.98;
  letter-spacing:.01em;
  margin:.2rem 0 1.1rem;
}
.hero-lead{ font-size:1.2rem; color:#d7e4ef; max-width:640px; margin:0 0 2rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:600;
  font-size:1rem;
  padding:13px 26px;
  border-radius:var(--radius);
  border:2px solid transparent;
  cursor:pointer;
  transition:.2s ease;
}
.btn-primary{ background:var(--accent); color:#fff; }
.btn-primary:hover{ background:var(--accent-dk); }
.btn-ghost{ border-color:rgba(255,255,255,.5); color:#fff; }
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.btn-light{ background:#fff; color:var(--navy); }
.btn-light:hover{ background:#eef3f7; }
.btn-block{ width:100%; text-align:center; }

/* ---------- Sections ---------- */
.section{ padding:84px 0; }
.section--alt{ background:var(--bg-alt); }
.section-head{ margin-bottom:2.4rem; }
.section-head--center{ text-align:center; margin-bottom:3rem; }

.grid-2{
  display:grid; grid-template-columns:0.9fr 1.1fr; gap:48px; align-items:start;
}
.grid-2--reverse .platform-media{ order:2; }
.prose p{ margin:0 0 1.1rem; }
.prose strong{ color:var(--navy); }

/* ---------- Mission ---------- */
.section--mission{
  background-size:cover; background-position:center;
  color:#fff; text-align:center;
}
.mission-inner{ max-width:760px; margin:0 auto; }
.section--mission .rule{ margin-left:auto; margin-right:auto; }
.mission-text{ font-size:1.15rem; color:#dfeaf2; margin:0 0 1.8rem; }

/* ---------- Team ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.member{
  background:#fff; border:1px solid var(--line); border-radius:6px;
  overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column;
}
.member-photo{ aspect-ratio:3/4; overflow:hidden; background:var(--bg-alt); }
.member-photo img{ width:100%; height:100%; object-fit:cover; }
.member-body{ padding:24px; display:flex; flex-direction:column; flex:1; }
.member-name{ font-family:var(--font-display); font-size:1.5rem; text-transform:uppercase; color:var(--navy); margin:0 0 .2rem; line-height:1.1; }
.member-role{ color:var(--accent); font-weight:600; font-size:.92rem; margin:0 0 .9rem; }
.member-short{ color:var(--muted); font-size:.97rem; margin:0 0 1rem; }
.link-toggle{
  background:none; border:0; padding:0; cursor:pointer;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em;
  font-weight:600; color:var(--navy); font-size:.9rem; text-align:left;
}
.link-toggle::before{ content:"+ "; color:var(--accent); }
.link-toggle[aria-expanded="true"]::before{ content:"– "; }
.member-bio{ margin-top:.9rem; font-size:.95rem; color:var(--ink); }
.member-bio ul{ padding-left:1.1rem; margin:0; }
.member-bio li{ margin-bottom:.5rem; }
.member-mail{
  margin-top:auto; padding-top:1.1rem;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em;
  font-weight:600; font-size:.9rem; color:var(--accent);
}
.member-mail:hover{ color:var(--accent-dk); }

/* ---------- Offer ---------- */
.offer-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.offer-grid--text{ grid-template-columns:repeat(2,1fr); gap:28px; }
.offer-card{
  background:#fff; border:1px solid var(--line); border-radius:6px; overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.offer-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.offer-img{ width:100%; aspect-ratio:16/10; object-fit:cover; background:var(--bg-alt); }
.offer-body{ padding:28px 30px; }
.offer-body h3{ font-family:var(--font-display); text-transform:uppercase; color:var(--navy); margin:0 0 .7rem; font-size:1.5rem; letter-spacing:.01em; }
.offer-body p{ color:var(--muted); font-size:.98rem; margin:0 0 .9rem; }
.offer-body p:last-child{ margin-bottom:0; }
.offer-body strong{ color:var(--navy); }
.offer-lead-in{ font-weight:600; color:var(--navy) !important; margin-bottom:.5rem !important; }
.offer-list{ margin:0 0 .9rem; padding-left:0; list-style:none; }
.offer-list li{
  position:relative; padding-left:1.4rem; margin-bottom:.4rem;
  color:var(--muted); font-size:.98rem;
}
.offer-list li::before{
  content:""; position:absolute; left:0; top:.55em;
  width:7px; height:7px; background:var(--accent); border-radius:50%;
}

/* Numer porządkowy karty */
.offer-num{
  display:inline-block; font-family:var(--font-display); font-weight:700;
  font-size:1rem; letter-spacing:.15em; color:var(--accent);
  border-bottom:2px solid var(--accent); padding-bottom:2px; margin-bottom:.8rem;
}
/* CTA „Masz dla nas wyzwanie?" */
.offer-cta{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.04em;
  font-weight:700; color:var(--accent) !important; font-size:1rem; margin-top:.4rem !important;
}
.offer-cta::before{
  content:"@"; display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; background:var(--accent); color:#fff;
  border-radius:4px; font-size:.95rem; font-weight:700;
}


.procedures{ margin-top:52px; max-width:760px; }
.procedures-title{ font-family:var(--font-display); text-transform:uppercase; color:var(--navy); font-size:1.4rem; margin:0 0 1rem; }
.procedures-list{ list-style:none; margin:0; padding:0; }
.procedures-list li{
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding:16px 0; border-top:1px solid var(--line);
}
.procedures-list li:last-child{ border-bottom:1px solid var(--line); }
.doc-link{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em;
  font-weight:600; color:var(--accent); font-size:.85rem; white-space:nowrap;
}
.doc-link[aria-disabled="true"]{ opacity:.6; }

/* ---------- Platform ---------- */
.platform-media{ position:relative; }
.platform-desktop{ border-radius:6px; box-shadow:var(--shadow); }
.platform-mobile{
  position:absolute; right:-6px; bottom:-24px; width:34%;
  border-radius:8px; box-shadow:var(--shadow);
  border:4px solid #fff;
}
.platform-text p{ color:var(--muted); }

/* ---------- News ---------- */
.news-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.news-card{
  background:#fff; border:1px solid var(--line); border-left:4px solid var(--accent);
  border-radius:6px; padding:26px 28px;
}
.news-card h3{ font-family:var(--font-display); text-transform:uppercase; color:var(--navy); margin:0 0 .5rem; font-size:1.35rem; }
.news-card p{ color:var(--muted); margin:0; font-size:.98rem; }

/* ---------- Partners ---------- */
.section--partners{ padding:56px 0; }
.partners-row{
  display:flex; align-items:center; justify-content:center; flex-wrap:wrap;
  gap:44px; margin-top:1rem;
}
.partners-row img{ max-height:64px; width:auto; filter:grayscale(1); opacity:.75; transition:.25s; }
.partners-row img:hover{ filter:none; opacity:1; }
.partners-row .partner-umk{ max-height:96px; }

/* ---------- Contact ---------- */
.section--contact{ background-size:cover; background-position:center; color:#fff; text-align:center; }
.contact-inner{ max-width:620px; margin:0 auto; }
.contact-name{ font-family:var(--font-display); font-size:1.5rem; text-transform:uppercase; margin:0 0 1.2rem; }
.contact-list{ list-style:none; margin:0 auto 1.8rem; padding:0; display:inline-block; text-align:left; }
.contact-list li{ padding:10px 0; border-bottom:1px solid rgba(255,255,255,.15); color:#dbe7f0; }
.contact-list li span{
  display:inline-block; min-width:120px;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em;
  color:#8fbfe4; font-size:.9rem;
}
.contact-list a{ color:#fff; }
.contact-list a:hover{ color:#8fbfe4; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-deep); color:#c8d7e3; padding:36px 0; }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-logo{ height:40px; background:#fff; padding:6px 10px; border-radius:4px; }
.footer-copy{ margin:0; font-size:.9rem; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid-2{ grid-template-columns:1fr; gap:32px; }
  .grid-2--reverse .platform-media{ order:0; }
  .team-grid{ grid-template-columns:1fr 1fr; }
  .offer-grid{ grid-template-columns:1fr 1fr; }
  .offer-grid--text{ grid-template-columns:1fr; }
  .news-grid{ grid-template-columns:1fr; }
  .platform-mobile{ display:none; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .section{ padding:60px 0; }
  .hero{ padding:70px 0 78px; }
  .team-grid,.offer-grid{ grid-template-columns:1fr; }
  .nav-toggle{ display:flex; }
  .main-nav{
    position:absolute; top:88px; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#fff; border-bottom:1px solid var(--line);
    max-height:0; overflow:hidden; transition:max-height .3s ease;
  }
  .main-nav.open{ max-height:420px; }
  .main-nav a{ padding:14px 24px; border-top:1px solid var(--line); }
  .nav-cta{ margin:12px 24px; text-align:center; }
  .footer-inner{ justify-content:center; text-align:center; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}
