/* ── Manifest Design System ── Receipt / Customs-form aesthetic ── */
/* Force light mode only */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  /* Manifest palette */
  --paper: #f3eee2;
  --panel: #fbf8ef;
  --ink: #0e1a2b;
  --navy: #1f3a5f;
  --navy-deep: #15293f;
  --dim: #5a6878;
  --border-navy: #1f3a5f;
  --divider: #d8cfb6;
  --tomato: #c43a2e;
  --good: #1f7a4a;
  --warn: #a86b00;

  /* Typography stacks */
  --font-display: "Bungee Inline", Impact, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;
  --font-body: "Inter", ui-sans-serif, system-ui, sans-serif;

  --max-w: 1120px;
  --nav-h: 56px;
  --announce-h: 36px;
}

/* Force light — ignore prefers-color-scheme */
@media (prefers-color-scheme: dark) {
  :root { color-scheme: light; }
}

html { scroll-behavior: smooth; color-scheme: light; }

body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Typography ─────────────────────────────────────────── */
h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 400; /* Bungee Inline only has 400 */
  line-height: 1.15;
  letter-spacing: 0.02em;
  color: var(--navy);
}
h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color: var(--navy);
}
h3 {
  font-family: var(--font-body);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ink);
}
p { color: var(--dim); }

/* ── Layout ─────────────────────────────────────────────── */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.section   { padding: 5rem 0; }
.section-sm { padding: 3.5rem 0; }
.text-center { text-align: center; }

/* ── Announcement Bar ───────────────────────────────────── */
.announce {
  background: var(--navy-deep);
  color: var(--paper);
  text-align: center;
  padding: .5rem 1rem;
  font-family: var(--font-mono);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 3px solid var(--tomato);
  height: var(--announce-h);
  display: flex;
  align-items: center;
  justify-content: center;
}
.announce a { color: var(--tomato); text-decoration: underline; }
.announce strong { color: var(--tomato); }

/* ── Stamp-bar Nav ──────────────────────────────────────── */
.nav {
  position: fixed; top: var(--announce-h); left: 0; right: 0; z-index: 100;
  height: var(--nav-h);
  background: var(--navy-deep);
  border-bottom: 4px solid var(--tomato);
  display: flex; align-items: center;
}
.nav .container { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.nav-logo {
  display: flex; align-items: center; gap: .625rem;
  text-decoration: none;
}
.nav-logo img {
  height: 28px;
  width: auto;
}
.nav-menu { display: flex; align-items: center; gap: 2rem; }
.nav-links { display: flex; align-items: center; gap: 1.75rem; list-style: none; }
.nav-links a {
  font-family: var(--font-mono);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(243,238,226,.7);
  text-decoration: none;
  transition: color .15s;
}
.nav-links a:hover { color: var(--paper); }
.nav-actions { display: flex; align-items: center; gap: .75rem; }

.nav-toggle {
  display: none; background: none; border: none; cursor: pointer;
  color: var(--paper); padding: .25rem;
}

@media (max-width: 768px) {
  .nav-toggle { display: block; }
  .nav-menu {
    display: none; position: absolute; top: var(--nav-h); left: 0; right: 0;
    background: var(--navy-deep); border-bottom: 2px solid var(--tomato);
    padding: 1rem 1.5rem; flex-direction: column; gap: .25rem;
  }
  .nav-menu.open { display: flex; }
  .nav-links { flex-direction: column; gap: .25rem; width: 100%; }
  .nav-links a { display: block; padding: .5rem 0; }
  .nav-actions { width: 100%; padding-top: .75rem; border-top: 1px solid rgba(243,238,226,.15); margin-top: .5rem; }
}

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: 10px 18px;
  border: 2px solid var(--navy-deep);
  background: var(--navy-deep);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 0;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s, color .15s;
  line-height: 1.4;
}
.btn:hover {
  background: var(--navy);
  border-color: var(--navy);
}
.btn:active { transform: scale(.98); }

.btn-primary {
  background: var(--navy-deep);
  color: var(--paper);
  border-color: var(--navy-deep);
}
.btn-primary:hover {
  background: var(--navy);
  border-color: var(--navy);
}

.btn-red {
  background: var(--tomato);
  color: var(--paper);
  border-color: var(--tomato);
}
.btn-red:hover {
  background: #a83225;
  border-color: #a83225;
}

.btn-outline {
  background: transparent;
  color: var(--navy-deep);
  border: 2px solid var(--navy-deep);
}
.btn-outline:hover {
  background: var(--navy-deep);
  color: var(--paper);
}

.btn-lg { padding: 12px 24px; font-size: 12px; }
.btn-sm { padding: 8px 14px; font-size: 10px; }

/* Ghost button for nav */
.btn-nav-cta {
  background: var(--tomato);
  color: var(--paper);
  border-color: var(--tomato);
}
.btn-nav-cta:hover {
  background: #a83225;
  border-color: #a83225;
}

/* ── Hero ────────────────────────────────────────────────── */
.hero {
  padding: calc(var(--nav-h) + var(--announce-h) + 4rem) 0 4rem;
}
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 3rem;
  align-items: center;
}
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-receipt { display: none; }
}
.hero-content { text-align: left; }
.hero-content h1 { max-width: 680px; margin-bottom: 1.25rem; }
.hero-content p { max-width: 540px; font-size: 1.0625rem; margin-bottom: 2rem; line-height: 1.7; }
.hero-actions { display: flex; gap: .75rem; flex-wrap: wrap; }

.thaifex-hero-logo { margin-bottom: 1.5rem; }
.thaifex-hero-logo img {
  height: 100px; width: auto; object-fit: contain;
  border-radius: 0;
}

/* Discount badge — Manifest style */
.discount-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--panel);
  border: 2px solid var(--tomato);
  color: var(--tomato);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: .6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: .5rem 1rem;
  border-radius: 0;
  margin-bottom: 1.25rem;
}
.countdown {
  font-size: .625rem;
  font-weight: 500;
  opacity: .8;
  font-family: var(--font-mono);
  letter-spacing: 0.1em;
}

/* Receipt-style mock panel */
.hero-receipt {
  background: var(--panel);
  border: 2px solid var(--navy);
  padding: 1.5rem;
  position: relative;
}
/* Corner registration marks */
.hero-receipt::before,
.hero-receipt::after {
  content: '';
  position: absolute;
  width: 12px; height: 12px;
  border-color: var(--tomato);
  border-style: solid;
}
.hero-receipt::before {
  top: 6px; left: 6px;
  border-width: 2px 0 0 2px;
}
.hero-receipt::after {
  bottom: 6px; right: 6px;
  border-width: 0 2px 2px 0;
}
.receipt-title {
  font-family: var(--font-mono);
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tomato);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--divider);
}
.receipt-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: .375rem 0;
  border-bottom: 1px dashed var(--divider);
}
.receipt-row:last-child { border-bottom: none; }
.receipt-label {
  font-family: var(--font-mono);
  font-size: .625rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dim);
}
.receipt-value {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--navy);
}
.receipt-value.good { color: var(--good); }
.receipt-value.warn { color: var(--warn); }
.receipt-value.danger { color: var(--tomato); }
.receipt-footer {
  margin-top: .75rem;
  padding-top: .75rem;
  border-top: 2px solid var(--navy);
  font-family: var(--font-mono);
  font-size: .5625rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dim);
  text-align: center;
}

/* ── Section Label (mono uppercase) ─────────────────────── */
.section-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: .6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--tomato);
  margin-bottom: .5rem;
}

.section-heading { margin-bottom: 3rem; }
.section-heading p { margin-top: .75rem; max-width: 560px; font-size: 1rem; }
.section-heading.text-center p { margin-left: auto; margin-right: auto; }

/* ── Stats ──────────────────────────────────────────────── */
.stat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; text-align: center;
}
.stat-card {
  background: var(--panel);
  border: 2px solid var(--navy);
  padding: 1.75rem 1rem;
  position: relative;
}
/* Corner marks on stat cards */
.stat-card::before,
.stat-card::after {
  content: '';
  position: absolute;
  width: 8px; height: 8px;
  border-color: var(--tomato);
  border-style: solid;
}
.stat-card::before { top: 4px; left: 4px; border-width: 2px 0 0 2px; }
.stat-card::after { bottom: 4px; right: 4px; border-width: 0 2px 2px 0; }
.stat-number {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 400;
  color: var(--navy);
  line-height: 1;
}
.stat-label {
  font-family: var(--font-mono);
  font-size: .625rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dim);
  margin-top: .5rem;
}
@media (max-width: 768px) { .stat-grid { grid-template-columns: 1fr; gap: 1rem; } }

/* ── Cards (Manifest: sharp corners, navy borders, no shadows) ── */
.card {
  background: var(--panel);
  border: 2px solid var(--navy);
  border-radius: 0;
  padding: 1.75rem;
  transition: border-color .2s;
}
.card:hover { border-color: var(--tomato); }
.card-icon {
  width: 2.75rem; height: 2.75rem;
  border: 2px solid var(--navy);
  border-radius: 0;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
  background: var(--paper);
  color: var(--navy);
}
.card-icon svg { width: 1.375rem; height: 1.375rem; stroke: var(--navy); }
.card h3 { margin-bottom: .5rem; }
.card p { font-size: .9rem; }

/* ── Grid Layouts ───────────────────────────────────────── */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}

/* ── Two Column Layout ──────────────────────────────────── */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 768px) { .two-col { grid-template-columns: 1fr; gap: 2rem; } }

/* ── Checklist ──────────────────────────────────────────── */
.checklist { list-style: none; padding: 0; }
.checklist li {
  padding: .625rem 0;
  font-size: .9375rem;
  color: var(--dim);
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  border-bottom: 1px dashed var(--divider);
}
.checklist li:last-child { border-bottom: none; }
.checklist li::before {
  content: '';
  display: inline-block;
  width: 1.125rem; height: 1.125rem;
  border: 2px solid var(--navy);
  border-radius: 0;
  flex-shrink: 0;
  margin-top: .15rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%231f3a5f'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");
  background-size: 12px; background-repeat: no-repeat; background-position: center;
  background-color: var(--panel);
}

/* Danger card variant */
.card-danger {
  border-color: var(--tomato);
  border-left-width: 4px;
}
.card-danger h3 { color: var(--tomato); }
.card-danger .checklist li::before {
  border-color: var(--tomato);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23c43a2e'%3E%3Cpath fill-rule='evenodd' d='M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");
}

/* ── Steps ──────────────────────────────────────────────── */
.steps-list { display: flex; flex-direction: column; gap: 0; max-width: 640px; margin: 0 auto; }
.step {
  display: flex; gap: 1.5rem; align-items: flex-start;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--divider);
}
.step:last-child { border-bottom: none; }
.step-number {
  width: 2.5rem; height: 2.5rem;
  border: 2px solid var(--navy);
  border-radius: 0;
  background: var(--navy-deep);
  color: var(--paper);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1rem;
  flex-shrink: 0;
}
.step-content h3 { margin-bottom: .25rem; }
.step-content p { font-size: .9rem; }
.step-connector {
  width: 2px; height: 1.5rem;
  background: var(--divider);
  margin-left: calc(1.25rem - 1px);
}

/* ── Best Practices ─────────────────────────────────────── */
.best-practice {
  background: var(--panel);
  border: 2px solid var(--navy);
  border-radius: 0;
  padding: 1.5rem;
}
.best-practice h3 { font-size: 1rem; margin-bottom: .375rem; }
.best-practice p { font-size: .875rem; }
.best-practice-icon {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--navy);
  margin-bottom: .5rem;
  width: 2rem; height: 2rem;
  border: 2px solid var(--navy);
  display: flex; align-items: center; justify-content: center;
  background: var(--paper);
}

/* ── FAQ Accordion ──────────────────────────────────────── */
.faq-item { border-bottom: 2px solid var(--navy); }
.faq-q {
  width: 100%; text-align: left; background: none; border: none;
  padding: 1.25rem 0;
  font-family: var(--font-mono);
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.faq-q::after {
  content: '+';
  font-family: var(--font-mono);
  font-size: 1.25rem;
  color: var(--tomato);
  transition: transform .2s;
  flex-shrink: 0;
  margin-left: 1rem;
}
.faq-item.open .faq-q::after { content: '\2212'; }
.faq-a {
  max-height: 0; overflow: hidden; transition: max-height .25s ease;
}
.faq-item.open .faq-a { max-height: 400px; }
.faq-a p { padding-bottom: 1.25rem; font-size: .875rem; line-height: 1.7; }

/* ── CTA Banner ─────────────────────────────────────────── */
.cta-banner {
  background: var(--navy-deep);
  color: var(--paper);
  border: 2px solid var(--navy);
  border-radius: 0;
  padding: 3.5rem 2rem;
  text-align: center;
  position: relative;
}
/* Corner marks */
.cta-banner::before,
.cta-banner::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  border-color: var(--tomato);
  border-style: solid;
}
.cta-banner::before { top: 8px; left: 8px; border-width: 2px 0 0 2px; }
.cta-banner::after { bottom: 8px; right: 8px; border-width: 0 2px 2px 0; }
.cta-banner h2 { color: var(--paper); margin-bottom: .75rem; }
.cta-banner p { color: rgba(243,238,226,.7); margin-bottom: 1.5rem; max-width: 480px; margin-left: auto; margin-right: auto; }
.cta-banner .btn {
  background: var(--tomato);
  color: var(--paper);
  border-color: var(--tomato);
}
.cta-banner .btn:hover {
  background: #a83225;
  border-color: #a83225;
}
.cta-banner .discount-badge {
  background: rgba(243,238,226,.1);
  border-color: var(--tomato);
  color: var(--tomato);
}

/* ── Mid-page CTAs ──────────────────────────────────────── */
.mid-cta {
  padding: 2.5rem 0;
}
.mid-cta p {
  font-family: var(--font-mono);
  font-size: .6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dim);
}
.mid-cta .lead {
  font-family: var(--font-body);
  font-size: 1.0625rem;
  font-weight: 700;
  letter-spacing: normal;
  text-transform: none;
  color: var(--ink);
  margin-bottom: .75rem;
}

/* ── Partner Logos Bar ───────────────────────────────────── */
.partner-bar {
  padding: 2rem 0;
  border-top: 2px solid var(--navy);
}
.partner-logos {
  display: flex; align-items: center; justify-content: center; gap: 2rem;
  padding: 1rem 0; flex-wrap: wrap;
}
.partner-logos img { height: 60px; width: auto; object-fit: contain; }
.partner-logos .logo-divider {
  width: 2px; height: 40px; background: var(--navy);
}
.partner-logos .logo-label {
  font-family: var(--font-mono);
  font-size: .5625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--dim);
  text-align: center;
  margin-bottom: .25rem;
}
.partner-logos .aleph-text {
  font-weight: 700;
  font-size: 1.125rem;
  color: var(--ink);
}

/* ── Footer ─────────────────────────────────────────────── */
.footer {
  background: var(--navy-deep);
  color: rgba(243,238,226,.6);
  border-top: 4px solid var(--tomato);
  padding: 3.5rem 0 0;
  font-size: .8125rem;
}
.footer-grid {
  display: grid; grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: 2.5rem; padding-bottom: 2.5rem;
}
.footer-brand { display: flex; flex-direction: column; gap: .75rem; }
.footer-brand a {
  display: inline-flex; align-items: center; gap: .5rem;
  text-decoration: none;
}
.footer-brand a img { height: 24px; width: auto; }
.footer-brand p { color: rgba(243,238,226,.5); line-height: 1.6; max-width: 260px; }
.footer-col h4 {
  font-family: var(--font-mono);
  font-size: .625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--paper);
  margin-bottom: .75rem;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.footer-col a {
  font-family: var(--font-mono);
  font-size: .6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(243,238,226,.5);
  text-decoration: none;
  transition: color .15s;
}
.footer-col a:hover { color: var(--paper); }
.footer-bottom {
  border-top: 1px solid rgba(243,238,226,.15);
  padding: 1.5rem 0;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .75rem;
  font-family: var(--font-mono);
  font-size: .625rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(243,238,226,.4);
}
.footer-bottom a {
  font-family: var(--font-mono);
  font-size: .625rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(243,238,226,.5);
  text-decoration: none;
}
.footer-bottom a:hover { color: var(--paper); }
.footer-social { display: flex; gap: 1rem; align-items: center; }
@media (max-width: 768px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; text-align: center; }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; }
}

/* ── Sticky CTA ─────────────────────────────────────────── */
.sticky-cta {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 99;
  background: var(--navy-deep);
  color: var(--paper);
  padding: .625rem 1rem;
  text-align: center;
  transform: translateY(100%);
  transition: transform .3s ease;
  border-top: 3px solid var(--tomato);
}
.sticky-cta.visible { transform: translateY(0); }
.sticky-cta .container {
  display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap;
}
.sticky-cta p {
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0;
}
.sticky-cta .btn {
  background: var(--tomato);
  color: var(--paper);
  border-color: var(--tomato);
  padding: .5rem 1.25rem;
  font-size: 10px;
}
.sticky-cta .btn:hover {
  background: #a83225;
  border-color: #a83225;
}

/* ── Section bg variants ────────────────────────────────── */
.bg-panel { background: var(--panel); }
.bg-paper { background: var(--paper); }
.bg-navy  { background: var(--navy-deep); color: var(--paper); }

/* ── Utility ────────────────────────────────────────────── */
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mb-4 { margin-bottom: 2rem; }
.gap-2 { gap: 1rem; }

/* ── Corner Registration Marks (decorative) ─────────────── */
.reg-marks { position: relative; }
.reg-marks::before,
.reg-marks::after {
  content: '';
  position: absolute;
  width: 10px; height: 10px;
  border-color: var(--tomato);
  border-style: solid;
}
.reg-marks::before { top: 6px; left: 6px; border-width: 2px 0 0 2px; }
.reg-marks::after { bottom: 6px; right: 6px; border-width: 0 2px 2px 0; }
