/* ========================================
   Developers Page Styles
   ======================================== */

.developers-page {
  max-width: 1200px;
  margin: 0 auto;
}

/* Tab Navigation */
.dev-tabs {
  display: flex;
  gap: 0.25rem;
  border-bottom: 1px solid hsl(var(--border));
  margin-bottom: 2rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.check-icon{
  background-color: transparent;
}

/* Fix copy button layout shift */
.code-block-container .copy-btn {
  min-width: 95px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.code-block-container .copy-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.code-block-container .copy-btn .check-icon {
  display: none;
}

.code-block-container .copy-btn.copied .copy-icon {
  display: none;
}

.code-block-container .copy-btn.copied .check-icon {
  display: block;
  color: hsl(142, 70%, 50%);
}

.dev-tab {
  padding: 0.875rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--muted-foreground));
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.dev-tab:hover {
  color: hsl(var(--foreground));
}

.dev-tab.active {
  color: hsl(var(--foreground));
  border-bottom-color: hsl(var(--foreground));
}

/* Tab Content */
.dev-tab-content {
  display: none;
}

.dev-tab-content.active {
  display: block;
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Overview Grid */
.dev-overview-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

@media (max-width: 900px) {
  .dev-overview-grid {
    grid-template-columns: 1fr;
  }
}

/* Quickstart Card */
.dev-quickstart-card {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 1rem;
  padding: 2rem;
  display: flex;
  flex-direction: column;
}

.quickstart-icon {
  width: 56px;
  height: 56px;
  border-radius: 0.75rem;
  background: hsl(var(--secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  color: hsl(var(--foreground));
  margin-bottom: 1.25rem;
}

.dev-quickstart-card h3 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: hsl(var(--foreground));
}

.dev-quickstart-card p {
  font-size: 0.9375rem;
  color: hsl(var(--muted-foreground));
  line-height: 1.6;
  margin-bottom: 1.5rem;
  flex: 1;
}

.quickstart-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: hsl(var(--foreground));
  color: hsl(var(--background));
  border: none;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
  width: fit-content;
}

.quickstart-btn:hover {
  opacity: 0.9;
  transform: translateX(2px);
}

/* Quick Links */
.dev-quick-links {
  margin-bottom: 2rem;
}

.dev-quick-links h3 {
  font-size: 1rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 1rem;
}

.quick-links-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
}

@media (max-width: 900px) {
  .quick-links-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 500px) {
  .quick-links-grid {
    grid-template-columns: 1fr;
  }
}

.quick-link-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 0.75rem;
  color: hsl(var(--foreground));
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s ease;
}

.quick-link-card:hover {
  background: hsl(var(--secondary));
  border-color: hsl(var(--foreground) / 0.1);
  transform: translateY(-2px);
}

.quick-link-card svg {
  flex-shrink: 0;
  color: hsl(var(--muted-foreground));
}

/* ========================================
   Models Tab
   ======================================== */

.models-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-bottom: 2rem;
}

@media (max-width: 768px) {
  .models-grid {
    grid-template-columns: 1fr;
  }
}

.model-card {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 1rem;
  padding: 1.5rem;
}

.model-card-featured {
  border-color: hsl(var(--foreground) / 0.2);
  background: linear-gradient(135deg, hsl(var(--card)) 0%, hsl(var(--secondary) / 0.5) 100%);
}

.model-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.model-badge {
  padding: 0.25rem 0.625rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.model-badge-base {
  background: hsl(200 70% 50% / 0.15);
  color: hsl(200 70% 50%);
}

.model-badge-advanced {
  background: hsl(270 70% 60% / 0.15);
  color: hsl(270 70% 60%);
}

.model-rate {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--muted-foreground));
}

.model-card h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 0.5rem;
}

.model-description {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  line-height: 1.6;
  margin-bottom: 1.25rem;
}

.model-specs {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid hsl(var(--border));
}

.model-spec {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.spec-label {
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
}

.spec-value {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--foreground));
}

.model-features {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.feature-tag {
  padding: 0.25rem 0.625rem;
  background: hsl(var(--secondary));
  border-radius: 0.375rem;
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--muted-foreground));
}

/* Model Comparison Table */
.model-comparison {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 1rem;
  padding: 1.5rem;
}

.model-comparison h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: hsl(var(--foreground));
}

.comparison-table-wrapper {
  overflow-x: auto;
}

.comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.comparison-table th,
.comparison-table td {
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid hsl(var(--border));
}

.comparison-table th {
  font-weight: 600;
  color: hsl(var(--foreground));
  background: hsl(var(--secondary) / 0.5);
}

.comparison-table td {
  color: hsl(var(--muted-foreground));
}

.comparison-table tr:last-child td {
  border-bottom: none;
}

/* ========================================
   Pricing Tab
   ======================================== */

.pricing-overview h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 0.25rem;
}

.pricing-subtitle {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin-bottom: 1.5rem;
}

.pricing-table-wrapper {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 2rem;
}

.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.pricing-table th,
.pricing-table td {
  padding: 1rem 1.25rem;
  text-align: left;
  border-bottom: 1px solid hsl(var(--border));
}

.pricing-table th {
  font-weight: 600;
  color: hsl(var(--foreground));
  background: hsl(var(--secondary) / 0.5);
}

.pricing-table td {
  color: hsl(var(--muted-foreground));
}

.pricing-table tr:last-child td {
  border-bottom: none;
}

.pricing-row-featured td {
  background: hsl(var(--foreground) / 0.03);
}

.plan-name {
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-right: 0.5rem;
}

.plan-tag {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
}

.plan-tag-free {
  background: hsl(142 70% 50% / 0.15);
  color: hsl(142 70% 45%);
}

.plan-tag-popular {
  background: hsl(var(--foreground));
  color: hsl(var(--background));
}

/* Pricing Calculator */
.pricing-calculator {
  margin-bottom: 2rem;
}

.pricing-calculator h4 {
  font-size: 1rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 1rem;
}

.calc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

@media (max-width: 640px) {
  .calc-grid {
    grid-template-columns: 1fr;
  }
}

.calc-card {
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: 0.75rem;
  padding: 1.25rem;
  text-align: center;
}

.calc-card-featured {
  border-color: hsl(var(--foreground) / 0.2);
  background: linear-gradient(135deg, hsl(var(--card)) 0%, hsl(var(--secondary) / 0.5) 100%);
}

.calc-plan {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 1rem;
}

.calc-minutes {
  margin-bottom: 0.25rem;
}

.calc-value {
  font-size: 1.75rem;
  font-weight: 700;
  color: hsl(var(--foreground));
}

.calc-unit {
  font-size: 0.8125rem;
  color: hsl(var(--muted-foreground));
  margin-left: 0.25rem;
}

.calc-or {
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
  margin: 0.5rem 0;
}

/* Pricing Notes */
.pricing-notes {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

@media (max-width: 640px) {
  .pricing-notes {
    grid-template-columns: 1fr;
  }
}

.note-card {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  background: hsl(var(--secondary) / 0.5);
  border-radius: 0.75rem;
}

.note-card svg {
  flex-shrink: 0;
  color: hsl(var(--muted-foreground));
  margin-top: 0.125rem;
}

.note-card h5 {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  margin-bottom: 0.25rem;
}

.note-card p {
  font-size: 0.8125rem;
  color: hsl(var(--muted-foreground));
  line-height: 1.5;
}

/* ========================================
   Mobile Responsive Styles
   ======================================== */

@media (max-width: 768px) {
  /* Hide elements on mobile */
  .hide-mobile {
    display: none !important;
  }

  /* Force developers page to fit viewport */
  .developers-page {
    padding: 0;
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: calc(100vw - 3rem) !important; /* Account for dashboard-content padding */
    box-sizing: border-box;
  }

  /* Force tab content to fit */
  .dev-tab-content {
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  /* Force models grid to fit */
  .models-grid {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  /* Force all cards and containers to fit */
  .model-card,
  .model-comparison,
  .pricing-table-wrapper,
  .pricing-overview,
  .dev-quickstart-card,
  .code-block-container,
  .dev-quick-links,
  .quick-links-grid {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    overflow: hidden;
  }

  /* Tabs - make them scrollable with smaller text */
  .dev-tabs {
    gap: 0;
    margin-bottom: 1.25rem;
    padding-bottom: 0;
  }

  .dev-tab {
    padding: 0.625rem 0.875rem;
    font-size: 0.8rem;
  }

  /* Overview grid - single column */
  .dev-overview-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-bottom: 1.5rem;
  }

  /* Quickstart card - smaller on mobile */
  .dev-quickstart-card {
    padding: 1.25rem;
  }

  .quickstart-icon {
    width: 44px;
    height: 44px;
    margin-bottom: 1rem;
  }

  .quickstart-icon svg {
    width: 20px;
    height: 20px;
  }

  .dev-quickstart-card h3 {
    font-size: 1.1rem;
  }

  .dev-quickstart-card p {
    font-size: 0.85rem;
    margin-bottom: 1rem;
  }

  .quickstart-btn {
    padding: 0.625rem 1rem;
    font-size: 0.8rem;
  }

  /* Code block - make scrollable and smaller */
  .code-block-container {
    overflow: hidden;
  }

  .code-block {
    font-size: 0.75rem;
  }

  .code-header {
    padding: 0.625rem 0.75rem;
  }

  .code-tabs {
    padding: 0.5rem 0.75rem;
  }

  .code-tab {
    padding: 0.375rem 0.625rem;
    font-size: 0.7rem;
  }

  .code-install {
    padding: 0.5rem 0.75rem;
  }

  .code-content {
    padding: 0.75rem;
    font-size: 0.7rem;
    overflow-x: auto;
  }

  .copy-btn {
    min-width: auto;
    padding: 0.375rem 0.5rem;
    font-size: 0.7rem;
  }

  .copy-btn .copy-text {
    display: none;
  }

  /* Quick Links - smaller cards */
  .dev-quick-links {
    margin-bottom: 1.5rem;
  }

  .dev-quick-links h3 {
    font-size: 0.9rem;
  }

  .quick-link-card {
    padding: 0.75rem 1rem;
    font-size: 0.8rem;
  }

  .quick-link-card svg {
    width: 18px;
    height: 18px;
  }

  /* Models Tab */
  .models-grid {
    gap: 1rem;
  }

  .model-card {
    padding: 1rem;
  }

  .model-card h3 {
    font-size: 1rem;
  }

  .model-description {
    font-size: 0.8rem;
    margin-bottom: 1rem;
  }

  .model-specs {
    gap: 0.5rem;
    flex-wrap: wrap;
  }

  .model-spec {
    min-width: 45%;
  }

  .spec-label {
    font-size: 0.7rem;
  }

  .spec-value {
    font-size: 0.8rem;
  }

  .feature-tag {
    font-size: 0.7rem;
    padding: 0.2rem 0.5rem;
  }

  /* Model Comparison Table */
  .model-comparison {
    padding: 1rem;
    overflow: hidden;
  }

  .model-comparison h3 {
    font-size: 0.9rem;
  }

  .comparison-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .comparison-table {
    font-size: 0.7rem;
    width: 100%;
  }

  .comparison-table th,
  .comparison-table td {
    padding: 0.5rem 0.625rem;
    white-space: nowrap;
  }

  /* Pricing Tab */
  .pricing-overview {
    overflow: hidden;
  }

  .pricing-overview h3 {
    font-size: 1.1rem;
  }

  .pricing-subtitle {
    font-size: 0.8rem;
  }

  .pricing-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .pricing-table {
    font-size: 0.65rem;
    width: 100%;
  }

  .pricing-table th,
  .pricing-table td {
    padding: 0.5rem 0.5rem;
    white-space: nowrap;
  }

  .plan-name {
    font-size: 0.75rem;
  }

  .plan-tag {
    font-size: 0.6rem;
    padding: 0.1rem 0.35rem;
  }

  .pricing-notes {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .note-card {
    padding: 0.75rem;
    gap: 0.75rem;
  }

  .note-card svg {
    width: 18px;
    height: 18px;
  }

  .note-card h5 {
    font-size: 0.8rem;
  }

  .note-card p {
    font-size: 0.75rem;
  }
}

/* Extra small screens */
@media (max-width: 480px) {
  .dev-tab {
    padding: 0.5rem 0.625rem;
    font-size: 0.75rem;
  }

  .dev-quickstart-card {
    padding: 1rem;
  }

  .quickstart-icon {
    width: 40px;
    height: 40px;
  }

  .dev-quickstart-card h3 {
    font-size: 1rem;
  }

  .quick-link-card {
    padding: 0.625rem 0.75rem;
    font-size: 0.75rem;
  }

  .quick-link-card svg {
    width: 16px;
    height: 16px;
  }
}
