@import url("./design-kit.css");
@import url("./landing.css");
@import url("./landing-v2.css");

/* ========== Site-wide additions for multi-page site ========== */

:root {
  --brand-name: "APPNAME";
}

/* Links on legal pages */
.legal-link {
  color: var(--text-primary);
  text-decoration: underline;
  text-decoration-color: rgba(0, 0, 12, 0.22);
  text-underline-offset: 3px;
}

.legal-link:hover {
  text-decoration-color: rgba(88, 216, 62, 0.8);
}

.page {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.page-main {
  min-width: 0;
  overflow-x: hidden;
  padding: var(--space-8) 0;
}

.page-main.is-tight {
  padding: var(--space-6) 0;
}

.page-title {
  margin: 0 0 var(--space-2);
}

.page-subtitle {
  margin: 0;
  color: var(--text-secondary);
  max-width: 70ch;
}

.center-wrap {
  display: grid;
  place-items: center;
  padding: var(--space-10) 0;
}

.panel {
  width: 100%;
  max-width: 100%;
  background: var(--surface-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: var(--space-6);
}

.panel.is-medium {
  max-width: 720px;
}

.panel.is-narrow {
  max-width: 520px;
}

.center-wrap .panel.is-medium,
.center-wrap .panel.is-narrow {
  margin-inline: auto;
}

.panel-header {
  margin-bottom: var(--space-5);
}

.panel-title {
  margin: 0 0 var(--space-2);
  font-size: var(--text-h3);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.panel-text {
  margin: 0;
  color: var(--text-secondary);
}

.form-grid {
  display: grid;
  gap: var(--space-4);
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.form-status {
  margin-top: var(--space-3);
  font-size: var(--text-small);
  color: var(--text-secondary);
}

.form-status.is-error {
  color: var(--color-danger-500);
}

.form-status.is-success {
  color: #2d7f1d;
}

/* Third-party apply embed (e.g. Giga): reserve space while script mounts */
.apply-form-host {
  width: 100%;
  min-height: 12rem;
}

.hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-layout {
  display: grid;
  gap: var(--space-6);
}

.contact-cards {
  display: grid;
  gap: var(--space-4);
}

.contact-left {
  align-self: start;
  display: grid;
  gap: var(--space-4);
}

.contact-support-decor {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6) 0;
  margin: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  color: var(--surface-accent, #58d83e);
}

.contact-support-decor-icon {
  width: 224px;
  height: 224px;
  display: block;
}

.contact-support-decor-icon path {
  fill: var(--surface-accent, #58d83e);
}

.contact-right {
  align-self: start;
}

.legal-stack {
  display: grid;
  gap: var(--space-5);
}

.legal-stack .panel,
.legal-stack .legal-section {
  margin: 0;
}

.table-wrap {
  overflow: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--surface-base);
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 560px;
}

th,
td {
  padding: 14px 16px;
  border-bottom: 1px solid rgba(0, 0, 12, 0.08);
  text-align: left;
  vertical-align: top;
  font-size: var(--text-small);
}

th {
  font-size: var(--text-caption);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
  background: rgba(0, 0, 12, 0.02);
}

tr:last-child td {
  border-bottom: 0;
}

/* ========== Footer ========== */
.site-footer {
  background: var(--color-secondary-900);
  color: rgba(255, 255, 255, 0.9);
  border-top: none;
}

.site-footer .brand-mark {
  background: rgba(255, 255, 255, 0.1);
}

.site-footer .brand-name {
  color: #ffffff;
}

.footer-grid {
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
}

.footer-heading {
  margin: 0 0 var(--space-3);
  color: #ffffff;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.footer-links {
  gap: 10px;
}

.footer-link {
  color: rgba(255, 255, 255, 0.78);
}

.footer-link:hover {
  color: #ffffff;
}

.footer-text {
  color: rgba(255, 255, 255, 0.78);
}

.footer-badge {
  margin-top: var(--space-4);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-weight: 800;
  font-size: var(--text-caption);
}

.ssl-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--color-accent-500);
}

.footer-disclaimer {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  display: grid;
  gap: var(--space-3);
  color: rgba(255, 255, 255, 0.74);
  font-size: var(--text-caption);
  line-height: 1.7;
  grid-column: 1 / -1;
}

.footer-bottom {
  grid-column: 1 / -1;
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.68);
  font-size: var(--text-caption);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: space-between;
  align-items: center;
}

.footer-bottom a {
  color: rgba(255, 255, 255, 0.78);
}

.footer-bottom a:hover {
  color: #ffffff;
}

/* Apply page: simple header without nav */
.simple-header .site-shell {
  grid-template-columns: 1fr auto;
}

.simple-header .site-nav,
.simple-header .header-cta,
.simple-header .nav-toggle {
  display: none !important;
}

@media (min-width: 700px) {
  .page-main {
    padding: var(--space-10) 0;
  }

  .panel {
    padding: var(--space-8);
  }

  /* Make footer top row: Brand + Company + Legal + Account */
  .site-footer .footer-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.6fr) minmax(0, 0.6fr) minmax(0, 0.6fr);
    align-items: start;
  }
}

@media (min-width: 900px) {
  .contact-layout {
    grid-template-columns: minmax(0, 0.44fr) minmax(0, 0.56fr);
    align-items: start;
  }

  /* Left column matches form height; icon sits centered in the space below the cards */
  .contact-left {
    align-self: stretch;
    grid-template-rows: auto 1fr;
    min-height: 0;
  }

  .contact-support-decor {
    min-height: 0;
    padding: var(--space-8) var(--space-2) var(--space-4);
  }

  .contact-support-decor-icon {
    width: 256px;
    height: 256px;
  }
}

/* Index hero-subproof: layout + icon fill duplicated from landing-v2 so deploy survives missing/renamed import or currentColor quirks */
.subproof-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3, 12px);
  min-width: 0;
}

.subproof-heading .subproof-title {
  flex: 1;
  min-width: 0;
}

.subproof-heading > svg {
  flex-shrink: 0;
  display: block;
  width: 30px;
  height: 30px;
  color: var(--surface-accent, #58d83e);
}

.subproof-heading > svg :is(path, rect, circle, ellipse, polygon, polyline) {
  fill: var(--surface-accent, #58d83e);
}

.subproof-heading > svg g {
  fill: var(--surface-accent, #58d83e);
}

