/* ild-product.css - Shared styles for document product pages */

.product-layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-8);
  align-items: start;
}
@media (max-width: 900px) {
  .product-layout { grid-template-columns: 1fr; }
}

.product-info { max-width: 100%; }

.order-card {
  position: sticky;
  top: calc(var(--nav-height) + var(--space-6));
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-7);
  box-shadow: var(--shadow-lg);
}
@media (max-width: 900px) {
  .order-card { position: static; order: -1; }
}

.order-card__price {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: var(--text-4xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--space-1);
}
.order-card__price-note {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-6);
}
.order-card__features { margin-bottom: var(--space-6); }
.order-card__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.order-card__feature svg {
  width: 18px; height: 18px; color: var(--color-accent); flex-shrink: 0; margin-top: 1px;
}
.order-card__guarantee {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-primary-light);
  border-radius: var(--radius-md);
  margin-top: var(--space-5);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.order-card__guarantee svg {
  width: 20px; height: 20px; color: var(--color-primary); flex-shrink: 0;
}

.includes-list { margin: var(--space-6) 0; }
.includes-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
}
.includes-item:last-child { border-bottom: none; }
.includes-item svg {
  width: 20px; height: 20px; color: var(--color-accent); flex-shrink: 0; margin-top: 2px;
}
.includes-item__text { font-size: var(--text-base); line-height: 1.5; }
.includes-item__text strong { font-weight: 600; color: var(--color-text); }

.q-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  margin: var(--space-6) 0;
}
@media (max-width: 600px) { .q-preview { grid-template-columns: repeat(2, 1fr); } }
.q-preview__step {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.q-preview__num {
  width: 28px; height: 28px; border-radius: var(--radius-full);
  background: var(--color-primary-light);
  display: flex; align-items: center; justify-content: center;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-weight: 700; font-size: var(--text-xs);
  color: var(--color-primary); flex-shrink: 0;
}
.q-preview__label { font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: var(--text-sm); font-weight: 500; }

.trust-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); margin: var(--space-6) 0;
}
@media (max-width: 600px) { .trust-grid { grid-template-columns: 1fr; } }
.trust-item {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-primary-light);
  border-radius: var(--radius-md);
}
.trust-item svg { width: 20px; height: 20px; color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.trust-item__text { font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: var(--text-sm); color: var(--color-text); line-height: 1.5; }

.related-docs { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 768px) { .related-docs { grid-template-columns: 1fr; } }

.social-proof {
  display: flex; align-items: center; gap: var(--space-2);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: var(--text-xs);
  color: var(--color-text-tertiary); margin-top: var(--space-4); justify-content: center;
}
.social-proof__dot {
  width: 6px; height: 6px; border-radius: var(--radius-full);
  background: var(--color-accent); animation: pulse 2s infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

.price-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: var(--text-sm); font-weight: 600;
  color: var(--color-primary); background: var(--color-surface);
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-full);
  margin-top: var(--space-4); border: 1px solid var(--color-border);
}
.price-badge svg { width: 16px; height: 16px; color: var(--color-accent); }

.sample-modal-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  z-index: 9998; align-items: center; justify-content: center; padding: var(--space-6);
}
.sample-modal-overlay.open { display: flex; }
.sample-modal {
  background: var(--color-surface); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl);
  max-width: 600px; width: 100%; max-height: 80vh; overflow-y: auto;
  padding: var(--space-8); position: relative; animation: modalIn 0.3s ease-out;
}
@keyframes modalIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.sample-modal__close {
  position: absolute; top: var(--space-4); right: var(--space-4);
  width: 36px; height: 36px; border-radius: var(--radius-full);
  background: var(--color-background); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.sample-modal__close:hover { background: var(--color-border); }
