/* ============================================================
   Home page — section layouts
   ============================================================ */

/* ---- Hero ---- */
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.hero-tag {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 0.84rem; letter-spacing: -0.005em;
  padding: 8px 16px 8px 12px; border-radius: var(--r-pill);
  background: var(--surface); box-shadow: inset 0 0 0 1px var(--line-strong);
  color: var(--ink-2); margin-bottom: 26px;
}
.pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 0 rgba(216,85,42,0.45); animation: pulse 2.2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(216,85,42,0.45); } 70% { box-shadow: 0 0 0 8px rgba(216,85,42,0); } 100% { box-shadow: 0 0 0 0 rgba(216,85,42,0); } }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 22px; margin-top: 38px; padding-top: 28px; border-top: 1px solid var(--line); }
.trust-item { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 0.92rem; color: var(--ink-2); }
.trust-item svg { width: 17px; height: 17px; color: var(--accent); flex: none; }

.hero-visual { position: relative; }
.hero-portrait {
  position: relative; aspect-ratio: 5 / 5.1; width: 100%;
  background: var(--surface-2); overflow: visible;
}
.hero-portrait image-slot { position: absolute; inset: 0; }
.cert-badge {
  position: absolute; top: -22px; right: -22px; z-index: 3;
  width: 92px; height: 92px; border-radius: 50%;
  background: var(--surface); box-shadow: var(--shadow-md), inset 0 0 0 1px var(--line);
  display: grid; place-items: center; color: var(--ink);
  animation: spin 26s linear infinite;
}
.cert-badge svg { width: 78px; height: 78px; }
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .cert-badge { animation: none; } .pulse { animation: none; } }
.hero-float {
  position: absolute; left: -18px; bottom: 28px; z-index: 3;
  display: flex; align-items: center; gap: 12px;
  background: var(--surface); padding: 14px 20px 14px 14px; border-radius: var(--r-pill);
  box-shadow: var(--shadow-md), inset 0 0 0 1px var(--line); font-size: 0.92rem;
}
.hero-float b { font-weight: 800; }
.hf-ic { width: 40px; height: 40px; border-radius: 50%; background: var(--accent-tint); color: var(--accent-deep); display: grid; place-items: center; flex: none; }
.hf-ic svg { width: 20px; height: 20px; }

/* ---- Featured solutions ---- */
.sol-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 40px; }
.sol-card { position: relative; padding: 36px; overflow: hidden; }
.sol-top { display: flex; align-items: center; justify-content: space-between; }
.sol-logo { width: 54px; height: 54px; border-radius: 15px; display: grid; place-items: center; background: var(--ink); color: var(--surface); }
.sol-logo.accent { background: var(--accent); }
.sol-logo svg { width: 26px; height: 26px; }
.sol-stripe { position: absolute; left: 0; bottom: 0; width: 100%; height: 5px; background: var(--ink); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; }
.sol-stripe.accent { background: var(--accent); }
.sol-card:hover .sol-stripe { transform: scaleX(1); }

/* ---- Featured products ---- */
.prod-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 40px; }
.prod-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.prod-card { display: flex; flex-direction: column; overflow: hidden; }
.prod-shot { aspect-ratio: 16 / 11; padding: 14px; background: var(--surface-2); }
.prod-shot image-slot { border-radius: 18px; }
.prod-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.prod-meta { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.prod-desc { margin-top: 10px; font-size: 0.95rem; line-height: 1.5; flex: 1; }
.prod-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 22px; }

/* ---- Why ---- */
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 52px; }
.why-card { padding: 4px; }
.why-card .feat-ic { margin-bottom: 22px; }
.why-card .h3 { margin-bottom: 10px; }
.why-card .muted { font-size: 0.95rem; line-height: 1.55; }

/* ---- Testimonials ---- */
.tst-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.tst-card { padding: 32px; display: flex; flex-direction: column; }
.stars { color: var(--accent); letter-spacing: 3px; font-size: 0.95rem; margin-bottom: 18px; }
.tst-card blockquote { font-size: 1.06rem; line-height: 1.5; font-weight: 600; letter-spacing: -0.01em; flex: 1; text-wrap: pretty; }
.tst-author { display: flex; align-items: center; gap: 13px; margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--line); }
.tst-author b { display: block; font-weight: 700; font-size: 0.95rem; }
.tst-author .muted { font-size: 0.85rem; }
.tst-avatar { width: 46px; height: 46px; border-radius: 50%; flex: none; display: grid; place-items: center; background: var(--ink); color: var(--surface); font-weight: 800; font-size: 0.9rem; }

/* ---- About strip ---- */
.about-strip { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(24px, 4vw, 56px); padding: clamp(24px, 3vw, 44px); align-items: center; }
.about-illu { aspect-ratio: 1 / 1; border-radius: 20px; background: var(--surface-2); }

/* ---- Blog ---- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-card { overflow: hidden; }
.blog-cover { aspect-ratio: 16 / 10; padding: 14px; background: var(--surface-2); }
.blog-body { padding: 4px 24px 26px; }
.blog-meta { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; font-size: 0.85rem; }
.blog-card .h3 { margin-bottom: 10px; }
.blog-card .muted { font-size: 0.94rem; line-height: 1.5; }

/* ---- CTA banner ---- */
.cta-banner { position: relative; border-radius: var(--r-xl); background: var(--ink); overflow: hidden; padding: clamp(40px, 6vw, 84px); }
.cta-grid-bg {
  position: absolute; inset: 0; opacity: 0.5;
  background-image: linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(circle at 75% 30%, #000, transparent 72%);
  mask-image: radial-gradient(circle at 75% 30%, #000, transparent 72%);
}
.cta-inner { position: relative; z-index: 2; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 940px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual { max-width: 460px; }
  .sol-grid { grid-template-columns: 1fr; }
  .prod-grid { grid-template-columns: 1fr 1fr; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .tst-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .about-strip { grid-template-columns: 1fr; }
  .about-illu { max-width: 320px; aspect-ratio: 4/3; }
}
@media (max-width: 600px) {
  .prod-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .prod-head { flex-direction: column; align-items: flex-start; gap: 16px; }
  .hero-float { left: 0; }
}
