/* calq.css — shared theme + sheet rendering styles
   Used by viewer.html, marketplace.html, and any future page that
   embeds a rendered .calq sheet. Tokens mirror index.html. */

:root {
  --cream:  #FDF6E3;
  --cream2: #F5EBD0;
  --amber:  #E8A020;
  --amberD: #C47E0A;
  --amberL: #FFF0C0;
  --ink:    #1C1A14;
  --ink2:   #2E2A20;
  --soft:   #5A5040;
  --ghost:  #A09070;

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono:  'DM Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--cream);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ═══════════════════════════════════════════════════
   NAV — shared with index.html structure
═══════════════════════════════════════════════════ */
.calq-nav {
  position: sticky; top: 0; z-index: 900;
  padding: 14px 32px;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(253, 246, 227, .92);
  backdrop-filter: blur(20px) saturate(1.6);
  border-bottom: 1px solid rgba(232, 160, 32, .15);
}
.calq-nav .logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.calq-nav .logo-wm {
  font-family: var(--serif); font-size: 24px; font-weight: 700;
  color: var(--ink); letter-spacing: -.5px; line-height: 1;
}
.calq-nav .logo-wm .q { color: var(--amber); }
.calq-nav .nav-r { display: flex; align-items: center; gap: 22px; }
.calq-nav .nav-r a {
  font-size: 14px; font-weight: 500; color: var(--soft);
  text-decoration: none; transition: color .2s;
}
.calq-nav .nav-r a:hover { color: var(--amberD); }
.calq-nav .nav-r a.active { color: var(--ink); }
.calq-nav .nav-cta {
  background: var(--ink); color: var(--cream) !important;
  padding: 9px 20px; border-radius: 100px;
  font-weight: 700; font-size: 13px; letter-spacing: .3px;
  transition: background .2s, transform .2s;
}
.calq-nav .nav-cta:hover { background: var(--amber); color: var(--ink) !important; transform: translateY(-1px); }

/* ═══════════════════════════════════════════════════
   PAGE LAYOUT
═══════════════════════════════════════════════════ */
.page {
  max-width: 1180px;
  margin: 0 auto;
  padding: 56px 32px 96px;
}
.page-head { text-align: center; margin-bottom: 40px; }
.page-head .ey {
  display: inline-block;
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  color: var(--amberD); margin-bottom: 16px;
}
.page-head h1 {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(40px, 6vw, 72px); line-height: 1; letter-spacing: -1.5px;
  color: var(--ink); margin-bottom: 14px;
}
.page-head h1 em { font-style: italic; color: var(--amberD); }
.page-head p {
  max-width: 600px; margin: 0 auto;
  color: var(--soft); font-size: 17px; line-height: 1.55;
}

/* ═══════════════════════════════════════════════════
   SHEET RENDERING — used by viewer.html and previews
═══════════════════════════════════════════════════ */
.calq-sheet {
  background: var(--cream);
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  font-family: var(--mono);
  color: var(--ink2);
  border: 1px solid rgba(232, 160, 32, .18);
}
.calq-sheet .calq-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.1;
  letter-spacing: -0.6px;
  color: var(--ink);
  margin-bottom: 6px;
}
.calq-sheet .calq-desc {
  font-family: var(--sans);
  font-size: 14px;
  color: var(--soft);
  margin-bottom: 22px;
  line-height: 1.5;
}
.calq-block {
  border-radius: var(--radius);
  padding: 10px 14px;
  margin: 6px 0;
  background: transparent;
  transition: background .2s ease;
}
.calq-block--open {
  border: 1px dashed rgba(232, 160, 32, .45);
}
.calq-section {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--ghost);
  padding: 8px 4px 4px;
}
.calq-row {
  display: grid;
  grid-template-columns: 28px minmax(80px, max-content) 1fr;
  align-items: baseline;
  gap: 12px;
  padding: 6px 4px;
  font-size: 18px;
  font-variant-numeric: tabular-nums;
  border-radius: 6px;
}
.calq-op {
  text-align: center;
  font-family: var(--mono);
  font-size: 18px;
  color: var(--amberD);
  font-weight: 500;
}
.calq-val {
  text-align: right;
  font-family: var(--mono);
  color: var(--ink);
}
.calq-val--result {
  font-weight: 700;
  font-size: 22px;
  color: var(--ink);
  border-top: 1px solid rgba(28, 26, 20, .25);
  padding-top: 6px;
  margin-top: 4px;
}
.calq-val--ref {
  color: var(--ink);
  position: relative;
}
.calq-val--ref::before {
  content: '';
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--calq-group-color, var(--amber));
  margin-right: 8px;
  vertical-align: middle;
}
.calq-val--namedref {
  font-style: italic;
  color: var(--amberD);
}
.calq-cmt {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--soft);
  font-weight: 400;
}
.calq-cmt--named {
  color: var(--amberD);
  font-weight: 600;
  font-family: var(--mono);
  font-size: 12px;
}
.calq-row--result .calq-cmt {
  font-weight: 600;
  color: var(--ink2);
}

/* ═══════════════════════════════════════════════════
   CARDS / GRIDS — marketplace
═══════════════════════════════════════════════════ */
.tcat-bar {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  margin: 0 auto 28px; max-width: 900px;
}
.tcat {
  background: var(--cream2);
  border: 1px solid rgba(232, 160, 32, .25);
  color: var(--soft);
  font-size: 13px; font-weight: 500;
  padding: 8px 16px;
  border-radius: 100px;
  cursor: pointer;
  transition: all .15s ease;
  font-family: var(--sans);
}
.tcat:hover { color: var(--ink); border-color: var(--amber); }
.tcat--active {
  background: var(--ink); color: var(--cream); border-color: var(--ink);
}
.tsearch {
  display: block; margin: 0 auto 32px; max-width: 480px;
  width: 100%; padding: 14px 22px;
  border-radius: 100px;
  border: 1px solid rgba(232, 160, 32, .35);
  background: #fff;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.tsearch:focus { border-color: var(--amber); box-shadow: 0 0 0 4px rgba(232, 160, 32, .12); }

.tgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}
.tcard {
  background: #fff;
  border-radius: var(--radius);
  padding: 20px;
  border: 1px solid rgba(232, 160, 32, .14);
  display: flex; flex-direction: column;
  transition: transform .15s ease, box-shadow .2s ease, border-color .15s ease;
  position: relative;
}
.tcard:hover {
  transform: translateY(-2px);
  border-color: rgba(232, 160, 32, .35);
  box-shadow: 0 6px 24px rgba(28, 26, 20, .06);
}
.tcard-cat {
  display: inline-block;
  font-size: 11px; font-weight: 700; letter-spacing: 1.3px; text-transform: uppercase;
  color: var(--amberD); margin-bottom: 8px;
}
.tcard-name {
  font-family: var(--serif);
  font-size: 22px; font-weight: 600; line-height: 1.15; letter-spacing: -0.4px;
  color: var(--ink); margin-bottom: 6px;
}
.tcard-desc {
  color: var(--soft); font-size: 14px; line-height: 1.5;
  flex: 1;
  margin-bottom: 16px;
}
.tcard-meta {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 14px;
}
.tcard-badge {
  font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 100px;
}
.tcard-badge--free {
  background: #e8f6ec; color: #1d6b3a;
}
.tcard-badge--pro {
  background: var(--amberL); color: var(--amberD);
}
.tcard-badge--paid {
  background: #efe8ff; color: #5b3eb8;
}
.tcard-acts {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.btn {
  font-family: var(--sans);
  font-size: 13px; font-weight: 600;
  padding: 9px 14px;
  border-radius: 100px;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid transparent;
  transition: background .15s ease, color .15s ease, transform .1s ease;
  white-space: nowrap;
}
.btn--prim { background: var(--ink); color: var(--cream); }
.btn--prim:hover { background: var(--amber); color: var(--ink); }
.btn--ghost { background: transparent; color: var(--soft); border-color: rgba(232, 160, 32, .35); }
.btn--ghost:hover { color: var(--ink); border-color: var(--amber); }
.btn--small { padding: 7px 12px; font-size: 12px; }

/* ═══════════════════════════════════════════════════
   VIEWER — drop zone, status states
═══════════════════════════════════════════════════ */
.viewer-shell {
  max-width: 720px;
  margin: 0 auto;
  padding: 32px;
}
.viewer-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  margin: 20px 0 14px;
  flex-wrap: wrap;
}
.viewer-status {
  text-align: center; padding: 14px;
  font-size: 13px; color: var(--soft);
  border-radius: var(--radius);
  background: var(--cream2);
  margin-bottom: 18px;
}
.viewer-status--err {
  background: #ffe6e1; color: #8b1f0c;
}
.viewer-status--warn {
  background: #fff5d6; color: #7a5500;
}
.dropzone {
  border: 2px dashed rgba(232, 160, 32, .55);
  border-radius: var(--radius-lg);
  padding: 64px 32px;
  text-align: center;
  background: rgba(255, 240, 192, .25);
  transition: background .15s, border-color .15s;
}
.dropzone--over { background: rgba(232, 160, 32, .15); border-color: var(--amberD); }
.dropzone .dz-icon {
  font-size: 56px; line-height: 1;
  color: var(--amberD); margin-bottom: 12px;
}
.dropzone h2 {
  font-family: var(--serif); font-weight: 600; font-size: 24px;
  color: var(--ink); margin-bottom: 8px;
}
.dropzone p { color: var(--soft); font-size: 14px; }
.dropzone label {
  display: inline-block;
  margin-top: 18px;
  cursor: pointer;
}

/* ═══════════════════════════════════════════════════
   NAV DROPDOWN — Platforms
═══════════════════════════════════════════════════ */
.nav-drop { position: relative; }
.nav-drop-trig {
  background: none; border: none; cursor: pointer;
  font-family: var(--sans);
  font-size: 14px; font-weight: 500; color: var(--soft);
  display: inline-flex; align-items: center; gap: 4px;
  padding: 6px 0;
  transition: color .15s ease;
}
.nav-drop-trig:hover { color: var(--amberD); }
.nav-drop-caret { font-size: 10px; transition: transform .15s ease; }
.nav-drop:hover .nav-drop-caret,
.nav-drop:focus-within .nav-drop-caret { transform: rotate(180deg); }

.nav-drop-menu {
  position: absolute; top: 100%; left: -16px;
  background: #fff;
  border: 1px solid rgba(232,160,32,.18);
  border-radius: 14px;
  box-shadow: 0 12px 36px rgba(28,26,20,.10);
  padding: 10px;
  min-width: 240px;
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
  z-index: 1000;
}
.nav-drop:hover .nav-drop-menu,
.nav-drop:focus-within .nav-drop-menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.nav-drop-menu a {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 9px 12px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--ink);
  font-size: 14px; font-weight: 500;
  transition: background .12s ease, color .12s ease;
}
.nav-drop-menu a:hover { background: var(--cream2); color: var(--amberD); }
.nav-drop-name { font-weight: 600; }
.nav-drop-status {
  font-size: 11px; font-weight: 500; color: var(--ghost);
  font-family: var(--mono);
}

/* ═══════════════════════════════════════════════════
   HOME — PLATFORMS PICKER
═══════════════════════════════════════════════════ */
.home-plats { background: var(--cream); padding: 96px 32px 80px; }
.home-plats-head, .home-market-head { text-align: center; margin-bottom: 40px; }
.home-plats-head .ey, .home-market-head .ey {
  display: inline-block;
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  color: var(--amberD); margin-bottom: 14px;
}
.home-plats-head .sh, .home-market-head .sh {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(36px, 5vw, 56px); line-height: 1.05; letter-spacing: -1.2px;
  color: var(--ink);
}
.home-plats-head .sh em, .home-market-head .sh em { font-style: italic; color: var(--amberD); }
.home-plats-head .bp, .home-market-head .bp { color: var(--soft); font-size: 16px; line-height: 1.6; }

.home-plats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  max-width: 1100px; margin: 0 auto;
}
.home-plat {
  display: flex; flex-direction: column; justify-content: space-between;
  background: #fff;
  border: 1px solid rgba(232,160,32,.18);
  border-radius: var(--radius-lg);
  padding: 24px;
  text-decoration: none; color: inherit;
  min-height: 180px;
  transition: transform .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.home-plat:hover {
  transform: translateY(-4px);
  border-color: var(--amber);
  box-shadow: 0 14px 30px rgba(28,26,20,.07);
}
.home-plat-name {
  font-family: var(--serif);
  font-size: 26px; font-weight: 600; letter-spacing: -.4px;
  color: var(--ink); margin-bottom: 8px;
}
.home-plat-tag { color: var(--soft); font-size: 14px; line-height: 1.5; }
.home-plat-foot {
  margin-top: 18px;
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 14px;
  border-top: 1px solid rgba(232,160,32,.14);
}
.home-plat-status {
  font-family: var(--mono);
  font-size: 11px; font-weight: 500; letter-spacing: .5px;
  color: var(--amberD);
}
.home-plat-arrow { font-size: 18px; color: var(--ink); transition: transform .15s ease; }
.home-plat:hover .home-plat-arrow { transform: translateX(4px); }

/* ═══════════════════════════════════════════════════
   HOME — MARKETPLACE TEASER
═══════════════════════════════════════════════════ */
.home-market { background: var(--cream2); padding: 96px 32px; }
.home-market-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
  max-width: 1100px; margin: 0 auto 40px;
}
.home-market-card {
  background: var(--cream);
  border: 1px solid rgba(232,160,32,.18);
  border-radius: var(--radius);
  padding: 22px;
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column; gap: 8px;
  transition: transform .15s ease, border-color .15s ease;
}
.home-market-card:hover { transform: translateY(-3px); border-color: var(--amber); }
.home-market-cat {
  font-size: 10px; font-weight: 700; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--amberD);
}
.home-market-title {
  font-family: var(--serif);
  font-size: 21px; font-weight: 600; line-height: 1.15; letter-spacing: -.3px;
  color: var(--ink);
}
.home-market-sum { color: var(--soft); font-size: 14px; line-height: 1.5; }
.home-market-cta { text-align: center; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════
   PLATFORM PAGE
═══════════════════════════════════════════════════ */
.page--platform { padding: 0; max-width: none; }
.plat-hero {
  background: var(--ink); color: var(--cream);
  padding: 96px 32px 72px;
  position: relative; overflow: hidden;
}
.plat-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 20% 30%, rgba(232,160,32,.20), transparent 50%);
  pointer-events: none;
}
.plat-hero-in {
  position: relative;
  display: grid; grid-template-columns: 1.2fr 1fr;
  gap: 56px; align-items: center;
  max-width: 1180px; margin: 0 auto;
}
.plat-eyebrow { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.plat-status {
  background: var(--amber); color: var(--ink);
  font-size: 11px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 100px;
  font-family: var(--mono);
}
.plat-version { font-family: var(--mono); color: rgba(253,246,227,.55); font-size: 13px; }
.plat-h1 {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(48px, 7vw, 84px); line-height: 1; letter-spacing: -2px;
  color: var(--cream); margin-bottom: 18px;
}
.plat-h1 em { color: var(--amber); font-style: italic; }
.plat-tagline {
  color: rgba(253,246,227,.78);
  font-size: 19px; line-height: 1.5; max-width: 520px; margin-bottom: 26px;
}
.plat-acts { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }
.plat-cta { background: var(--amber) !important; color: var(--ink) !important; padding: 14px 24px; font-size: 15px; }
.plat-cta:hover { background: #FFC44A !important; transform: translateY(-2px); }
.plat-acts .btn--ghost { color: var(--cream); border-color: rgba(253,246,227,.28); }
.plat-acts .btn--ghost:hover { background: rgba(253,246,227,.06); color: var(--amber); border-color: var(--amber); }

.plat-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 24px; margin: 0;
  padding-top: 28px;
  border-top: 1px solid rgba(253,246,227,.14);
}
.plat-meta dt {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.2px;
  text-transform: uppercase; color: rgba(253,246,227,.45);
  margin-bottom: 4px;
}
.plat-meta dd { font-size: 14px; font-weight: 500; color: var(--cream); margin: 0; }

.plat-shots { position: relative; min-height: 460px; }
.plat-shot {
  position: absolute; top: 0;
  border-radius: 28px; overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
  background: var(--ink2);
}
.plat-shot img { display: block; width: 100%; height: auto; }
.plat-shot--0 { left: 0; top: 30px; width: 56%; transform: rotate(-3deg); }
.plat-shot--1 { left: 30%; top: 0; width: 56%; z-index: 2; }
.plat-shot--2 { right: 0; top: 60px; width: 50%; transform: rotate(3deg); z-index: 1; }

.plat-feat { padding: 96px 32px; background: var(--cream); }
.plat-feat-head { text-align: center; margin-bottom: 56px; }
.plat-feat-head .ey {
  display: inline-block;
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  color: var(--amberD); margin-bottom: 14px;
}
.plat-feat-head .sh {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(34px, 4.5vw, 56px); line-height: 1.05; letter-spacing: -1.2px;
}
.plat-feat-head .sh em { color: var(--amberD); font-style: italic; }
.plat-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  max-width: 1180px; margin: 0 auto;
}
.plat-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  border: 1px solid rgba(232,160,32,.14);
  transition: transform .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.plat-card:hover {
  transform: translateY(-3px);
  border-color: rgba(232,160,32,.32);
  box-shadow: 0 12px 30px rgba(28,26,20,.06);
}
.plat-card-icon { font-size: 36px; line-height: 1; margin-bottom: 14px; }
.plat-card-title {
  font-family: var(--serif);
  font-size: 22px; font-weight: 600; letter-spacing: -.3px;
  color: var(--ink); margin-bottom: 8px;
}
.plat-card-body { color: var(--soft); font-size: 15px; line-height: 1.55; margin: 0; }

.plat-req { background: var(--cream2); padding: 80px 32px; }
.plat-req-in {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 56px; align-items: center;
}
.plat-req .ey {
  display: inline-block; color: var(--amberD);
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 12px;
}
.plat-req .sh-sm {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(28px, 3.5vw, 40px); letter-spacing: -.8px;
  color: var(--ink); margin-bottom: 18px;
}
.plat-req-list { list-style: none; padding: 0; margin: 0; }
.plat-req-list li { padding: 10px 0; border-bottom: 1px solid rgba(28,26,20,.08); color: var(--ink2); font-size: 15px; }
.plat-req-list li:before { content: '✓ '; color: var(--amberD); margin-right: 6px; font-weight: 700; }
.plat-req-cta { text-align: center; }
.plat-req-note { color: var(--ghost); font-size: 12px; margin-top: 12px; }

.plat-other { padding: 80px 32px; background: var(--cream); text-align: center; }
.plat-other-head { margin-bottom: 36px; }
.plat-other-head .ey {
  display: inline-block; color: var(--amberD);
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 12px;
}
.plat-other-head .sh-sm {
  font-family: var(--serif); font-weight: 600; font-size: 32px; letter-spacing: -.8px;
  color: var(--ink); margin-bottom: 6px;
}
.plat-other-head p { color: var(--soft); font-size: 14px; }
.plat-other-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  max-width: 1100px; margin: 0 auto;
}
.plat-other-card {
  display: flex; align-items: center; justify-content: space-between;
  background: #fff;
  border: 1px solid rgba(232,160,32,.16);
  border-radius: var(--radius);
  padding: 16px 22px;
  text-decoration: none; color: inherit;
  transition: border-color .15s ease, transform .12s ease;
}
.plat-other-card:hover { border-color: var(--amber); transform: translateY(-2px); }
.plat-other-name { font-family: var(--serif); font-weight: 600; font-size: 18px; }
.plat-other-status { font-family: var(--mono); font-size: 10px; color: var(--ghost); margin-left: 12px; }
.plat-other-arrow { margin-left: 10px; font-size: 16px; color: var(--amberD); }

@media (max-width: 880px) {
  .plat-hero-in { grid-template-columns: 1fr; gap: 32px; }
  .plat-shots { min-height: 320px; }
  .plat-shot--0, .plat-shot--1, .plat-shot--2 { transform: none; }
  .plat-shot--0 { left: 0; width: 50%; top: 0; }
  .plat-shot--1 { right: 0; left: auto; width: 50%; top: 30px; }
  .plat-shot--2 { display: none; }
  .plat-req-in { grid-template-columns: 1fr; gap: 28px; }
  .plat-req-cta { text-align: left; }
}

/* ═══════════════════════════════════════════════════
   SUBMIT PAGE
═══════════════════════════════════════════════════ */
.page--submit { max-width: 860px; }
.submit-banner {
  border-radius: var(--radius);
  padding: 14px 20px;
  margin: 0 0 28px;
  font-size: 14px; line-height: 1.5;
}
.submit-banner--ok  { background: #e8f6ec; color: #1d6b3a; border: 1px solid #b6e2c0; }
.submit-banner--err { background: #ffe6e1; color: #8b1f0c; border: 1px solid #f4baad; }

.submit-flow {
  background: var(--cream2);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  margin-bottom: 36px;
}
.submit-section-title {
  font-family: var(--serif); font-weight: 600;
  font-size: 26px; letter-spacing: -.5px;
  margin-bottom: 18px;
}
.submit-steps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px; }
.submit-steps li { display: grid; grid-template-columns: 38px 1fr; gap: 16px; align-items: start; }
.submit-step-num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--ink); color: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-weight: 700; font-size: 14px;
}
.submit-steps li > div:last-child { line-height: 1.55; color: var(--ink2); }
.submit-steps a { color: var(--amberD); }
.submit-steps code { background: var(--cream); padding: 2px 6px; border-radius: 4px; font-family: var(--mono); font-size: 13px; }

.submit-form {
  background: #fff;
  border: 1px solid rgba(232,160,32,.18);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
}
.submit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; position: relative; }
.submit-field { display: flex; flex-direction: column; gap: 6px; }
.submit-field--wide { grid-column: 1 / -1; }
.submit-label { font-family: var(--sans); font-weight: 600; font-size: 13px; color: var(--ink2); letter-spacing: .2px; }
.submit-field input, .submit-field select, .submit-field textarea {
  font-family: var(--sans);
  font-size: 15px;
  padding: 12px 14px;
  border: 1px solid rgba(232,160,32,.30);
  border-radius: 10px;
  background: var(--cream);
  color: var(--ink);
  transition: border-color .15s ease, box-shadow .15s ease;
  width: 100%;
}
.submit-field input:focus, .submit-field select:focus, .submit-field textarea:focus {
  outline: none;
  border-color: var(--amber);
  box-shadow: 0 0 0 4px rgba(232,160,32,.12);
}
.submit-field small { color: var(--ghost); font-size: 12px; margin-top: 2px; }
.submit-field--file input[type=file] {
  padding: 14px;
  background: var(--cream2);
  border-style: dashed;
  cursor: pointer;
}
.submit-radio {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(232,160,32,.18);
  border-radius: 10px;
  cursor: pointer;
  margin-bottom: 8px;
  transition: border-color .12s ease, background .12s ease;
}
.submit-radio:has(input:checked) { border-color: var(--amber); background: var(--amberL); }
.submit-tos {
  margin: 24px 0 18px;
  color: var(--ghost); font-size: 12px; line-height: 1.55;
  padding: 14px 16px;
  background: var(--cream); border-radius: 10px;
}
.submit-btn { font-size: 15px; padding: 14px 28px; }

@media (max-width: 700px) {
  .submit-grid { grid-template-columns: 1fr; }
  .submit-flow, .submit-form { padding: 24px 20px; }
  .home-plats, .home-market { padding: 64px 20px; }
}

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
.calq-foot {
  text-align: center;
  padding: 32px 16px 48px;
  color: var(--ghost);
  font-size: 12px;
}
.calq-foot a { color: var(--soft); text-decoration: none; }
.calq-foot a:hover { color: var(--amberD); }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media (max-width: 700px) {
  .page { padding: 36px 16px 56px; }
  .calq-nav { padding: 12px 16px; }
  .calq-nav .nav-r { gap: 14px; }
  .calq-nav .nav-r a:not(.nav-cta) { display: none; }
  .calq-sheet { padding: 18px; }
  .calq-row { font-size: 16px; grid-template-columns: 24px minmax(70px, max-content) 1fr; }
  .calq-val--result { font-size: 19px; }
}
