/* ── Valiquity Valuation Tool v5.1 ── */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');
:root {
    --vt-blue: #3B82F6;
    --vt-blue-hover: #2563EB;
    --vt-blue-bg: #EFF6FF;
    --vt-green: #10B981;
    --vt-green-bg: #ECFDF5;
    --vt-navy: #1E293B;
    --vt-brown: #8B572A;
    --vt-bg: #F8F7F4;
    --vt-card: #ffffff;
    --vt-border: #C4CDD8;
    --vt-border-hover: #94A3B8;
    --vt-text: #1E293B;
    --vt-muted: #64748B;
    --vt-danger: #EF4444;
    --vt-radius: 14px;
    --vt-radius-sm: 10px;
}
.vt-wrap { max-width: 780px; margin: 16px auto; padding: 0 24px; font-family: 'DM Sans', -apple-system, sans-serif; color: var(--vt-text); line-height: 1.6; box-sizing: border-box; overflow-x: hidden; }
.vt-wrap *, .vt-wrap *::before, .vt-wrap *::after { box-sizing: border-box; }
.vt-topbar { display: none; align-items: center; gap: 12px; margin-bottom: 20px; }
.vt-progress-track { flex: 1; height: 7px; background: var(--vt-border); border-radius: 6px; overflow: hidden; }
.vt-progress-fill { height: 100%; width: 0%; background: var(--vt-blue); border-radius: 6px; transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }
.vt-progress-pct { font-family: 'Space Mono', monospace; font-size: 14px; font-weight: 700; color: var(--vt-blue); min-width: 36px; text-align: right; }
.vt-screen { display: none; }
.vt-screen.active { display: block; animation: vtSlideIn 0.3s ease; }
.vt-screen.active.vt-no-anim { animation: none; }
.vt-wrap.vt-loading { max-height: 100vh; overflow: hidden; }
@keyframes vtSlideIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.vt-time-badge { display: inline-block; font-size: 15px; font-weight: 600; color: var(--vt-green); background: var(--vt-green-bg); padding: 6px 16px; border-radius: 20px; margin-bottom: 12px; }
.vt-heading { font-size: 34px !important; font-weight: 700 !important; color: var(--vt-navy) !important; margin: 0 0 8px !important; line-height: 1.2 !important; letter-spacing: -0.4px; }
.vt-question { font-size: 17px !important; color: var(--vt-muted) !important; margin: 0 0 20px !important; font-weight: 400 !important; line-height: 1.5 !important; }
.vt-question strong { color: var(--vt-blue); font-weight: 600; }
.vt-cards { display: flex; flex-direction: column; gap: 10px; margin-bottom: 8px; }
.vt-cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.vt-cards-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; align-items: stretch; }
.vt-cards-row { display: flex; flex-direction: row; flex-wrap: wrap; gap: 10px; align-items: stretch; }
.vt-cards-sm .vt-card { min-height: auto; }
.vt-card { position: relative; cursor: pointer; }
.vt-card input[type="radio"] { position: absolute; opacity: 0; width: 0; height: 0; }
.vt-card-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; background: var(--vt-card); border: 1.5px solid var(--vt-border); border-radius: var(--vt-radius-sm); transition: all 0.2s ease; gap: 12px; }
.vt-card:hover .vt-card-inner { border-color: var(--vt-border-hover); background: #F8FAFC; }
.vt-card input:checked + .vt-card-inner { border-color: var(--vt-blue); background: var(--vt-blue-bg); box-shadow: 0 0 0 1px var(--vt-blue); }
.vt-card-label { font-size: 16px; font-weight: 500; color: var(--vt-text); }
.vt-card input:checked + .vt-card-inner .vt-card-label { color: var(--vt-blue); font-weight: 600; }
.vt-card-inner::after { content: ''; width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--vt-border); flex-shrink: 0; transition: all 0.2s ease; box-sizing: border-box; }
.vt-card input:checked + .vt-card-inner::after { border-color: var(--vt-blue); background: var(--vt-blue); box-shadow: inset 0 0 0 3px #fff; }
.vt-cards-grid-3 .vt-card-inner { padding: 12px 14px; min-height: 52px; }
.vt-cards-grid-3 .vt-card-label { font-size: 14px; flex: 1; line-height: 1.3; }
.vt-cards-grid-3 .vt-card-inner::after { width: 18px; height: 18px; flex-shrink: 0; align-self: center; }
.vt-cards-grid-3 .vt-card { display: flex; }
.vt-cards-grid-3 .vt-card-inner { flex: 1; align-items: center; gap: 8px; }
.vt-card-compact { flex: 1; min-width: 100px; display: flex; flex-direction: column; }
.vt-card-compact .vt-card-inner { flex: 1; flex-direction: column; justify-content: center; text-align: center; padding: 14px 10px; gap: 4px; }
.vt-card-compact .vt-card-inner::after { display: none; }
.vt-card-icon { font-size: 24px; font-weight: 700; color: var(--vt-muted); }
.vt-card input:checked + .vt-card-inner .vt-card-icon { color: var(--vt-blue); }
.vt-card-compact .vt-card-label { font-size: 16px; font-weight: 600; }
.vt-card-sub { font-size: 13px; color: var(--vt-muted); font-weight: 400; }
.vt-field { margin-bottom: 20px; }
.vt-hidden { display: none; }
.vt-field.vt-revealing { display: block; animation: vtReveal 0.35s ease forwards; }
@keyframes vtReveal { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.vt-label { display: block; font-size: 16px !important; font-weight: 600 !important; color: var(--vt-text) !important; margin-bottom: 6px !important; }
.vt-input { width: 100%; max-width: 100%; padding: 14px 16px; font-size: 17px; font-family: 'DM Sans', sans-serif; color: var(--vt-text); background: var(--vt-card); border: 1.5px solid #CBD5E1 !important; border-radius: var(--vt-radius-sm); transition: border-color 0.2s, box-shadow 0.2s; box-sizing: border-box; -webkit-appearance: none; }
.vt-input:focus { outline: none; border-color: var(--vt-blue) !important; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }
.vt-input::placeholder { color: #94A3B8; }
.vt-input.vt-err { border-color: var(--vt-danger); box-shadow: 0 0 0 3px rgba(239,68,68,0.08); }
.vt-select { appearance: auto; cursor: pointer; }
.vt-input-box { position: relative; display: flex; align-items: center; }
.vt-input-box .vt-input { padding-left: 40px; font-family: 'Space Mono', monospace; font-size: 17px; letter-spacing: 0.5px; }
.vt-pre { position: absolute; left: 14px; font-size: 17px; color: var(--vt-muted); font-weight: 600; pointer-events: none; z-index: 1; }
.vt-hint { display: block; font-size: 14px !important; color: var(--vt-muted) !important; margin-top: 6px !important; font-weight: 400 !important; line-height: 1.5 !important; }
.vt-nav { display: flex; gap: 12px; margin-top: 24px; }
.vt-nav-center { justify-content: center; }
.vt-next { flex: 1; padding: 16px 28px; font-size: 17px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: var(--vt-navy); color: #fff; border: none; border-radius: var(--vt-radius-sm); cursor: pointer; transition: all 0.2s ease; }
.vt-next:hover { background: #334155; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(30,41,59,0.15); }
.vt-next-go { background: var(--vt-green); }
.vt-next-go:hover { background: #059669; }
.vt-back { padding: 16px 24px; font-size: 17px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: transparent; color: var(--vt-muted); border: 1.5px solid var(--vt-border); border-radius: var(--vt-radius-sm); cursor: pointer; transition: all 0.2s ease; white-space: nowrap; }
.vt-back:hover { background: #F8FAFC; border-color: var(--vt-border-hover); color: var(--vt-text); }
.vt-spinner { width: 18px; height: 18px; border: 2.5px solid rgba(255,255,255,0.3); border-top-color: #fff; border-radius: 50%; animation: vtSpin 0.6s linear infinite; display: inline-block; vertical-align: middle; margin-left: 8px; }
@keyframes vtSpin { to { transform: rotate(360deg); } }
.vt-review { background: #F8FAFC; border: 1.5px solid var(--vt-border); border-radius: var(--vt-radius); padding: 20px 24px; margin-bottom: 8px; overflow-x: auto; }
.vt-review table { width: 100%; border-collapse: collapse; table-layout: fixed; word-wrap: break-word; }
.vt-review td { padding: 8px 0; font-size: 16px !important; vertical-align: middle; }
.vt-review td:first-child { color: var(--vt-muted); width: 38%; }
.vt-review td:last-child { font-weight: 600; text-align: right; display: flex; justify-content: flex-end; align-items: center; gap: 6px; flex-wrap: wrap; }
.vt-result-badge { display: inline-block; font-size: 14px; font-weight: 700; color: var(--vt-green); background: var(--vt-green-bg); padding: 6px 18px; border-radius: 20px; margin-bottom: 10px; }
.vt-hero { text-align: center; padding: 32px 24px; margin: 20px 0; background: var(--vt-navy); border-radius: var(--vt-radius); color: #fff; }
.vt-hero-label { display: block; font-size: 13px; font-weight: 500; opacity: 0.7; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 8px; }
.vt-hero-num { display: block; font-family: 'DM Sans', -apple-system, sans-serif; font-size: 28px; font-weight: 700; line-height: 1.2; margin-bottom: 8px; word-break: break-all; overflow: visible; }
.vt-hero-range { display: block; font-size: 13px; opacity: 0.65; }
/* ── Normalisation Banner ── */
.vt-normalise-banner { display: flex; gap: 14px; align-items: flex-start; background: #F0F7FF; border: 1.5px solid #BFDBFE; border-radius: var(--vt-radius-sm); padding: 16px 18px; margin-top: 24px; }
.vt-normalise-icon { font-size: 20px; color: var(--vt-blue); flex-shrink: 0; margin-top: 1px; }
.vt-normalise-body { flex: 1; }
.vt-normalise-title { font-size: 14px !important; font-weight: 700 !important; color: var(--vt-navy) !important; margin: 0 0 4px !important; line-height: 1.4 !important; }
.vt-normalise-text { font-size: 13px !important; color: var(--vt-muted) !important; margin: 0 0 10px !important; line-height: 1.5 !important; }
.vt-normalise-btn { display: inline-block; padding: 7px 18px; font-size: 13px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: #023a51; color: #fff !important; border-radius: 6px; text-decoration: none !important; transition: background 0.2s; }
.vt-normalise-btn:hover { background: #034b68; color: #fff !important; }

/* ── Industry Examples (US-listed companies) — Desktop tooltip ── */
.vt-ind-card { position: relative; overflow: visible; }
.vt-ind-tooltip {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: var(--vt-navy);
    color: #fff;
    padding: 10px 14px;
    border-radius: 8px;
    width: max-content;
    max-width: 320px;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.18);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    z-index: 50;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
    text-align: left;
}
.vt-ind-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--vt-navy);
}
.vt-ind-card:hover .vt-ind-tooltip,
.vt-ind-card:focus-within .vt-ind-tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}
.vt-ind-tooltip-label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 4px;
}
.vt-ind-tooltip-list {
    display: block;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
    color: #fff;
}
/* Wrapper around label + (mobile) examples — flex behaviour for proper stacking */
.vt-ind-text { display: flex; flex-direction: column; flex: 1; min-width: 0; gap: 2px; }
.vt-ind-text > .vt-card-label { flex: none; }
/* Hidden by default on desktop — only used on mobile */
.vt-ind-examples-mobile { display: none; }

/* Edge-of-grid tooltip clipping fix: visible first/last column cards get tooltip anchored to their edge.
   Classes vt-col-first / vt-col-last are set by JS based on visible position, since the DOM contains
   all 94 cards at once and :nth-child can't tell which are currently visible. */
.vt-ind-card.vt-col-first .vt-ind-tooltip { left: 0; right: auto; transform: translateX(0) translateY(4px); }
.vt-ind-card.vt-col-first .vt-ind-tooltip::after { left: 24px; right: auto; transform: translateX(0); }
.vt-ind-card.vt-col-first:hover .vt-ind-tooltip,
.vt-ind-card.vt-col-first:focus-within .vt-ind-tooltip { transform: translateX(0) translateY(0); }
.vt-ind-card.vt-col-last .vt-ind-tooltip { left: auto; right: 0; transform: translateX(0) translateY(4px); }
.vt-ind-card.vt-col-last .vt-ind-tooltip::after { left: auto; right: 24px; transform: translateX(0); }
.vt-ind-card.vt-col-last:hover .vt-ind-tooltip,
.vt-ind-card.vt-col-last:focus-within .vt-ind-tooltip { transform: translateX(0) translateY(0); }
/* ── Disclaimer paragraphs ── */
.vt-disclaimer p { margin: 0 !important; font-size: 12px !important; color: var(--vt-muted) !important; line-height: 1.6 !important; }
.vt-methods { display: grid; gap: 12px; margin: 20px 0; }
.vt-methods-3col { grid-template-columns: 1fr 1fr 1fr; }
.vt-methods-2col { grid-template-columns: 1fr 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
.vt-methods-1col { grid-template-columns: 1fr; max-width: 240px; margin-left: auto; margin-right: auto; }
.vt-method-card { background: var(--vt-card); border: 1.5px solid var(--vt-border); border-radius: var(--vt-radius); padding: 18px 16px; text-align: center; }
.vt-method-card h4 { font-size: 12px !important; font-weight: 600 !important; color: var(--vt-muted) !important; text-transform: uppercase; letter-spacing: 0.8px; margin: 0 0 8px !important; }
.vt-method-value { font-family: 'DM Sans', -apple-system, sans-serif; font-size: 15px; font-weight: 700; color: var(--vt-navy); margin-bottom: 4px; line-height: 1.4; word-break: break-word; }
.vt-method-range { font-size: 11px; color: var(--vt-muted); letter-spacing: 0.3px; }
.vt-sources { display: none; }
.vt-email-sent { text-align: center; padding: 16px; background: var(--vt-green-bg); border: 1px solid #A7F3D0; border-radius: var(--vt-radius-sm); margin: 16px 0; }
.vt-email-sent p { font-size: 15px !important; color: #065F46 !important; margin: 0 !important; }
.vt-btn-download { flex: 1; padding: 15px 20px; font-size: 16px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: #023a51; color: #ffffff !important; border: 2px solid #023a51; border-radius: var(--vt-radius-sm); cursor: pointer; transition: all 0.2s ease; text-align: center; }
.vt-btn-download:hover { background: #034b68; border-color: #034b68; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(2,58,81,0.25); }
.vt-report-actions { display: flex; gap: 12px; margin: 20px 0 0; }
.vt-btn-view { flex: 1; padding: 14px 20px; font-size: 16px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: #ffffff; color: #023a51; border: 2px solid #023a51; border-radius: var(--vt-radius-sm); cursor: pointer; transition: all 0.2s ease; text-align: center; }
.vt-btn-view:hover { background: #f0f7ff; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(2,58,81,0.12); }
.vt-btn-download { flex: 1; padding: 14px 20px; font-size: 16px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: #023a51; color: #ffffff; border: 2px solid #023a51; border-radius: var(--vt-radius-sm); cursor: pointer; transition: all 0.2s ease; text-align: center; }
.vt-btn-download:hover { background: #034b68; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(2,58,81,0.25); }
@media (max-width: 480px) { .vt-report-actions { flex-direction: column; } }
.vt-warnings { background: #FFFBEB; border: 1px solid #FDE68A; border-radius: var(--vt-radius-sm); padding: 14px 18px; margin: 14px 0; font-size: 14px !important; color: #92400E !important; line-height: 1.5 !important; }
.vt-warnings p { margin: 4px 0 !important; }
.vt-cta-prominent { margin: 24px 0; padding: 32px; background: linear-gradient(135deg, #f0f7ff 0%, #e8f4f8 100%); border: 2px solid #023a51; border-radius: var(--vt-radius); text-align: center; }
.vt-cta-prominent h3 { font-size: 24px !important; font-weight: 700 !important; color: #023a51 !important; margin: 0 0 12px !important; line-height: 1.3 !important; }
.vt-cta-prominent p { font-size: 16px !important; color: var(--vt-muted) !important; margin: 0 0 20px !important; line-height: 1.6 !important; max-width: 520px; margin-left: auto !important; margin-right: auto !important; }
.vt-cta-btn-primary { display: inline-block; padding: 16px 40px; font-size: 18px; font-weight: 600; font-family: 'DM Sans', sans-serif; background: #023a51; color: #fff !important; border-radius: var(--vt-radius-sm); text-decoration: none !important; transition: all 0.2s ease; letter-spacing: 0.3px; }
.vt-cta-btn-primary:hover { background: #034b68; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(2,58,81,0.25); color: #fff !important; }
.vt-disclaimer { margin-top: 28px; padding: 16px 20px; background: #F8FAFC; border: 1px solid var(--vt-border); border-radius: var(--vt-radius-sm); font-size: 12px !important; color: var(--vt-muted) !important; line-height: 1.6 !important; }
.vt-disclaimer strong { font-weight: 600 !important; color: var(--vt-text) !important; font-size: 12px !important; }
@media (max-width: 768px) {
    .vt-wrap { padding: 0 16px; margin: 8px auto; max-width: 100%; }
    .vt-heading { font-size: 24px !important; line-height: 1.3 !important; }
    .vt-question { font-size: 15px !important; margin-bottom: 16px !important; }
    .vt-time-badge { font-size: 13px; padding: 5px 12px; }
    .vt-cards-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .vt-cards-grid-3 { grid-template-columns: 1fr 1fr; gap: 8px; }
    .vt-cards-grid-3 .vt-card-label { font-size: 13px; }
    .vt-cards-grid-3 .vt-card-inner { padding: 10px 12px; min-height: 44px; align-items: center; }
    /* Mobile: hide the hover tooltip (no hover on touch), show examples as a subtitle */
    .vt-ind-tooltip { display: none !important; }
    .vt-ind-examples-mobile {
        display: block;
        font-size: 11px;
        font-weight: 400;
        color: var(--vt-muted);
        line-height: 1.35;
    }
    .vt-card input:checked + .vt-card-inner .vt-ind-examples-mobile { color: var(--vt-blue); opacity: 0.85; }
    .vt-cards-row { flex-direction: row; flex-wrap: wrap; gap: 8px; }
    .vt-card-compact { min-width: 0; flex: 1 1 45%; }
    .vt-card-compact .vt-card-inner { padding: 12px 8px; }
    .vt-card-compact .vt-card-label { font-size: 14px; }
    .vt-card-sub { font-size: 11px; }
    .vt-card-icon { font-size: 20px; }
    .vt-card-inner { padding: 11px 14px; }
    .vt-card-label { font-size: 14px; }
    .vt-card-inner::after { width: 18px; height: 18px; }
    .vt-label { font-size: 14px !important; }
    .vt-input { font-size: 16px !important; padding: 12px 14px; }
    .vt-input-box .vt-input { padding-left: 34px; font-size: 16px !important; }
    .vt-pre { font-size: 15px; left: 12px; }
    .vt-hint { font-size: 12px !important; }
    .vt-select { font-size: 15px !important; }
    .vt-nav { flex-direction: column; gap: 10px; margin-top: 20px; }
    .vt-next, .vt-back { width: 100%; text-align: center; padding: 14px 20px; font-size: 15px; }
    .vt-methods-3col, .vt-methods-2col { grid-template-columns: 1fr; }
    .vt-hero { padding: 24px 16px; margin: 16px 0; }
    .vt-hero-num { font-size: 20px; }
    .vt-hero-range { font-size: 12px; }
    .vt-hero-label { font-size: 11px; }
    .vt-method-card { padding: 14px 12px; }
    .vt-method-value { font-size: 17px; }
    .vt-review { padding: 14px 16px; }
    .vt-review td { font-size: 14px !important; padding: 6px 0; }
    .vt-cta-prominent { padding: 20px 16px; margin: 16px 0; }
    .vt-cta-prominent h3 { font-size: 20px !important; }
    .vt-cta-prominent p { font-size: 14px !important; }
    .vt-cta-btn-primary { padding: 14px 24px; font-size: 16px; width: 100%; text-align: center; display: block; }
    .vt-topbar { margin-bottom: 14px; }
    .vt-progress-pct { font-size: 12px; }
    .vt-disclaimer { padding: 12px 14px; font-size: 11px !important; }
}
@media (max-width: 380px) {
    .vt-heading { font-size: 21px !important; }
    .vt-cards-grid { grid-template-columns: 1fr; }
    .vt-cards-grid-3 { grid-template-columns: 1fr; }
    .vt-card-compact { flex: 1 1 100%; }
    .vt-hero-num { font-size: 22px; }
}
/* ── Valuation Results Table ── */
.vt-val-table-wrap { overflow-x: auto; margin: 20px 0; -webkit-overflow-scrolling: touch; }
.vt-val-table { width: 100%; border-collapse: collapse; font-size: 14px; min-width: 580px; }
.vt-val-table thead th { background: var(--vt-navy); color: #fff; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; padding: 10px 12px; text-align: left; white-space: nowrap; }
.vt-val-table thead th:nth-child(n+2) { text-align: center; }
.vt-val-table thead th:nth-child(n+4) { text-align: right; }
.vt-val-table tbody td { padding: 10px 12px; border-bottom: 1px solid var(--vt-border); font-size: 14px; }
.vt-val-table tbody tr:nth-child(even) { background: #F8FAFC; }
.vt-vt-method { font-weight: 500; color: var(--vt-navy); }
.vt-vt-center { text-align: center !important; }
.vt-vt-right { text-align: right !important; font-family: 'Space Mono', monospace; font-size: 13px; }
.vt-vt-blended { background: #E8F4F8 !important; border-top: 2px solid var(--vt-navy); }
.vt-vt-blended td { padding: 12px 12px; }
@media (max-width: 768px) {
    .vt-val-table { font-size: 12px; }
    .vt-val-table thead th { font-size: 10px; padding: 8px 8px; }
    .vt-val-table tbody td { padding: 8px 8px; font-size: 12px; }
    .vt-vt-right { font-size: 11px; }
}
