/* ============================================================
   Lexoft — Homepage styles
   ============================================================ */

/* Hero */
.hero { background: linear-gradient(180deg, var(--accent-soft) 0%, #fff 100%); border-bottom: 1px solid var(--line); padding: 60px 0 64px; }
.hero-inner { max-width: 760px; margin: 0 auto; text-align: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid var(--accent-soft-2); color: var(--accent-dark); font-size: 13px; font-weight: 600; padding: 6px 14px; border-radius: 100px; box-shadow: var(--sh-1); }
.hero-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); }
.hero h1 { font-size: clamp(34px, 5.2vw, 52px); font-weight: 800; letter-spacing: -.035em; line-height: 1.08; margin-top: 22px; color: var(--ink); text-wrap: balance; }
.hero h1 em { font-style: normal; color: var(--accent); }
.hero p { font-size: 19px; color: var(--ink-2); margin-top: 18px; line-height: 1.55; max-width: 600px; margin-left: auto; margin-right: auto; }

.hero-search { position: relative; max-width: 620px; margin: 32px auto 0; }
.hero-search-box { display: flex; align-items: center; gap: 12px; background: #fff; border: 1.5px solid var(--line-2); border-radius: 14px; padding: 6px 6px 6px 18px; box-shadow: var(--sh-2); transition: .18s; }
.hero-search-box:focus-within { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft), var(--sh-2); }
.hero-search-box > svg { width: 22px; height: 22px; color: var(--ink-4); flex-shrink: 0; }
.hero-search-box input { flex: 1; border: none; outline: none; font-family: inherit; font-size: 17px; color: var(--ink); background: none; padding: 12px 0; }
.hero-search-box input::placeholder { color: var(--ink-4); }
.hero-search .search-results { width: 100%; left: 0; right: auto; top: calc(100% + 10px); text-align: left; }
.hero-tags { display: flex; align-items: center; justify-content: center; gap: 9px; flex-wrap: wrap; margin-top: 18px; }
.hero-tags .ht-label { font-size: 13px; color: var(--ink-3); font-weight: 500; }
.hero-tags a { font-size: 13.5px; font-weight: 500; color: var(--ink-2); background: #fff; border: 1px solid var(--line); padding: 6px 13px; border-radius: 100px; transition: .14s; }
.hero-tags a:hover { color: var(--accent); border-color: var(--accent-soft-2); background: var(--accent-soft); }

/* Category grid */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.cat-card { display: flex; gap: 16px; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 22px; transition: .18s; }
.cat-card:hover { border-color: var(--accent-soft-2); box-shadow: var(--sh-2); transform: translateY(-3px); }
.cat-card .cc-body h3 { font-size: 17px; font-weight: 700; color: var(--ink); letter-spacing: -.01em; display: flex; align-items: center; gap: 6px; }
.cat-card .cc-body h3 svg.arr { width: 16px; height: 16px; color: var(--ink-4); opacity: 0; transform: translateX(-4px); transition: .18s; }
.cat-card:hover .cc-body h3 svg.arr { opacity: 1; transform: translateX(0); color: var(--accent); }
.cat-card .cc-body p { font-size: 13.5px; color: var(--ink-3); margin-top: 4px; line-height: 1.45; }
.cat-card .cc-count { font-size: 12.5px; color: var(--ink-4); font-weight: 600; margin-top: 10px; }

/* Featured / popular */
.featured-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 22px; }
.feat-main { display: flex; flex-direction: column; justify-content: flex-end; background: linear-gradient(160deg, var(--accent-darker), var(--accent)); border-radius: var(--r-lg); padding: 36px; color: #fff; min-height: 320px; position: relative; overflow: hidden; }
.feat-main::after { content: ''; position: absolute; right: -60px; top: -60px; width: 260px; height: 260px; border-radius: 50%; background: rgba(255,255,255,.06); }
.feat-main .badge { background: rgba(255,255,255,.16); color: #fff; align-self: flex-start; }
.feat-main h3 { font-size: 30px; font-weight: 800; letter-spacing: -.025em; line-height: 1.15; margin: 16px 0 12px; max-width: 460px; }
.feat-main p { font-size: 15.5px; color: rgba(255,255,255,.82); max-width: 440px; line-height: 1.55; }
.feat-main .feat-meta { display: flex; align-items: center; gap: 14px; margin-top: 22px; font-size: 13.5px; color: rgba(255,255,255,.8); }
.feat-side { display: flex; flex-direction: column; gap: 16px; }
.feat-item { display: flex; flex-direction: column; gap: 8px; background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 20px; transition: .16s; flex: 1; }
.feat-item:hover { border-color: var(--accent-soft-2); box-shadow: var(--sh-2); transform: translateY(-2px); }
.feat-item h4 { font-size: 16px; font-weight: 700; color: var(--ink); line-height: 1.3; }
.feat-item .fi-meta { font-size: 12.5px; color: var(--ink-3); margin-top: auto; }

/* Recent updates list */
.updates { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; }
.update-row { display: flex; align-items: center; gap: 18px; padding: 18px 22px; border-bottom: 1px solid var(--line); transition: .14s; }
.update-row:last-child { border-bottom: none; }
.update-row:hover { background: var(--bg-2); }
.update-row .ur-cat { font-size: 12px; font-weight: 600; color: var(--accent); text-transform: uppercase; letter-spacing: .03em; width: 150px; flex-shrink: 0; }
.update-row .ur-title { font-size: 15.5px; font-weight: 600; color: var(--ink); flex: 1; }
.update-row:hover .ur-title { color: var(--accent); }
.update-row .ur-date { font-size: 13px; color: var(--ink-3); flex-shrink: 0; display: flex; align-items: center; gap: 6px; }
.update-row .ur-date svg { width: 14px; height: 14px; color: var(--ink-4); }

/* About teaser (legacy E-E-A-T block - kept for compatibility) */
.about-teaser { background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 44px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.about-teaser h2 { font-size: 30px; font-weight: 800; letter-spacing: -.025em; color: var(--ink); line-height: 1.15; }
.about-teaser p { font-size: 16px; color: var(--ink-2); margin-top: 14px; line-height: 1.6; }
.eeat-list { display: flex; flex-direction: column; gap: 14px; }
.eeat-item { display: flex; gap: 14px; align-items: flex-start; background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 16px 18px; }
.eeat-item .ico { width: 38px; height: 38px; border-radius: 10px; }
.eeat-item .ico svg { width: 20px; height: 20px; }
.eeat-item h4 { font-size: 15px; font-weight: 700; color: var(--ink); }
.eeat-item p { font-size: 13.5px; color: var(--ink-3); margin-top: 3px; line-height: 1.45; }

/* ============================================================
   About the portal (new, replaces about-teaser on homepage)
   ============================================================ */
.about-portal {
  background: linear-gradient(180deg, var(--accent-soft) 0%, #fff 60%);
  border: 1px solid var(--accent-soft-2);
  border-radius: var(--r-xl);
  padding: 56px 48px;
  position: relative;
  overflow: hidden;
}
.about-portal::before {
  content: '';
  position: absolute; top: -100px; right: -100px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, var(--accent-soft-2) 0%, transparent 70%);
  border-radius: 50%; opacity: .5; pointer-events: none;
}
.about-portal-head { max-width: 780px; position: relative; }
.about-portal-head .eyebrow { color: var(--accent); }
.about-portal-head h2 {
  font-size: clamp(28px, 3.6vw, 38px);
  font-weight: 800; letter-spacing: -.03em; line-height: 1.15;
  color: var(--ink); margin-top: 10px;
}
.about-portal-lead {
  font-size: 17.5px; color: var(--ink-2); line-height: 1.65;
  margin-top: 18px;
}

.about-portal-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
  margin: 36px 0 40px; position: relative;
}
.ap-stat {
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--r); padding: 20px 22px;
  display: flex; flex-direction: column; gap: 4px;
}
.ap-stat b {
  font-size: 30px; font-weight: 800; color: var(--accent);
  letter-spacing: -.02em; line-height: 1; font-feature-settings: "tnum";
}
.ap-stat span { font-size: 13px; color: var(--ink-3); line-height: 1.3; }

.about-portal-pillars {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
  margin-bottom: 36px; position: relative;
}
.ap-pillar {
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 24px 26px;
  display: flex; flex-direction: column; gap: 10px;
  transition: .18s;
}
.ap-pillar:hover { border-color: var(--accent-soft-2); box-shadow: var(--sh-2); transform: translateY(-2px); }
.ap-pillar .ico {
  width: 42px; height: 42px; border-radius: 11px;
  background: var(--accent-soft); color: var(--accent);
  display: grid; place-items: center;
}
.ap-pillar .ico svg { width: 22px; height: 22px; }
.ap-pillar h3 {
  font-size: 17px; font-weight: 700; color: var(--ink);
  letter-spacing: -.01em; margin-top: 4px;
}
.ap-pillar p { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }

.about-portal-cta {
  display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center;
  background: var(--ink); color: #C7D0DC;
  padding: 32px 36px; border-radius: var(--r-lg);
  position: relative;
}
.about-portal-cta h3 {
  font-size: 20px; font-weight: 700; color: #fff;
  margin-bottom: 8px; letter-spacing: -.01em;
}
.about-portal-cta p { font-size: 15px; color: #A6B0BE; line-height: 1.6; }
.about-portal-cta .btn-primary {
  background: var(--accent); color: #fff; white-space: nowrap;
}

@media (max-width: 920px) {
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-grid { grid-template-columns: 1fr; }
  .about-teaser { grid-template-columns: 1fr; gap: 28px; padding: 32px; }
  .about-portal { padding: 36px 28px; }
  .about-portal-stats { grid-template-columns: repeat(2, 1fr); }
  .about-portal-pillars { grid-template-columns: 1fr; }
  .about-portal-cta { grid-template-columns: 1fr; padding: 26px 24px; }
}
@media (max-width: 600px) {
  .cat-grid { grid-template-columns: 1fr; }
  .update-row { flex-wrap: wrap; gap: 6px 14px; }
  .update-row .ur-cat { width: auto; }
  .update-row .ur-title { flex-basis: 100%; order: 3; }
}
