/* contact-canvas.css — shared source of truth for /contact/ canvas rendering.
   Loaded BOTH by the production /contact/ page AND the v3 sandbox so they
   cannot drift. Send-button rules stay separate (different HTML structure
   between sandbox <img class="send-img"> and production <button class="send-btn">).
   Tokens + var defaults + locked-blueprint-driven layout. */

:root {
  color-scheme: light;
  --color-olive-deep: #4A5533;
  --color-ink: #3B2A1C;
  --color-ink-soft: #6B4E3D;
  --color-terracotta: #A8521C;
  --font-cinzel: 'Cinzel', Georgia, serif;
  --font-body: 'Merriweather', Georgia, serif;
  /* Blueprint numbers come only from the locked JSON via JS — no literals here. */
  --send-top: 0px;
  --plaque-w: 0px;
  --plaque-top: 0px;
  --stage-w: 0px;
  --stage-top: 0px;
  --send-w: 0px;
  --fb-top: 0;
  --fb-bottom: 0;
  --fb-left: 0;
  --fb-right: 0;
  --input-h: 0px;
  --input-font: 0px;
  --row-gap: 0px;
  --textarea-h: 0px;
  --humanity-font: 0px;
  --contact-font: 0px;
  --gap-humanity-contact: 0px;
  --footer-bottom-offset: 0px;
  --label-font: 0px;
  --label-input-gap: 0px;
  --gap-phone-email: 0px;
  --col-gap: 0px;
  --line-trunc: 78%;
  --label-offset-x-name: 0px;
  --label-offset-x-email: 0px;
  --label-offset-x-phone: 0px;
  --label-offset-x-website: 0px;
  --label-offset-x-budget: 0px;
  --label-offset-x-timeline: 0px;
  --label-offset-x-project: 0px;
  --budget-select-x: 0px;
}

.stage-wrap {
  position: absolute;
  left: 50%;
  top: var(--stage-top);
  transform: translateX(-50%);
  width: var(--stage-w);
  z-index: 0;
}
.stage-wrap img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  -webkit-user-drag: none;
}

.plaque-wrap {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: var(--plaque-top);
  width: var(--plaque-w);
  z-index: 2;
}
.plaque-wrap img {
  display: block;
  width: 100%;
  height: auto;
}

.form-layer {
  position: absolute;
  z-index: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  top: calc(var(--stage-top) + (var(--stage-w) * 1024 / 1536) * (var(--fb-top) / 100));
  bottom: calc(100% - var(--stage-top) - (var(--stage-w) * 1024 / 1536) * (1 - var(--fb-bottom) / 100));
  left: calc((100% - var(--stage-w)) / 2 + var(--stage-w) * var(--fb-left) / 100);
  width: calc(var(--stage-w) * (var(--fb-right) - var(--fb-left)) / 100);
}

.form-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1 1 auto;
  min-height: 0;
  align-items: stretch;
  padding-bottom: var(--footer-bottom-offset);
}

.field-block {
  display: flex;
  flex-direction: column;
  gap: var(--row-gap);
  flex: 1 1 auto;
}

.row-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  row-gap: 0;
  column-gap: var(--col-gap);
}

.row-full .field { grid-column: 1 / -1; }

.field {
  display: flex;
  flex-direction: column;
  gap: var(--label-input-gap);
}

.field-label {
  font-family: var(--font-cinzel);
  font-weight: 600;
  font-size: var(--label-font);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-ink);
  line-height: 1.1;
}
.field-label[data-field="name"]     { padding-left: var(--label-offset-x-name); }
.field-label[data-field="email"]    { padding-left: var(--label-offset-x-email); }
.field-label[data-field="phone"]    { padding-left: var(--label-offset-x-phone); }
.field-label[data-field="website"]  { padding-left: var(--label-offset-x-website); }
.field-label[data-field="budget"]   { padding-left: var(--label-offset-x-budget); }
.field-label[data-field="timeline"] { padding-left: var(--label-offset-x-timeline); }
.field-label[data-field="project"]  { padding-left: var(--label-offset-x-project); }
.field-label .req { color: var(--color-terracotta); }
.field-label .opt {
  font-family: var(--font-body);
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-ink-soft);
  font-weight: 300;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  height: var(--input-h);
  line-height: calc(var(--input-h) - 8px);
  font-size: var(--input-font);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-ink-soft);
  color: var(--color-ink);
  font-family: var(--font-body);
  padding: 0 0 4px 0;
  outline: none;
}

#f-name {
  margin-left: var(--label-offset-x-name);
  width: calc(100% - var(--label-offset-x-name));
}
#f-phone {
  margin-left: var(--label-offset-x-phone);
  width: calc(100% - var(--label-offset-x-phone));
}
#f-headache {
  margin-left: var(--label-offset-x-project);
  width: calc(100% - var(--label-offset-x-project));
}

.field textarea {
  height: var(--textarea-h);
  line-height: 1.35;
  resize: none;
  border-bottom: 0;
  background-image:
    linear-gradient(to right, var(--color-ink-soft) 0, var(--color-ink-soft) var(--line-trunc), transparent var(--line-trunc), transparent 100%),
    linear-gradient(to right, var(--color-ink-soft), var(--color-ink-soft));
  background-position:
    0 calc(2 * 1.35 * var(--input-font)),
    0 calc(1 * 1.35 * var(--input-font));
  background-size: 100% 1px, 100% 1px;
  background-repeat: no-repeat, no-repeat;
}

.field select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A8521C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left 4px bottom 8px;
  padding: calc(var(--input-h) - var(--input-font) - 4px) 0 4px 22px;
  line-height: var(--input-font);
}
.field select[data-field="budget"] {
  margin-left: var(--budget-select-x);
  width: calc(100% - var(--budget-select-x));
}

.contact-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--gap-humanity-contact);
  flex-shrink: 0;
}
.footer-line-caps {
  font-family: var(--font-cinzel);
  font-weight: 600;
  font-size: var(--humanity-font);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-ink);
}
.footer-line-row {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--gap-phone-email);
}
.footer-sep {
  color: var(--color-ink-soft);
  font-family: var(--font-body);
  font-size: var(--contact-font);
}
.footer-line-link {
  color: var(--color-terracotta);
  text-decoration: underline;
  font-family: var(--font-body);
  font-size: var(--contact-font);
}
.footer-line-link:hover { color: #c96a32; }
