/* Public-facing pages layout (legal, future website pages) */

.public-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.public-page main {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.public-page main > .section {
  flex: 1;
}

.public-page main > .section-centered {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 4rem;
}

.public-page .section-centered .box {
  background: var(--bulma-scheme-main-bis);
}

.public-page .table {
  background: var(--bulma-scheme-main-bis);
}

.public-page .section {
  --bulma-section-padding: 2rem 0.75rem;
  --bulma-section-padding-desktop: 2rem;
}

/* Dark mode: same layered scheme as tools pages
   Layer 1 (navbar):  #1f2937
   Layer 2 (body):    #1a1a2e
   Surfaces (boxes):  #1f2937 */

[data-theme="dark"] .public-page {
  background: #1a1a2e;
}

[data-theme="dark"] .public-page .navbar {
  background: #1f2937;
  border-bottom: 1px solid #374151;
}

[data-theme="dark"] .public-page .navbar .logo .logo-networks {
  fill: #ffffff;
  stroke: none;
}

[data-theme="dark"] .public-page .title,
[data-theme="dark"] .public-page .subtitle {
  color: rgba(255, 255, 255, 0.9);
}

[data-theme="dark"] .public-page .subtitle {
  color: rgba(255, 255, 255, 0.6);
}

[data-theme="dark"] .public-page .box {
  background: #1f2937;
  border: 1px solid #374151;
}

[data-theme="dark"] .public-page .table {
  background: #1f2937;
}

[data-theme="dark"] .public-page .table th {
  color: rgba(255, 255, 255, 0.9);
  border-color: #374151;
}

[data-theme="dark"] .public-page .table td {
  border-color: #374151;
}

/* Footer -- light mode */
.public-footer {
  background: var(--bulma-scheme-main-bis);
  border-top: 1px solid var(--bulma-border);
  color: var(--bulma-text-weak);
  padding: var(--arp-space-12) var(--arp-space-6) var(--arp-space-8);
}

.public-footer h2 {
  color: var(--bulma-text-strong);
  font-weight: 600;
  margin-bottom: var(--arp-space-3);
}

.public-footer ul {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}

.public-footer ul li {
  margin-bottom: var(--arp-space-2);
}

.public-footer a {
  color: var(--bulma-text);
  transition: color 0.15s;
}

.public-footer a:hover {
  color: var(--arp-accent);
}

.public-footer .social-buttons .button {
  background: transparent;
  border: 1px solid var(--bulma-border);
  color: var(--bulma-text);
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.public-footer .social-buttons .button:hover {
  background: var(--bulma-scheme-main-ter);
  color: var(--bulma-text-strong);
  border-color: var(--bulma-text);
}

.public-footer hr {
  height: 1px;
  margin: var(--arp-space-6) 0;
  border: none;
  background: var(--arp-border-strong);
}

.public-footer .copyright {
  color: var(--bulma-text-weak);
  text-align: center;
}

/* Footer -- dark mode overrides */
[data-theme="dark"] .public-footer {
  background: #1f2937;
  border-top-color: #374151;
}

[data-theme="dark"] .public-footer h2 {
  color: #ffffff;
}

[data-theme="dark"] .public-footer a {
  color: rgba(255, 255, 255, 0.6);
}

[data-theme="dark"] .public-footer a:hover {
  color: #ff9500;
}

[data-theme="dark"] .public-footer .social-buttons .button {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.6);
}

[data-theme="dark"] .public-footer .social-buttons .button:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #ffffff;
}

[data-theme="dark"] .public-footer .copyright {
  color: rgba(255, 255, 255, 0.4);
}

@media screen and (max-width: 768px) {
  .public-footer .social-buttons {
    justify-content: flex-start;
  }
}

/* Public article header banner */
.public-article-header {
  background: linear-gradient(135deg, #2c5282, #4a6fa5);
  padding: var(--arp-space-8) var(--arp-space-8);
  text-align: center;
  margin-bottom: var(--arp-space-8);
  border-radius: var(--bulma-radius-large);
}

.public-article-header .title {
  color: #ffffff;
  margin-bottom: var(--arp-space-3);
}

.public-article-header .subtitle {
  color: rgba(255, 255, 255, 0.85);
}

[data-theme="dark"] .public-article-header {
  background: linear-gradient(135deg, #0f1f33, #1a3a5c);
}

@media screen and (max-width: 768px) {
  .public-article-header .title {
    font-size: var(--bulma-size-3);
  }

  .public-article-header .subtitle {
    font-size: var(--bulma-size-6);
  }
}

/* Public article pages (informational / marketing content) */
.public-article .content h2.title {
  display: flex;
  align-items: center;
  gap: var(--arp-space-3);
  margin-top: var(--arp-space-8);
  margin-bottom: var(--arp-space-4);
  padding-top: var(--arp-space-6);
  border-top: 1px solid var(--bulma-border);
}

.public-article .content h2.title .icon {
  color: #4a6fa5;
}

[data-theme="dark"] .public-article .content h2.title .icon {
  color: #4a6fa5;
}

.public-article .content h3.title {
  margin-top: var(--arp-space-6);
  margin-bottom: var(--arp-space-3);
}

.public-article .content a:hover {
  color: #1d4ed8;
}

[data-theme="dark"] .public-article .content a:hover {
  color: #9d6fff;
}

.public-article .content pre {
  background-color: #f6f8fa;
  border-left: 3px solid #d0d7de;
  padding: var(--arp-space-3) var(--arp-space-4);
  border-radius: var(--arp-radius-xs);
  overflow-x: auto;
  line-height: 1.45;
}

[data-theme="dark"] .public-article .content pre {
  background-color: #161b22;
  border-left-color: #00bfa5;
}

.public-article .content pre > code {
  background: transparent;
  color: inherit;
  padding: 0;
  border-radius: 0;
}

.public-article [id] {
  scroll-margin-top: 80px;
}

/* Peering grid */
.peering-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--arp-space-4);
}

.peering-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--arp-space-3);
  margin-bottom: var(--arp-space-6);
  padding: var(--arp-space-3) var(--arp-space-4);
  background: var(--bulma-scheme-main);
  border-radius: var(--bulma-radius);
  border: 1px solid var(--bulma-border);
}

@media (max-width: 768px) {
  .peering-legend {
    justify-content: flex-start;
  }
}

.peering-legend-item {
  display: flex;
  align-items: center;
  gap: var(--arp-space-2);
  font-size: 0.875rem;
  color: var(--bulma-text);
}

.peering-entry {
  display: flex;
  align-items: center;
  gap: var(--arp-space-3);
  padding: var(--arp-space-3) var(--arp-space-4);
  border-radius: var(--bulma-radius-large);
  background: color-mix(in srgb, var(--bulma-primary) 8%, var(--bulma-scheme-main));
  border: 1px solid color-mix(in srgb, var(--bulma-primary) 20%, var(--bulma-border));
  transition: border-color 0.2s ease;
  height: 5rem;
  box-sizing: border-box;
  text-decoration: none;
}

.peering-entry:hover {
  border-color: var(--bulma-primary);
}

[data-theme="dark"] .peering-entry {
  background: color-mix(in srgb, var(--bulma-primary) 12%, var(--bulma-scheme-main));
}

.peering-entry:hover {
  border-color: var(--bulma-primary);
}

.asn-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 60px;
  padding: var(--arp-space-1) var(--arp-space-2);
  background: var(--bulma-scheme-main);
  color: var(--bulma-primary);
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: var(--arp-radius-xs);
  letter-spacing: 0.02em;
}

.peering-entry .asn-name {
  font-weight: 500;
  color: var(--bulma-text-strong);
}

.peering-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.peering-dot-1 { background: #22c55e; }
.peering-dot-2 { background: var(--arp-accent); }
.peering-dot-3 { background: #a855f7; }
.peering-dot-4 { background: #f59e0b; }
.peering-dot-5 { background: #ec4899; }
.peering-dot-6 { background: #06b6d4; }
.peering-dot-7 { background: #64748b; }
