/* Styles for telefonie-voip page */

/* ============================================================
   PAGE: telefonie-voip.css
   Stiluri specifice /telefonie-voip/
   Variabile din tokens.css
   ============================================================ */

/* ── Reading Progress Bar ────────────────────────────────────── */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: var(--color-accent);
  z-index: calc(var(--z-header) + 1);
  transition: width 0.1s linear;
  pointer-events: none;
}

/* ── Sticky CTA Bar ─────────────────────────────────────────── */
.sticky-cta {
  position: fixed;
  bottom: -80px;
  left: 0;
  right: 0;
  z-index: var(--z-overlay);
  background: var(--color-primary);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  padding: var(--space-3) var(--space-6);
  box-shadow: 0 -4px 20px rgba(0,0,0,0.2);
  transition: bottom var(--transition-base);
  font-size: var(--fs-sm);
}
.sticky-cta.is-visible { bottom: 0; }
.sticky-cta span { color: rgba(255,255,255,0.85); }
@media (max-width: 768px) {
  .sticky-cta { flex-direction: column; gap: var(--space-2); padding: var(--space-3); }
  .sticky-cta span { font-size: var(--fs-xs); text-align: center; }
}

/* ── Breadcrumb ─────────────────────────────────────────────── */
.breadcrumb {
  padding: var(--space-4) 0;
  font-size: var(--fs-sm);
  color: var(--color-gray-500);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.breadcrumb a { color: var(--color-gray-500); transition: color var(--transition-fast); }
.breadcrumb a:hover { color: var(--color-primary-light); }
.breadcrumb span { color: var(--color-gray-300); }

/* ── Hero inline link ───────────────────────────────────────── */
.hero-inline-link {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: var(--fw-medium);
}
.hero-inline-link:hover { color: var(--color-accent-dark); }

/* ── VoIP Flow Visual (hero) ────────────────────────────────── */
.voip-flow-visual {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  justify-content: center;
}
.voip-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.7);
}
.voip-node__icon {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  fill: white;
}
.voip-node--server .voip-node__icon {
  background: rgba(0,200,150,0.2);
  border-color: var(--color-accent);
}
.voip-flow-line {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  position: relative;
  width: 80px;
}
.voip-flow-label {
  font-size: 9px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
/* Pachete animate */
.voip-packet {
  width: 8px;
  height: 8px;
  background: var(--color-accent);
  border-radius: 50%;
  position: absolute;
  top: 20px;
  animation: packet-flow 2s ease-in-out infinite;
  opacity: 0;
}
.voip-packet--1 { animation-delay: 0s; }
.voip-packet--2 { animation-delay: 0.4s; }
.voip-packet--3 { animation-delay: 0.8s; }
.voip-packet--4 { animation-delay: 0.2s; }
.voip-packet--5 { animation-delay: 0.6s; }
.voip-packet--6 { animation-delay: 1s; }
@keyframes packet-flow {
  0%   { opacity: 0; transform: translateX(-20px); }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { opacity: 0; transform: translateX(20px); }
}
.voip-flow-stat {
  margin-top: var(--space-6);
  text-align: center;
  background: rgba(255,255,255,0.08);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-6);
  border: 1px solid rgba(255,255,255,0.12);
}
.voip-flow-stat__num {
  display: block;
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  color: var(--color-accent);
  font-family: var(--font-display);
}
.voip-flow-stat__label {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.55);
  margin-top: var(--space-1);
  display: block;
}

/* ── Table of Contents ──────────────────────────────────────── */
.toc-wrapper {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.toc-label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-700);
  white-space: nowrap;
  margin: 0;
}
.toc-nav {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.toc-link {
  font-size: var(--fs-sm);
  color: var(--color-primary-light);
  font-weight: var(--fw-medium);
  transition: color var(--transition-fast);
  white-space: nowrap;
}
.toc-link:hover { color: var(--color-primary); text-decoration: underline; }
.toc-sep { color: var(--color-gray-300); }

/* ── VoIP Definition section ────────────────────────────────── */
.voip-definition {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-12);
  align-items: flex-start;
}
@media (max-width: 992px) {
  .voip-definition { grid-template-columns: 1fr; }
}
.voip-definition__text h2 { margin-bottom: var(--space-6); }
.voip-definition__text p {
  margin-bottom: var(--space-4);
  color: var(--color-gray-600);
  line-height: var(--lh-relaxed);
}
.voip-def-box {
  background: rgba(37,99,235,0.05);
  border-left: 4px solid var(--color-primary-light);
  padding: var(--space-5) var(--space-6);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  margin-bottom: var(--space-6);
}
.voip-def-box p { margin: 0; font-size: var(--fs-lg); color: var(--color-gray-700); }
.voip-def-box strong { color: var(--color-gray-900); }

/* Stat highlights sidebar */
.voip-stat-highlight {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}
.stat-big {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.stat-big--accent {
  background: rgba(0,200,150,0.05);
  border-color: var(--color-accent);
}
.stat-big__num {
  display: block;
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  color: var(--color-primary);
  font-family: var(--font-display);
  line-height: 1;
  margin-bottom: var(--space-3);
}
.stat-big--accent .stat-big__num { color: var(--color-accent); }
.stat-big__text { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); }

/* Text links inline */
.text-link {
  color: var(--color-primary-light);
  font-weight: var(--fw-medium);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}
.text-link:hover { color: var(--color-primary); }

/* ── Inline CTA Banner ──────────────────────────────────────── */
.inline-cta-banner {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  padding: var(--space-5) 0;
}
.inline-cta-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.inline-cta-banner__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.inline-cta-banner__text strong {
  color: var(--color-white);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
}
.inline-cta-banner__text span {
  color: rgba(255,255,255,0.75);
  font-size: var(--fs-sm);
}
@media (max-width: 768px) {
  .inline-cta-banner__inner { flex-direction: column; text-align: center; }
}

/* ── HowTo Steps ────────────────────────────────────────────── */
.howto-steps {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.howto-step {
  display: grid;
  grid-template-columns: 48px 64px 1fr;
  gap: var(--space-5);
  align-items: flex-start;
  width: 100%;
  padding: var(--space-6) 0;
}
.howto-step__num {
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--color-accent);
  padding-top: var(--space-4);
  text-align: right;
}
.howto-step__icon {
  width: 64px;
  height: 64px;
  background: var(--color-white);
  border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  fill: var(--color-primary);
  box-shadow: var(--shadow-sm);
  flex-shrink: 0;
}
.howto-step__content h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-2);
}
.howto-step__content p { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); margin: 0; }
.howto-step__content strong { color: var(--color-gray-800); }
.howto-connector {
  font-size: var(--fs-2xl);
  color: var(--color-gray-300);
  text-align: center;
  line-height: 1;
  padding-left: 88px;
  width: 100%;
}
.voip-fact-box {
  max-width: 720px;
  margin: var(--space-8) auto 0;
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.voip-fact-box--inline { margin-top: var(--space-6); max-width: 100%; }
.voip-fact-box__text { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); margin: 0; }
.voip-fact-box strong { color: var(--color-gray-900); }

@media (max-width: 768px) {
  .howto-step { grid-template-columns: 32px 1fr; }
  .howto-step__icon { display: none; }
  .howto-connector { padding-left: 40px; }
}

/* ── Compare Tabs ───────────────────────────────────────────── */
.compare-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-6);
  border-bottom: 2px solid var(--color-gray-200);
  padding-bottom: 0;
}
.compare-tab {
  padding: var(--space-3) var(--space-5);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-gray-500);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}
.compare-tab:hover { color: var(--color-primary); }
.compare-tab.is-active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
  font-weight: var(--fw-semibold);
}
.compare-panel { display: none; }
.compare-panel.is-active { display: block; }
.compare-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-4);
}
@media (max-width: 768px) {
  .compare-two-col { grid-template-columns: 1fr; }
}
.compare-col {
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}
.compare-col h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-4);
}
.compare-col ul { display: flex; flex-direction: column; gap: var(--space-3); }
.compare-col li {
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  padding-left: var(--space-5);
  position: relative;
  color: var(--color-gray-600);
}
.compare-col li::before {
  content: '·';
  position: absolute;
  left: 0;
  font-weight: var(--fw-bold);
}
.compare-col--bad { background: #fef2f2; }
.compare-col--bad h3 { color: #991b1b; }
.compare-col--bad li::before { color: var(--color-error); }
.compare-col--good { background: #f0fdf4; }
.compare-col--good h3 { color: #166534; }
.compare-col--good li::before { color: var(--color-accent); }
.compare-col--good li { color: #166534; }
.compare-col--good strong { color: #14532d; }
.compare-col--neutral { background: var(--color-gray-50); }
.compare-col--neutral h3 { color: var(--color-gray-700); }
.compare-panel__note {
  font-size: var(--fs-sm);
  color: var(--color-gray-500);
  padding: var(--space-3) var(--space-4);
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  margin-top: var(--space-2);
}

/* ── VoIP Benefits Grid ─────────────────────────────────────── */
.voip-benefits-grid { gap: var(--space-6); }
.voip-benefit-card {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.voip-benefit-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
.voip-benefit-card__icon {
  width: 52px;
  height: 52px;
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  fill: var(--color-primary);
}
.voip-benefit-card h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
}
.voip-benefit-card p {
  font-size: var(--fs-sm);
  color: var(--color-gray-600);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* ── Requirements Grid ──────────────────────────────────────── */
.req-grid { gap: var(--space-6); }
.req-card {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.req-card--required { border-top: 3px solid var(--color-primary); }
.req-card--optional { border-top: 3px solid var(--color-gray-300); }
.req-card__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-primary);
}
.req-card__label--opt { color: var(--color-gray-400); }
.req-card h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
}
.req-card p { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); margin: 0; }
.req-card__example {
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--fs-xs);
  color: var(--color-gray-500);
  margin-top: var(--space-2);
}
.req-card__example span { font-weight: var(--fw-semibold); color: var(--color-gray-700); }

/* Highlight box */
.voip-highlight-box {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  margin-top: var(--space-10);
}
.voip-highlight-box__icon { font-size: 2rem; flex-shrink: 0; }
.voip-highlight-box__content h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-2);
}
.voip-highlight-box__content p { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); margin: 0; }
.voip-highlight-box__content strong { color: var(--color-gray-900); }

/* ── Choose List ────────────────────────────────────────────── */
.choose-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.choose-item {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--space-6);
  padding: var(--space-8) 0;
  border-bottom: 1px solid var(--color-gray-200);
  align-items: flex-start;
}
.choose-item:last-child { border-bottom: none; }
.choose-item__num {
  width: 48px;
  height: 48px;
  background: var(--color-primary);
  color: white;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  flex-shrink: 0;
}
.choose-item__content h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-3);
}
.choose-item__content p { font-size: var(--fs-sm); color: var(--color-gray-600); line-height: var(--lh-relaxed); margin: 0; }
.choose-item__content strong { color: var(--color-gray-900); }

/* ── Related Pages Widget ───────────────────────────────────── */
.related-label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-4);
}
.related-pages { gap: var(--space-4); }
.related-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  transition: box-shadow var(--transition-base), border-color var(--transition-fast);
  text-decoration: none;
}
.related-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-light);
}
.related-card--accent {
  border-color: var(--color-accent);
  background: rgba(0,200,150,0.03);
}
.related-card--accent:hover { border-color: var(--color-accent-dark); }
.related-card__icon {
  width: 44px;
  height: 44px;
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  fill: var(--color-primary);
  flex-shrink: 0;
}
.related-card--accent .related-card__icon { background: rgba(0,200,150,0.1); fill: var(--color-accent); }
.related-card__content { flex: 1; }
.related-card__content h3 {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-1);
}
.related-card__content p { font-size: var(--fs-xs); color: var(--color-gray-500); line-height: var(--lh-normal); margin: 0; }
.related-card__arrow { color: var(--color-gray-400); font-size: var(--fs-lg); flex-shrink: 0; }

/* ── CTA Dark ───────────────────────────────────────────────── */
.cta-dark { background: linear-gradient(145deg, #0f172a 0%, #1e3a5f 60%, #1a365d 100%); }
.cta-dark-inner { text-align: center; max-width: 600px; margin: 0 auto; }
.cta-dark-inner h2 { color: var(--color-white); margin-bottom: var(--space-4); }
.cta-dark-inner > p { color: rgba(255,255,255,0.75); font-size: var(--fs-lg); margin-bottom: var(--space-8); }
.cta-dark-actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; margin-bottom: var(--space-6); }
.cta-dark-note { font-size: var(--fs-sm); color: rgba(255,255,255,0.5); }
.cta-dark-note a { color: rgba(255,255,255,0.8); transition: color var(--transition-fast); }
.cta-dark-note a:hover { color: var(--color-white); }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 992px) {
  .voip-stat-highlight { position: static; flex-direction: row; }
  .stat-big { flex: 1; }
}
@media (max-width: 768px) {
  .voip-stat-highlight { flex-direction: column; }
  .toc-wrapper { flex-direction: column; align-items: flex-start; }
  .choose-item { grid-template-columns: 40px 1fr; gap: var(--space-4); }
  .choose-item__num { width: 40px; height: 40px; font-size: var(--fs-xs); }
  .voip-highlight-box { flex-direction: column; }
  .voip-flow-visual { gap: var(--space-2); }
  .voip-node__icon { width: 44px; height: 44px; }
  .voip-flow-line { width: 40px; }
  .related-pages { grid-template-columns: 1fr; }
  .compare-tabs { gap: var(--space-1); }
  .compare-tab { padding: var(--space-2) var(--space-3); font-size: var(--fs-xs); }
}

