/* 3D Marvels Instant Quote — mobile-first, matches 3dmarvels.ie
   Brand: orange #FFAA33 / #E98C00, charcoal #1D2327, Helvetica, pill buttons. */

.tdm-quote {
    --tdm-orange: #ffaa33;
    --tdm-orange-dark: #e98c00;
    --tdm-ink: #1d2327;
    --tdm-line: #e6e4dc;
    --tdm-muted: #777;
    max-width: 480px;
    margin: 0 auto;
    font-family: Helvetica, Arial, Verdana, sans-serif;
    color: var(--tdm-ink);
    box-sizing: border-box;
}
.tdm-quote *, .tdm-quote *::before, .tdm-quote *::after { box-sizing: inherit; }

.tdm-title { font-size: 22px; font-weight: 700; color: var(--tdm-orange-dark); margin: 0 0 14px; }
.tdm-step { margin-bottom: 4px; }
.tdm-step-label { font-size: 14px; font-weight: 700; margin: 16px 0 8px; }

/* Card grids */
.tdm-cards { display: grid; gap: 7px; }
.tdm-cards.tdm-2 { grid-template-columns: 1fr 1fr; }
.tdm-cards.tdm-3 { grid-template-columns: 1fr 1fr 1fr; }
.tdm-card {
    border: 2px solid var(--tdm-line); border-radius: 11px; padding: 10px 4px;
    text-align: center; cursor: pointer; background: #fff; color: var(--tdm-ink);
    font-family: inherit; font-size: 13px; font-weight: 700; position: relative;
    transition: border-color .12s, background .12s;
}
.tdm-card:hover { border-color: var(--tdm-orange); }
.tdm-card.tdm-sel { background: var(--tdm-orange); border-color: var(--tdm-orange); color: var(--tdm-ink); }
.tdm-card.tdm-soon { opacity: .45; cursor: not-allowed; color: #999; }
.tdm-card.tdm-soon:hover { border-color: var(--tdm-line); }
.tdm-soon-badge { display: block; font-size: 9px; font-weight: 700; color: var(--tdm-orange-dark); margin-top: 1px; }
.tdm-card .tdm-card-sub { display: block; font-size: 10px; font-weight: 400; opacity: .7; margin-top: 1px; }

/* Upload */
.tdm-dropzone {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center; gap: 4px; cursor: pointer; margin-top: 14px;
    border: 2px dashed var(--tdm-orange); border-radius: 14px;
    background: #fff8ee; padding: 26px 14px; transition: background .15s;
}
.tdm-dropzone.tdm-drag { background: #ffeccc; }
.tdm-dz-icon { font-size: 32px; line-height: 1; color: var(--tdm-orange-dark); }
.tdm-dz-title { font-size: 15px; font-weight: 700; }
.tdm-dz-hint { font-size: 12px; color: var(--tdm-muted); }
.tdm-file {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    background: #f1efe8; border-radius: 10px; padding: 10px 12px; margin-top: 14px;
}
.tdm-file-name { font-size: 14px; font-weight: 700; word-break: break-all; }
.tdm-file-remove { background: none; border: none; font-size: 22px; line-height: 1; cursor: pointer; color: var(--tdm-muted); }

/* Colour swatches */
.tdm-colours { display: flex; gap: 11px; align-items: center; flex-wrap: wrap; }
.tdm-swatch {
    width: 32px; height: 32px; border-radius: 50%; border: 3px solid #fff;
    outline: 1px solid var(--tdm-line); cursor: pointer; padding: 0;
    transition: transform .1s;
}
.tdm-swatch:hover { transform: scale(1.12); }
.tdm-swatch.tdm-sel { outline: none; border-color: var(--tdm-orange); box-shadow: 0 0 0 2px var(--tdm-orange); }

/* Quantity */
.tdm-qty { display: flex; align-items: center; gap: 14px; }
.tdm-qty button {
    width: 38px; height: 38px; border-radius: 10px; border: 2px solid var(--tdm-line);
    background: #fff; font-size: 20px; font-weight: 700; cursor: pointer; color: var(--tdm-ink);
}
.tdm-qty button:hover { border-color: var(--tdm-orange); }
.tdm-qty input {
    width: 64px; height: 38px; text-align: center; font-size: 16px; font-weight: 700;
    font-family: inherit; color: var(--tdm-ink); border: 2px solid var(--tdm-line);
    border-radius: 10px; background: #fff; -moz-appearance: textfield;
}
.tdm-qty input:focus { outline: none; border-color: var(--tdm-orange); }
.tdm-qty input::-webkit-outer-spin-button, .tdm-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Advanced link + help */
.tdm-advanced-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; color: var(--tdm-orange-dark); font-size: 12px; font-weight: 700; text-decoration: none; }
.tdm-help { border-top: 1px solid #eee; margin-top: 16px; padding-top: 12px; text-align: center; }
.tdm-help p { font-size: 12px; color: #555; margin: 0 0 8px; }
.tdm-help-icons { display: flex; justify-content: center; gap: 10px; }
.tdm-help-btn { width: 38px; height: 38px; border-radius: 50%; background: #f1efe8; display: flex; align-items: center; justify-content: center; color: var(--tdm-ink); font-size: 19px; text-decoration: none; }
.tdm-help-btn.tdm-wa { background: #e7f7ee; color: #0f9f4f; }
.tdm-help-btn.tdm-call { background: #fff3df; color: var(--tdm-orange-dark); }

/* Buttons */
.tdm-btn { width: 100%; border: none; border-radius: 30px; padding: 14px; margin-top: 14px; font-size: 15px; font-weight: 700; font-family: inherit; cursor: pointer; }
.tdm-btn-primary { background: var(--tdm-orange); color: var(--tdm-ink); }
.tdm-btn-primary:hover { background: var(--tdm-orange-dark); }
.tdm-btn:disabled { opacity: .5; cursor: not-allowed; }

/* Loading + error */
.tdm-loading-state { text-align: center; padding: 24px 10px; }
.tdm-spinner { display: inline-block; width: 32px; height: 32px; border-radius: 50%; border: 4px solid #f1e3cc; border-top-color: var(--tdm-orange-dark); animation: tdm-spin 1s linear infinite; }
@keyframes tdm-spin { to { transform: rotate(360deg); } }
.tdm-loading-title { font-size: 15px; font-weight: 700; margin: 10px 0 2px; }
.tdm-loading-hint { font-size: 12px; color: var(--tdm-muted); margin: 0; }
.tdm-error { background: #fdecec; border: 1px solid #e2a0a0; color: #a32d2d; border-radius: 10px; padding: 10px 12px; font-size: 13px; margin-top: 12px; }

/* Result */
.tdm-result { margin-top: 16px; }
.tdm-estimate-note { display: flex; gap: 8px; align-items: flex-start; background: #fff3df; border: 1px solid var(--tdm-orange); border-radius: 10px; padding: 10px 12px; font-size: 12px; color: #8a5a00; margin-bottom: 12px; }
.tdm-estimate-note .ti { font-size: 16px; }
.tdm-tier { display: flex; align-items: center; justify-content: space-between; width: 100%; border: 2px solid var(--tdm-line); border-radius: 14px; padding: 12px 14px; cursor: pointer; margin-bottom: 10px; background: #fff; font-family: inherit; text-align: left; }
.tdm-tier:hover { border-color: var(--tdm-orange); }
.tdm-tier.tdm-sel { border-color: var(--tdm-orange); background: #fff8ee; }
.tdm-tier-name { font-size: 14px; font-weight: 700; display: block; }
.tdm-tier-lead { font-size: 11px; color: var(--tdm-muted); display: block; margin-top: 2px; }
.tdm-tier-price { font-size: 23px; font-weight: 700; }
.tdm-urgent { color: var(--tdm-orange-dark); }
.tdm-vat-note, .tdm-postproc-note { font-size: 10px; color: #999; text-align: center; margin: 6px 0 0; line-height: 1.5; }
.tdm-tier.tdm-static { cursor: default; }
.tdm-tier.tdm-static:hover { border-color: var(--tdm-line); }

/* Instant order */
.tdm-good { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: #0f9f4f; margin: 0 0 14px; }
.tdm-instant-total { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; padding: 12px 14px; border: 2px solid var(--tdm-orange); border-radius: 14px; background: #fff8ee; }
.tdm-instant-total span:first-child { font-size: 13px; font-weight: 700; }
.tdm-instant-total span:last-child { font-size: 26px; font-weight: 700; color: var(--tdm-ink); }

/* Quote request form */
.tdm-request-intro { font-size: 13px; font-weight: 700; margin: 16px 0 8px; }
.tdm-fields { display: flex; flex-direction: column; gap: 8px; }
.tdm-fields input, .tdm-fields textarea {
    width: 100%; border: 2px solid var(--tdm-line); border-radius: 10px; padding: 11px 12px;
    font-family: inherit; font-size: 14px; color: var(--tdm-ink); background: #fff;
}
.tdm-fields input:focus, .tdm-fields textarea:focus { outline: none; border-color: var(--tdm-orange); }

/* Confirmation */
.tdm-done { text-align: center; padding: 24px 12px; }
.tdm-done .ti { font-size: 40px; color: #0f9f4f; }
.tdm-done-title { font-size: 18px; font-weight: 700; margin: 8px 0 2px; }
.tdm-done-msg { font-size: 13px; color: var(--tdm-muted); margin: 0; }
.tdm-reset-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; background: none; border: none; color: var(--tdm-orange-dark); font-family: inherit; font-size: 13px; font-weight: 700; cursor: pointer; }
.tdm-reset-link:hover { text-decoration: underline; }
