/* ── PROTOSS Computer Kft. – styles.css ── */
/* Brand: #1c4a98 (kék) / #d52727 (piros) / Verdana */

:root {
  --primary:      #1c4a98;
  --primary-dark: #14387a;
  --primary-light:#e8edf7;
  --accent:       #d52727;
  --accent-dark:  #b01f1f;
  --soft:         #f0f4fb;
  --bg:           #f5f7fc;
  --text:         #1d2733;
  --muted:        #5d6b7a;
  --border:       #d4dde9;
  --white:        #ffffff;
}

/* ── BASE ── */
body {
  background: var(--bg);
  color: var(--text);
  font-family: Verdana, Geneva, sans-serif;
  font-size: 14.5px;
  line-height: 1.75;
}

/* ── TOPBAR ── */
.topbar {
  background: linear-gradient(90deg, var(--primary-dark) 0%, var(--primary) 60%, #d52727 100%);
  color: #dfe8ef;
}

/* ── BRAND ── */
.brand { display: flex; align-items: center; }

/* ── NAV ── */
.navbar { background: linear-gradient(90deg, var(--primary-dark) 0%, var(--primary) 60%, #8a1a1a 100%) !important; border-bottom: none !important; box-shadow: 0 2px 16px rgba(20,56,122,.25) !important; }
.nav-link { font-weight: 600; font-size: .85rem; color: rgba(255,255,255,.8) !important; }
.nav-link:hover, .nav-link.active { color: #fff !important; }
.navbar-brand { padding: 0; }
.navbar-logo { height: 38px; width: auto; object-fit: contain; }
.navbar-toggler { border-color: rgba(255,255,255,.4) !important; }
.navbar-toggler-icon { filter: invert(1); }
.btn-nav-cta { background: var(--accent) !important; color: #fff !important; border-color: var(--accent) !important; font-weight: 700; }
.btn-nav-cta:hover { background: var(--accent-dark) !important; border-color: var(--accent-dark) !important; }

/* ── BUTTONS ── */
.btn-primary { background: var(--primary); border-color: var(--primary); }
.btn-primary:hover, .btn-primary:focus { background: var(--primary-dark); border-color: var(--primary-dark); }
.btn-outline-primary { color: var(--primary); border-color: var(--primary); }
.btn-outline-primary:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-danger { background: var(--accent); border-color: var(--accent); }

/* ── HERO (főoldal) ── */
.hero { background: linear-gradient(135deg, var(--primary-light) 0%, #ffffff 60%); }
.hero-title, .page-title { color: var(--primary-dark); line-height: 1.15; }
.hero-title { font-size: clamp(1.8rem, 4vw, 2.8rem); }
.page-title { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
.lead-custom { color: var(--muted); font-size: 1.05rem; }

/* ── BADGES ── */
.badge-soft { background: var(--primary-light); color: var(--primary); }
.badge.text-bg-primary { background: var(--primary) !important; }
.badge.text-bg-accent  { background: var(--accent) !important; }

/* ── SECTIONS ── */
.soft-section { background: var(--white); }
.section-padding { padding: 4rem 0; }
.page-hero { background: var(--white); border-bottom: 1px solid var(--border); }

/* ── CARDS ── */
.card-soft,
.service-card,
.step-card,
.form-card,
.hero-card {
  background: var(--white);
  border: 1px solid var(--border);
  box-shadow: 0 8px 28px rgba(28,74,152,.07);
  border-radius: 1rem;
}

.service-card.featured {
  border: 2px solid var(--primary);
  box-shadow: 0 8px 28px rgba(28,74,152,.14);
}

/* ── PROBLEM BOXES ── */
.problem-box {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: .9rem;
  padding: 1rem 1.1rem;
  height: 100%;
  font-size: .9rem;
  position: relative;
  padding-left: 1.4rem;
}
.problem-box::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px; border-radius: .9rem 0 0 .9rem;
  background: var(--accent);
}

/* ── CALLOUT ── */
.callout {
  background: var(--primary-light);
  border-left: 5px solid var(--primary);
  border-radius: 0 .5rem .5rem 0;
  font-weight: 600;
  color: var(--primary-dark);
  font-size: .92rem;
}

/* ── STEP CARDS ── */
.step-card .badge { font-size: .8rem; min-width: 28px; min-height: 28px; display: inline-flex; align-items: center; justify-content: center; }

/* ── CTA SECTIONS ── */
.cta-box {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 70%, #8a1a1a 100%);
  border-radius: 1.2rem;
}

/* ── BLOG CARDS ── */
.blog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 1rem;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
  height: 100%;
  display: flex; flex-direction: column;
}
.blog-card:hover { box-shadow: 0 10px 36px rgba(28,74,152,.12); transform: translateY(-3px); }
.blog-card-num {
  display: inline-block;
  background: var(--primary-light);
  color: var(--primary);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  padding: .2rem .75rem; border-radius: 999px;
  margin-bottom: .6rem;
}
.blog-card-tag {
  font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: .35rem;
}
.blog-card h2 { font-size: .95rem; color: var(--primary-dark); line-height: 1.4; margin-bottom: .5rem; }
.blog-card p { font-size: .85rem; color: var(--muted); line-height: 1.65; flex: 1; }
.blog-card-body { padding: 1.4rem; display: flex; flex-direction: column; flex: 1; }
.blog-card-footer {
  padding: 1rem 1.4rem;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.blog-card-read { font-size: .82rem; font-weight: 700; color: var(--primary); text-decoration: none; }
.blog-card-read:hover { color: var(--accent); }

/* ── ARTICLE PAGES ── */
.article-page { max-width: 760px; margin: 0 auto; padding: 3rem 1.5rem 5rem; }
.article-meta { font-size: .8rem; color: var(--muted); margin-bottom: 2rem; display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; }
.article-tag-pill {
  background: var(--primary-light); color: var(--primary);
  font-size: .72rem; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; padding: .2rem .75rem; border-radius: 999px;
}
.article-body h2 { color: var(--primary-dark); font-size: 1.3rem; margin: 2rem 0 .7rem; padding-bottom: .4rem; border-bottom: 2px solid var(--primary-light); }
.article-body h3 { color: var(--primary); font-size: 1.05rem; margin: 1.6rem 0 .5rem; }
.article-body p { margin-bottom: 1.1rem; font-size: .92rem; }
.article-body ul, .article-body ol { padding-left: 1.4rem; margin-bottom: 1.1rem; font-size: .92rem; }
.article-body li { margin-bottom: .3rem; }

.glossary-box {
  background: var(--primary-light);
  border-left: 4px solid var(--primary);
  border-radius: 0 .6rem .6rem 0;
  padding: 1.1rem 1.4rem;
  margin: 1.5rem 0;
}
.glossary-box-title { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--primary); margin-bottom: .7rem; }
.glossary-term { margin-bottom: .7rem; }
.glossary-term:last-child { margin-bottom: 0; }
.glossary-term strong { display: block; font-size: .9rem; color: var(--primary-dark); margin-bottom: .1rem; }
.glossary-term span { font-size: .85rem; color: var(--muted); }

.highlight-box {
  background: #fff8e6; border: 1px solid #e8c84a;
  border-radius: .6rem; padding: 1rem 1.3rem;
  margin: 1.2rem 0; font-size: .9rem; color: #5a4500;
}

.questions-box {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: .8rem; padding: 1.2rem 1.4rem; margin-top: 1.8rem;
}
.questions-box-title { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--primary); margin-bottom: .7rem; }
.questions-box ul { list-style: none; padding: 0; margin: 0; }
.questions-box li { font-size: .88rem; color: var(--muted); padding: .4rem 0 .4rem 1.3rem; border-bottom: 1px solid var(--border); position: relative; line-height: 1.5; }
.questions-box li:last-child { border-bottom: none; }
.questions-box li::before { content: '?'; position: absolute; left: 0; font-weight: 700; color: var(--primary); font-size: .8rem; }

/* ── ARTICLE NAV BREADCRUMB ── */
.article-breadcrumb { font-size: .82rem; color: var(--muted); margin-bottom: 1.5rem; }
.article-breadcrumb a { color: var(--primary); text-decoration: none; font-weight: 600; }

/* ── TESTIMONIALS ── */
.testimonial {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 1rem; padding: 1.5rem 1.7rem;
  position: relative; border-top: 4px solid var(--primary);
}
.testimonial-text { font-size: .9rem; color: var(--text); font-style: italic; line-height: 1.7; margin-bottom: .8rem; }
.testimonial-from { font-size: .78rem; font-weight: 700; color: var(--muted); }

/* ── CONTACT FORM ── */
.form-label { font-size: .8rem; font-weight: 700; color: var(--primary-dark); letter-spacing: .02em; text-transform: uppercase; }
.form-control:focus, .form-select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(28,74,152,.12); }

/* ── FOOTER ── */
.footer { background: var(--primary-dark); color: #d8e4ed; }
.footer a { color: #ffffff; text-decoration: none; }
.footer a:hover { text-decoration: underline; color: #ccd8f0; }
.footer-brand { font-weight: 700; font-size: 1rem; color: #fff; }
.footer-brand span { color: var(--accent); }

/* ── HELPERS ── */
.helper { color: var(--muted); font-size: .88rem; }
.text-accent { color: var(--accent) !important; }
.text-primary-brand { color: var(--primary) !important; }
.bg-primary-light { background: var(--primary-light); }

/* ── GEO ELEMEK (quick-answer, geo-list, geo-faq) ── */
.quick-answer {
  background: var(--primary-light);
  border-left: 4px solid var(--primary);
  border-radius: 0 .8rem .8rem 0;
  padding: 1.2rem 1.6rem;
  margin-bottom: 1.6rem;
}
.quick-answer-label {
  font-size: .68rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--primary); margin-bottom: .5rem;
}
.quick-answer p {
  font-size: .95rem; color: var(--primary-dark);
  font-weight: 600; margin: 0; line-height: 1.65;
}
.geo-list {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: .8rem;
  padding: 1.1rem 1.5rem;
  margin-bottom: 1.6rem;
}
.geo-list-label {
  font-size: .68rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--muted); margin-bottom: .7rem;
}
.geo-list ul { list-style: none; padding: 0; margin: 0; }
.geo-list li {
  padding: .35rem 0 .35rem 1.3rem;
  border-bottom: 1px solid var(--border);
  font-size: .9rem; color: var(--text);
  position: relative; line-height: 1.5;
}
.geo-list li:last-child { border-bottom: none; }
.geo-list li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--primary); font-weight: 700; font-size: .82rem;
}
.geo-faq {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: .8rem;
  padding: 1.3rem 1.6rem;
  margin-top: 2rem;
}
.geo-faq-label {
  font-size: .68rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--primary); margin-bottom: 1rem;
}
.geo-faq-item {
  margin-bottom: 1rem; padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}
.geo-faq-item:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.geo-faq-q {
  font-size: .92rem; font-weight: 700;
  color: var(--primary-dark); margin-bottom: .35rem;
}
.geo-faq-a {
  font-size: .88rem; color: var(--text);
  line-height: 1.65; margin: 0;
}
