/* ============================================================
   EPDS.hu — Page components: Kapcsolat, Rólunk, Referenciák,
   Blog, Letölthető dokumentumok, Fogalomtár.
   Extends styles.css + knowledge.css; nothing locked is changed.
   ============================================================ */

/* ===========================================================
   KAPCSOLAT — booking + contact
   =========================================================== */
.contact-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:34px;align-items:start;margin-top:8px;}

/* booking form card */
.cform{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);
  padding:30px 32px 32px;
}
.cform .cf-h{font-size:20px;font-weight:500;color:var(--navy);letter-spacing:-.01em;}
.cform .cf-sub{font-size:14.5px;color:var(--muted);margin-top:7px;text-wrap:pretty;}

/* track picker — three radio cards */
.track-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:22px 0 4px;}
.track-pick .tp{
  position:relative;border:1px solid var(--line-strong);border-radius:var(--radius-sm);
  padding:14px 14px 13px;cursor:pointer;background:#fff;transition:border-color .15s ease,background .15s ease;
}
.track-pick .tp:hover{border-color:var(--accent);}
.track-pick .tp input{position:absolute;opacity:0;pointer-events:none;}
.track-pick .tp .tp-idx{font-family:var(--font-label);font-size:11px;letter-spacing:var(--label-tracking);color:var(--accent-text);}
.track-pick .tp .tp-t{font-size:14px;font-weight:500;color:var(--navy);margin-top:7px;line-height:1.25;text-wrap:balance;}
.track-pick .tp input:checked + .tp-idx + .tp-t{color:var(--navy);}
.track-pick .tp:has(input:checked){border-color:var(--accent);background:var(--accent-tint);box-shadow:inset 0 0 0 1px var(--accent);}

/* generic form fields */
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;margin-top:20px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field.full{grid-column:1 / -1;}
.field label{font-size:13px;font-weight:500;color:var(--muted);}
.field label .req{color:var(--accent-press);}
.field input,.field select,.field textarea{
  height:46px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);
  background:#fff;padding:0 14px;font-family:inherit;font-size:15px;color:var(--ink);
  transition:border-color .15s ease,box-shadow .15s ease;
}
.field textarea{height:auto;min-height:108px;padding:12px 14px;resize:vertical;line-height:1.5;}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%2365727D' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint);}
.field input::placeholder,.field textarea::placeholder{color:#94A2AC;}
.cf-foot{display:flex;align-items:center;gap:16px;margin-top:22px;flex-wrap:wrap;}
.cf-foot .cf-note{font-size:12.5px;color:var(--faint);max-width:34ch;}

/* contact aside */
.contact-aside{display:flex;flex-direction:column;gap:16px;}
.ci-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);padding:24px 24px;}
.ci-card h3{font-size:15px;font-weight:500;color:var(--navy);margin-bottom:4px;}
.ci-row{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line);}
.ci-row:first-of-type{border-top:none;padding-top:10px;}
.ci-row .ci-ic{
  width:34px;height:34px;flex-shrink:0;border:1px solid var(--line-strong);border-radius:8px;
  display:flex;align-items:center;justify-content:center;color:var(--navy);background:#fff;
}
.ci-row .ci-ic svg{width:17px;height:17px;}
.ci-row .ci-k{font-family:var(--font-label);font-size:10.5px;letter-spacing:var(--label-tracking);color:var(--faint);}
.ci-row .ci-v{font-size:15px;color:var(--ink);margin-top:3px;font-weight:500;}
.ci-row .ci-v a{color:var(--ink);}
.ci-row .ci-v a:hover{color:var(--accent-press);}
.ci-row .ci-v .sub{display:block;font-size:13px;color:var(--muted);font-weight:400;margin-top:2px;}

/* hours table */
.hours{display:grid;grid-template-columns:auto 1fr;gap:7px 16px;margin-top:6px;}
.hours dt{font-size:13.5px;color:var(--muted);}
.hours dd{font-size:13.5px;color:var(--ink);margin:0;text-align:right;font-weight:500;}

/* map placeholder */
.map-ph{
  height:200px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:
    repeating-linear-gradient(0deg,rgba(15,42,67,.04) 0 1px,transparent 1px 26px),
    repeating-linear-gradient(90deg,rgba(15,42,67,.04) 0 1px,transparent 1px 26px),
    #EDF1F4;
  position:relative;display:flex;align-items:center;justify-content:center;
}
.map-ph .pin{display:flex;flex-direction:column;align-items:center;gap:8px;}
.map-ph .pin .dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(233,143,23,.2);}
.map-ph .pin span{font-family:var(--font-label);font-size:11px;letter-spacing:var(--label-tracking);color:var(--faint);background:rgba(255,255,255,.8);padding:4px 9px;border-radius:5px;border:1px solid var(--line);}

/* ===========================================================
   RÓLUNK — about / experts / certifications
   =========================================================== */
.about-lead{max-width:760px;}
.about-lead p{font-size:18px;line-height:1.6;color:var(--ink);margin-top:18px;text-wrap:pretty;}
.about-lead p + p{margin-top:14px;}

.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;background:var(--paper);margin-top:36px;}
.about-stats .as{padding:24px 26px;border-left:1px solid var(--line);}
.about-stats .as:first-child{border-left:none;}
.about-stats .as .n{font-size:30px;font-weight:500;color:var(--navy);letter-spacing:-.02em;}
.about-stats .as .n .u{font-size:18px;color:var(--accent);}
.about-stats .as .l{font-size:13.5px;color:var(--muted);margin-top:6px;text-wrap:pretty;}

/* team grid — richer expert cards (extends .experts/.expert) */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.team .meta{padding:20px 22px 22px;}
.team .bio{font-size:14px;color:var(--muted);line-height:1.55;margin-top:12px;padding-top:13px;border-top:1px solid var(--line);text-wrap:pretty;}

/* certifications */
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.cert{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);padding:22px 22px;display:flex;gap:15px;align-items:flex-start;}
.cert .cert-ic{
  width:42px;height:42px;flex-shrink:0;border:1px solid var(--line-strong);border-radius:9px;
  display:flex;align-items:center;justify-content:center;color:var(--accent-press);background:var(--accent-tint);
}
.cert .cert-ic svg{width:21px;height:21px;}
.cert h3{font-size:15.5px;font-weight:500;color:var(--navy);line-height:1.25;}
.cert p{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5;text-wrap:pretty;}

/* values / approach list */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.value{border-top:2px solid var(--accent);padding-top:18px;}
.value h3{font-size:17px;font-weight:500;color:var(--navy);}
.value p{font-size:14.5px;color:var(--muted);margin-top:9px;line-height:1.55;text-wrap:pretty;}

/* ===========================================================
   REFERENCIÁK — anonymised case studies
   =========================================================== */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.case{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);
  overflow:hidden;display:flex;flex-direction:column;
}
.case .case-top{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 24px;border-bottom:1px solid var(--line);background:var(--bg);}
.case .case-tag{font-family:var(--font-label);font-size:11px;letter-spacing:var(--label-tracking);color:var(--accent-text);}
.case .case-scope{font-family:var(--font-label);font-size:11px;letter-spacing:var(--label-tracking);color:var(--faint);}
.case .case-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1;}
.case h3{font-size:18.5px;font-weight:500;color:var(--navy);letter-spacing:-.01em;line-height:1.2;text-wrap:balance;}
.case dl{display:grid;grid-template-columns:auto 1fr;gap:9px 16px;margin:16px 0 0;}
.case dt{font-family:var(--font-label);font-size:11px;letter-spacing:var(--label-tracking);color:var(--accent-text);padding-top:2px;white-space:nowrap;}
.case dd{margin:0;font-size:14.5px;line-height:1.5;color:var(--ink);text-wrap:pretty;}
.case .case-result{
  margin-top:18px;padding-top:15px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);
}
.case .case-result .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;}
.case .case-result strong{color:var(--navy);font-weight:500;}

/* outcome metric strip */
.outcome-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;background:var(--paper);}
.outcome-strip .oc{padding:26px 28px;border-left:1px solid var(--line);}
.outcome-strip .oc:first-child{border-left:none;}
.outcome-strip .oc .n{font-size:28px;font-weight:500;color:var(--navy);letter-spacing:-.02em;}
.outcome-strip .oc .n .u{color:var(--accent);font-size:18px;}
.outcome-strip .oc .l{font-size:14px;color:var(--muted);margin-top:7px;text-wrap:pretty;}

/* ===========================================================
   BLOG — article list
   =========================================================== */
.blog-filter{display:flex;flex-wrap:wrap;gap:9px;margin:4px 0 36px;}
.blog-filter a{
  font-size:13.5px;color:var(--ink);border:1px solid var(--line);border-radius:20px;padding:8px 15px;
  background:#fff;transition:border-color .15s ease,color .15s ease,background .15s ease;
}
.blog-filter a:hover{border-color:var(--accent);color:var(--accent-press);}
.blog-filter a.is-active{background:var(--navy);border-color:var(--navy);color:#fff;}

/* featured post */
.blog-feature{
  display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;background:var(--paper);margin-bottom:34px;
}
.blog-feature .bf-media{
  background:
    repeating-linear-gradient(135deg,rgba(15,42,67,.04) 0 1px,transparent 1px 12px),
    #E7ECF0;min-height:300px;position:relative;border-right:1px solid var(--line);
}
.blog-feature .bf-media .bf-cat{
  position:absolute;top:18px;left:18px;font-family:var(--font-label);font-size:11px;
  letter-spacing:var(--label-tracking);color:var(--accent-text);background:rgba(255,255,255,.9);
  border:1px solid var(--line);padding:5px 11px;border-radius:20px;
}
.blog-feature .bf-body{padding:34px 36px;display:flex;flex-direction:column;justify-content:center;}
.blog-feature .bf-date{font-family:var(--font-label);font-size:11.5px;letter-spacing:var(--label-tracking);color:var(--faint);}
.blog-feature h2{font-size:27px;font-weight:500;color:var(--navy);letter-spacing:-.015em;line-height:1.14;margin-top:12px;text-wrap:balance;}
.blog-feature p{font-size:15.5px;color:var(--muted);margin-top:14px;line-height:1.55;text-wrap:pretty;}
.blog-feature .go{margin-top:22px;display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:500;color:var(--navy);}
.blog-feature .go .arr{color:var(--accent);transition:transform .15s ease;}
.blog-feature:hover .go .arr{transform:translateX(3px);}

/* blog card category tag + up-link */
.blog-card .bc-cat{font-family:var(--font-label);font-size:10.5px;letter-spacing:var(--label-tracking);
  color:var(--accent-text);border:1px solid var(--line-strong);border-radius:20px;padding:3px 10px;align-self:flex-start;margin-bottom:13px;}
.blog-card .bc-up{font-size:12.5px;color:var(--faint);margin-top:12px;}
.blog-card .bc-up a{color:var(--accent-text);text-decoration:underline;text-decoration-color:var(--line-strong);text-underline-offset:2px;}
.blog-card .bc-up a:hover{text-decoration-color:var(--accent);}

/* ===========================================================
   LETÖLTHETŐ DOKUMENTUMOK — downloads grid
   =========================================================== */
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.dl-card{
  display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--paper);padding:24px 24px 22px;transition:border-color .15s ease;
}
.dl-card .dl-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.dl-card .dl-ic{
  width:44px;height:44px;border:1px solid var(--line-strong);border-radius:9px;
  display:flex;align-items:center;justify-content:center;color:var(--accent-press);background:var(--accent-tint);
}
.dl-card .dl-ic svg{width:21px;height:21px;}
.dl-card .dl-type{font-family:var(--font-label);font-size:10.5px;letter-spacing:var(--label-tracking);
  color:var(--faint);border:1px solid var(--line);border-radius:20px;padding:4px 10px;}
.dl-card h3{font-size:16.5px;font-weight:500;color:var(--navy);line-height:1.25;text-wrap:balance;}
.dl-card p{font-size:13.5px;color:var(--muted);margin-top:9px;line-height:1.5;flex:1;text-wrap:pretty;}
.dl-card .dl-go{
  margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--navy);
}
.dl-card .dl-go .arr{color:var(--accent);font-size:15px;transition:transform .15s ease;}
.dl-card:hover .dl-go .arr{transform:translateX(3px);}
.dl-card .dl-meta{font-family:var(--font-label);font-size:10.5px;letter-spacing:var(--label-tracking);color:var(--faint);margin-top:6px;}

/* email-gate note band */
.dl-note{margin-top:30px;border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:var(--radius);background:var(--accent-tint);padding:18px 24px;font-size:14.5px;color:var(--ink);}

/* ===========================================================
   FOGALOMTÁR — A–Z glossary
   =========================================================== */
.az-bar{
  position:sticky;top:var(--header-h);z-index:20;background:rgba(245,247,249,.96);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  display:flex;flex-wrap:wrap;gap:5px;padding:16px 0;border-bottom:1px solid var(--line);margin-bottom:8px;
}
.az-bar a{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  font-size:13.5px;font-weight:500;color:var(--navy);border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;transition:border-color .15s ease,background .15s ease,color .15s ease;
}
.az-bar a:hover{border-color:var(--accent);color:var(--accent-press);}
.az-bar a.empty{color:var(--line-strong);background:transparent;border-color:transparent;pointer-events:none;}

.gloss-group{padding-top:34px;scroll-margin-top:130px;}
.gloss-group .gg-letter{
  font-family:var(--font-label);font-size:13px;letter-spacing:var(--label-tracking);color:var(--accent-text);
  padding-bottom:12px;border-bottom:1px solid var(--line-strong);margin-bottom:4px;
}
.gloss-term{display:grid;grid-template-columns:230px 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);}
.gloss-term dt{font-size:16px;font-weight:500;color:var(--navy);letter-spacing:-.005em;}
.gloss-term dd{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink);text-wrap:pretty;}
.gloss-term dd .up{display:block;margin-top:7px;font-size:13px;}
.gloss-term dd .up a{color:var(--accent-text);text-decoration:underline;text-decoration-color:var(--line-strong);text-underline-offset:2px;}
.gloss-term dd .up a:hover{text-decoration-color:var(--accent);}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .contact-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .cert-grid{grid-template-columns:repeat(2,1fr);}
  .dl-grid{grid-template-columns:repeat(2,1fr);}
  .about-stats{grid-template-columns:repeat(2,1fr);}
  .about-stats .as:nth-child(3){border-left:none;}
  .about-stats .as{border-top:1px solid var(--line);}
  .about-stats .as:nth-child(1),.about-stats .as:nth-child(2){border-top:none;}
}
@media (max-width:760px){
  .case-grid{grid-template-columns:1fr;}
  .value-grid{grid-template-columns:1fr;gap:24px;}
  .blog-feature{grid-template-columns:1fr;}
  .blog-feature .bf-media{border-right:none;border-bottom:1px solid var(--line);min-height:200px;}
}
@media (max-width:560px){
  .track-pick{grid-template-columns:1fr;}
  .cf-grid{grid-template-columns:1fr;}
  .cform{padding:24px 22px 26px;}
  .team-grid{grid-template-columns:1fr;}
  .cert-grid{grid-template-columns:1fr;}
  .dl-grid{grid-template-columns:1fr;}
  .about-stats{grid-template-columns:1fr;}
  .about-stats .as{border-left:none;border-top:1px solid var(--line);}
  .about-stats .as:first-child{border-top:none;}
  .outcome-strip{grid-template-columns:1fr;}
  .outcome-strip .oc{border-left:none;border-top:1px solid var(--line);}
  .outcome-strip .oc:first-child{border-top:none;}
  .gloss-term{grid-template-columns:1fr;gap:6px;}
  .value-grid{grid-template-columns:1fr;}
}
