/* =========================================================
   CIAO ADMIN — PAGE-SPECIFIC STYLES
   ========================================================= */

/* Homepage hero illustration */
.hero-illustration {
  background: linear-gradient(135deg, #0066CC 0%, #003F7D 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  aspect-ratio: 4/3;
  position: relative;
  overflow: hidden;
  box-shadow: var(--elev-4);
  display: grid;
  place-items: center;
}
.hero-illustration::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 30%, rgba(255,255,255,0.18) 0%, transparent 50%);
  pointer-events: none;
}
.hero-mockup {
  background: white;
  border-radius: var(--radius-md);
  box-shadow: 0 30px 80px rgba(0,0,0,0.35);
  padding: var(--space-5);
  width: 78%;
  position: relative;
  z-index: 2;
  color: var(--on-surface);
  text-align: left;
}
.hero-mockup__bar {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
}
.hero-mockup__bar span {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--border-strong);
}
.hero-mockup__doc {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-4);
  background: var(--bg-alt);
}
.hero-mockup__doc h5 { margin: 0 0 var(--space-1); font-size: 0.85rem; }
.hero-mockup__doc small { color: var(--on-surface-muted); font-size: 0.7rem; }
.hero-mockup__chips { display: flex; gap: var(--space-2); margin-top: var(--space-3); flex-wrap: wrap; }
.hero-mockup__chip {
  padding: 2px 8px;
  background: var(--primary-container);
  color: var(--primary);
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  font-weight: 600;
}

/* Pain stats */
.pain-stat {
  text-align: center;
  padding: var(--space-8) var(--space-5);
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.pain-stat__number {
  font-size: clamp(3rem, 5vw, 4.5rem);
  font-weight: 800;
  color: var(--color-danger-500);
  line-height: 1;
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
  margin-bottom: var(--space-3);
}
.pain-stat__label {
  font-size: 1rem;
  color: var(--on-surface-secondary);
  line-height: 1.4;
}

/* Solution steps (large) */
.solution-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}
@media (max-width: 900px) { .solution-grid { grid-template-columns: 1fr; } }
.solution-card {
  text-align: center;
  padding: var(--space-8);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  position: relative;
}
.solution-card__emoji {
  font-size: 3rem;
  margin-bottom: var(--space-4);
}
.solution-card__title {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: var(--space-3);
  color: var(--on-surface);
}
.solution-card__desc {
  color: var(--on-surface-secondary);
  line-height: 1.55;
  margin: 0;
}

/* Demo video block */
.demo-block {
  background: var(--bg-alt);
  border-radius: var(--radius-xl);
  padding: var(--space-12);
  text-align: center;
}
.demo-video {
  margin: 0 auto;
  max-width: 920px;
  aspect-ratio: 16/9;
  background: var(--color-neutral-950);
  color: white;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  position: relative;
  cursor: pointer;
  overflow: hidden;
  box-shadow: var(--elev-4);
}
.demo-video::after {
  content: '▶';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  background: rgba(0,0,0,0.4);
  color: rgba(255,255,255,0.9);
  transition: background 200ms;
}
.demo-video:hover::after { background: rgba(0,0,0,0.55); }

/* Personas grid */
.persona-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
@media (max-width: 1023px) { .persona-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .persona-grid { grid-template-columns: 1fr; } }

/* Features grid */
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .features-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .features-grid { grid-template-columns: 1fr; } }

/* Pricing grid */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4);
  align-items: stretch;
}
@media (max-width: 1280px) { .pricing-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px)  { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pricing-grid { grid-template-columns: 1fr; } }

/* Pricing teaser */
.pricing-teaser-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .pricing-teaser-grid { grid-template-columns: 1fr; } }

/* Use cases (split list) */
.usecase-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}
@media (max-width: 768px) { .usecase-grid { grid-template-columns: 1fr; } }
.usecase-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.usecase-card__icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  background: var(--primary-container);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}

/* Comparator hero */
.comparator-hero { background: var(--bg-alt); padding: var(--space-16) 0; text-align: center; }
.versus-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-pill);
  font-weight: 700;
  margin-bottom: var(--space-5);
}

/* Security cards */
.security-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .security-grid { grid-template-columns: 1fr; } }

/* Multilang prose adaptations */
:lang(de) .article-prose p { hyphens: auto; }

/* Two-col with aside */
.two-col {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-12);
  align-items: start;
}
@media (max-width: 1023px) { .two-col { grid-template-columns: 1fr; } }

/* Garantie cards */
.guarantee-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 768px) { .guarantee-grid { grid-template-columns: 1fr; } }
.guarantee-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
}
.guarantee-card__icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-pill);
  background: var(--color-success-50);
  color: var(--color-success-500);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  margin: 0 auto var(--space-4);
}

/* Form */
.form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 560px;
}
.form label {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--on-surface);
}
.form input, .form textarea, .form select {
  height: 44px;
  padding: 0 var(--space-3);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 0.95rem;
  color: var(--on-surface);
  font-weight: 400;
}
.form textarea { min-height: 140px; padding: var(--space-3); resize: vertical; }
.form input:focus, .form textarea:focus, .form select:focus {
  outline: 2px solid var(--primary);
  outline-offset: 1px;
  border-color: var(--primary);
}

/* Logo cloud */
.logo-cloud {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  opacity: 0.7;
}
.logo-cloud img, .logo-cloud .logo-name {
  height: 32px;
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--on-surface-muted);
}

/* Process / timeline */
.process-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  position: relative;
}
@media (max-width: 900px) { .process-row { grid-template-columns: 1fr; } }
.process-step {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  position: relative;
}
.process-step__num {
  display: inline-flex;
  width: 32px; height: 32px;
  background: var(--primary-container);
  color: var(--primary);
  border-radius: var(--radius-pill);
  align-items: center;
  justify-content: center;
  font-weight: 700;
  margin-bottom: var(--space-3);
}

/* Article TOC list */
.toc-list { display: flex; flex-direction: column; gap: var(--space-2); }
.toc-list a { display: block; padding: var(--space-1) 0; }

/* Multi-lang switcher inline */
.lang-quick {
  display: inline-flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
  font-size: 0.85rem;
  color: var(--on-surface-muted);
}
.lang-quick a { font-weight: 600; }

/* Tag chip */
.tag-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--space-2);
  background: var(--primary-container);
  color: var(--primary);
  border-radius: var(--radius-xs);
  font-size: 0.75rem;
  font-weight: 600;
}

/* Blog index card */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 900px) { .blog-grid { grid-template-columns: 1fr; } }
.blog-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.blog-card__cover {
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--primary-container) 0%, var(--bg-alt) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}
.blog-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); flex-grow: 1; }
.blog-card h3 { font-size: 1.15rem; margin: 0; }
.blog-card .blog-meta { font-size: 0.8rem; color: var(--on-surface-muted); }
