/* compliance.css — Merged from eu-ai-act.css + corp.css + pricing.css */
.compliance-wrap { max-width: 900px; margin: 0 auto; padding: 0 1.5rem 5rem; }

/* Hero */
.compliance-hero { padding: 3rem 0 2rem; border-bottom: 2px solid var(--border); margin-bottom: 2.5rem; }
.compliance-hero h1 { font-size: 2.2rem; letter-spacing: -0.03em; margin-bottom: 0.5rem; }
.compliance-hero .subtitle { font-size: 1.05rem; color: var(--text-dim); line-height: 1.7; max-width: 640px; }
.compliance-hero .frame-line { font-size: 0.78rem; color: var(--text-faint); font-family: var(--font-mono); margin-top: 1rem; letter-spacing: 0.04em; }

/* Urgency banner */
.compliance-urgency {
    border: 2px solid var(--border); margin: 0 0 2.5rem;
    display: grid; grid-template-columns: 1fr 1fr; background: var(--surface-2);
}
.urgency-col { padding: 1.25rem; }
.urgency-col:first-child { border-right: 2px solid var(--border); }
.urgency-date {
    font-family: var(--font-display); font-weight: 900; font-size: 2rem;
    letter-spacing: -0.03em; line-height: 1; margin-bottom: 0.3rem;
}
.urgency-label {
    font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.1em; color: var(--text-faint); margin-bottom: 0.4rem;
}
.urgency-col p { font-size: 0.82rem; color: var(--text-dim); line-height: 1.5; margin: 0; }

/* Timeline bar (from eu-ai-act) */
.deadline-bar {
    border: 2px solid var(--border); margin: 1.5rem 0;
    display: grid; grid-template-columns: repeat(3, 1fr);
}
.deadline-col { padding: 1.1rem 1.25rem; border-right: 2px solid var(--border); }
.deadline-col:last-child { border-right: none; }
.deadline-col.active-now { background: var(--surface-2); }
.deadline-date {
    font-family: var(--font-mono); font-size: 0.72rem; font-weight: 700;
    color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.35rem;
}
.deadline-col h3 { font-size: 0.92rem; margin-bottom: 0.3rem; }
.deadline-col p { font-size: 0.8rem; color: var(--text-dim); line-height: 1.5; margin: 0; }
.status-pill {
    display: inline-block; font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.08em; padding: 0.15rem 0.5rem; border: 1px solid var(--text-faint); margin-bottom: 0.4rem;
}
.status-pill.in-force { border-color: var(--danger, #c0392b); color: var(--danger, #c0392b); }
.status-pill.coming { border-color: var(--text); color: var(--text); }

/* Penalty grid */
.penalty-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    border: 2px solid var(--border); margin: 1.5rem 0;
}
.penalty-cell { padding: 1.25rem; border-right: 2px solid var(--border); text-align: center; }
.penalty-cell:last-child { border-right: none; }
.penalty-amount {
    font-family: var(--font-display); font-weight: 900; font-size: 1.6rem;
    letter-spacing: -0.03em; line-height: 1.1; display: block; margin-bottom: 0.3rem;
}
.penalty-pct { font-size: 0.8rem; color: var(--text-dim); margin-bottom: 0.4rem; }
.penalty-applies { font-size: 0.75rem; color: var(--text-faint); line-height: 1.4; }

/* Assessment tiers (from corp) */
.tier-strip {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border: 2px solid var(--border); margin: 2.5rem 0;
}
.tier-col { padding: 1.5rem; border-right: 2px solid var(--border); }
.tier-col:last-child { border-right: none; }
.tier-col.featured { background: var(--surface-2); }
.tier-label {
    font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.1em; color: var(--text-faint); margin-bottom: 0.5rem;
}
.tier-col h3 { font-size: 1.05rem; margin-bottom: 0.25rem; }
.tier-price {
    font-family: var(--font-mono); font-size: 1.2rem; font-weight: 700; margin: 0.5rem 0 0.75rem;
}
.tier-col ul { list-style: none; padding: 0; margin: 0; }
.tier-col li {
    color: var(--text-dim); font-size: 0.82rem; padding: 0.3rem 0 0.3rem 1rem;
    position: relative; line-height: 1.5;
}
.tier-col li::before { content: "+"; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.tier-col .tier-note { font-size: 0.75rem; color: var(--text-faint); margin-top: 0.75rem; padding-top: 0.5rem; border-top: 1px solid var(--border); }

/* Void Model Card */
.void-model-card { border: 2px solid var(--border); margin: 1.5rem 0; background: var(--bg-card); }
.vmc-header { display: flex; justify-content: space-between; align-items: center; padding: 0.75rem 1.25rem; border-bottom: 1px solid var(--border); background: var(--surface-2); }
.vmc-title { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; color: var(--text-faint); }
.vmc-status { font-size: 0.65rem; font-weight: 700; padding: 0.15rem 0.5rem; border-radius: 3px; }
.vmc-status-certified { background: rgba(0,200,83,0.15); color: var(--green); }
.vmc-body { padding: 1rem 1.25rem; }
.vmc-row { display: flex; justify-content: space-between; padding: 0.35rem 0; font-size: 0.82rem; border-bottom: 1px solid rgba(255,255,255,0.04); }
.vmc-label { color: var(--text-faint); }
.vmc-value { color: var(--text); }
.vmc-score { font-family: var(--font-mono); font-size: 1.1rem; font-weight: 700; color: var(--green); }
.vmc-dims { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; padding: 0.75rem 0; }
.vmc-dim { text-align: center; font-size: 0.82rem; }
.vmc-dim-label { display: block; font-size: 0.68rem; color: var(--text-faint); }
.vmc-dim-value { font-family: var(--font-mono); font-weight: 700; }
.vmc-footer { padding: 0.5rem 1.25rem; border-top: 1px solid var(--border); font-size: 0.72rem; color: var(--text-faint); }

/* Annex grid (from eu-ai-act) */
.annex-grid { margin: 1.5rem 0; border: 2px solid var(--border); }
.annex-row { display: grid; grid-template-columns: 50px 160px 1fr 100px; border-bottom: 1px solid var(--border); align-items: start; }
.annex-row:last-child { border-bottom: none; }
.annex-row.header { background: var(--surface-2); }
.annex-row > div { padding: 0.7rem 0.9rem; font-size: 0.82rem; line-height: 1.4; }
.annex-row.header > div { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-faint); }
.annex-row .annex-ref { font-family: var(--font-mono); font-weight: 700; color: var(--text-faint); }
.annex-row .annex-domain { font-weight: 600; color: var(--text); }
.annex-row .annex-desc { color: var(--text-dim); }
.annex-paper-tag { font-size: 0.68rem; font-family: var(--font-mono); color: var(--text-faint); padding: 0.15rem 0.4rem; border: 1px solid var(--border); white-space: nowrap; display: inline-block; }
.annex-paper-tag.live { border-color: var(--text); color: var(--text); }
.profiling-note { font-size: 0.72rem; color: var(--text-faint); font-style: italic; }

/* Sectors grid (from corp) */
.sectors-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border: 2px solid var(--border); margin: 1.5rem 0;
}
.sector-cell { padding: 1rem 1.25rem; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.sector-cell:nth-child(3n) { border-right: none; }
.sector-cell:nth-last-child(-n+3) { border-bottom: none; }
.sector-cell h4 { font-size: 0.82rem; margin-bottom: 0.25rem; }
.sector-cell p { font-size: 0.75rem; color: var(--text-dim); line-height: 1.45; margin: 0; }
.sector-cell .eu-flag { font-size: 0.65rem; color: var(--kill, #cc0000); font-weight: 700; }

/* Pricing tiers (from pricing.css) */
.tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin: 2rem 0; }
.tier { background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; padding: 1.5rem; display: flex; flex-direction: column; }
.tier-featured { border-color: var(--accent); }
.tier h3 { color: var(--accent); font-size: 1.1rem; margin-bottom: 0.25rem; }
.tier .price { font-family: var(--font-mono); font-size: 1.4rem; font-weight: 700; margin: 0.5rem 0 1rem; }
.tier .price-free { color: var(--green); }
.tier .price-paid { color: var(--text); }
.tier ul { list-style: none; padding: 0; margin: 0; flex: 1; }
.tier ul li { color: var(--text-dim); font-size: 0.9rem; padding: 0.35rem 0; padding-left: 1.2rem; position: relative; }
.tier ul li::before { content: "+"; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.tier .tier-note { font-size: 0.8rem; color: var(--text-dim); margin-top: 1rem; padding-top: 0.75rem; border-top: 1px solid var(--border); }

/* Size-based pricing table */
.size-band-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.size-band-table thead tr { border-bottom: 1px solid var(--border); background: rgba(255,255,255,0.03); }
.size-band-table th { padding: 0.6rem 0.75rem; text-align: left; color: var(--text-dim); font-weight: 600; white-space: nowrap; }
.size-band-table td { padding: 0.55rem 0.75rem; border-bottom: 1px solid rgba(255,255,255,0.04); color: var(--text); }
.size-band-table tbody tr:last-child td { border-bottom: none; }
.band-label { font-weight: 600; color: var(--accent) !important; }
.band-rev { color: var(--text-dim) !important; font-family: var(--font-mono); font-size: 0.82rem; }
.band-unit { font-size: 0.78rem; color: var(--text-dim); }
.band-reports { font-family: var(--font-mono); font-size: 0.82rem; color: var(--green) !important; }

/* Calculator */
.size-calc-wrap { background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; padding: 1.25rem; margin-bottom: 1.25rem; }
.size-calc-inputs { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.calc-field { display: flex; flex-direction: column; gap: 0.3rem; min-width: 200px; }
.calc-field label { font-size: 0.82rem; color: var(--text-dim); font-weight: 500; }
.calc-field select { background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 0.45rem 0.65rem; color: var(--text); font-size: 0.88rem; font-family: var(--font-mono); }
.calc-output { margin-top: 0.25rem; }
.calc-band-badge { display: inline-block; border: 1px solid var(--accent); color: var(--accent); padding: 0.2rem 0.7rem; border-radius: 20px; font-size: 0.82rem; font-weight: 600; margin-bottom: 0.75rem; }
.calc-result-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; max-width: 480px; }
.calc-result-table tr { border-bottom: 1px solid rgba(255,255,255,0.04); }
.calc-result-table tr:last-child { border-bottom: none; }
.calc-result-table td { padding: 0.4rem 0.5rem; }
.calc-result-table td:first-child { color: var(--text-dim); }
.calc-result-table td:last-child { text-align: right; color: var(--green); font-weight: 600; font-family: var(--font-mono); }
.calc-unit { font-size: 0.78rem; color: var(--text-dim); font-weight: 400; }
.calc-contact { color: var(--text-dim); font-style: italic; }

/* Assessment block */
.assessment-block { border: 2px solid var(--border); padding: 1.5rem; margin: 2rem 0; display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.assessment-col { padding: 0 1.25rem; }
.assessment-col:first-child { border-right: 2px solid var(--border); padding-left: 0; }
.assessment-col:last-child { padding-right: 0; }
.assessment-col h3 { font-size: 0.95rem; margin-bottom: 0.6rem; }
.assessment-col ul { margin: 0; padding-left: 1.1rem; }
.assessment-col li { font-size: 0.82rem; color: var(--text-dim); line-height: 1.6; margin-bottom: 0.2rem; }

/* Payment */
.payment-strip { border: 2px solid var(--border); padding: 1.5rem; margin: 2.5rem 0; display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.payment-strip h3 { grid-column: 1 / -1; margin-bottom: 0; }

/* Decline block */
.decline-block { border: 2px solid var(--border); margin: 2.5rem 0; display: grid; grid-template-columns: 1fr 1fr; }
.decline-col { padding: 1.25rem; }
.decline-col:first-child { border-right: 2px solid var(--border); }
.decline-col h3 { font-size: 0.95rem; margin-bottom: 0.5rem; }
.decline-col p { font-size: 0.82rem; color: var(--text-dim); line-height: 1.55; margin: 0; }
.decline-col .score-tag { display: inline-block; font-family: var(--font-mono); font-size: 0.72rem; font-weight: 700; padding: 0.15rem 0.5rem; margin-bottom: 0.5rem; }
.score-certified { border: 1px solid var(--green); color: var(--green); }
.score-declined { border: 1px solid var(--kill, #cc0000); color: var(--kill, #cc0000); }

/* CTA */
.compliance-cta { border: 2px solid var(--border); padding: 2rem; text-align: center; margin: 2.5rem 0; background: var(--surface-2); }
.compliance-cta h3 { font-size: 1.2rem; margin-bottom: 0.5rem; }
.compliance-cta p { color: var(--text-dim); font-size: 0.88rem; margin-bottom: 1.25rem; max-width: 540px; margin-left: auto; margin-right: auto; }

/* Guarantee */
.guarantee { background: rgba(61,220,132,0.08); border: 1px solid var(--green); border-radius: 8px; padding: 1.5rem; margin: 2rem 0; text-align: center; }

/* Who table */
.who-table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
.who-table th, .who-table td { text-align: left; padding: 0.6rem 0.75rem; border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.who-table th { color: var(--accent); font-weight: 600; }
.who-table td { color: var(--text-dim); }

.section-divider { border-top: 2px solid var(--border); padding-top: 2rem; margin-top: 2.5rem; }

/* Subscribe buttons */
.tier-subscribe-btn { width: 100%; margin-top: 1rem; padding: 0.65rem 1rem; font-size: 0.95rem; font-weight: 600; }
.tier-subscribe-btn:disabled { opacity: 0.5; cursor: default; }
.btn-current { background: var(--bg-card) !important; border: 1px solid var(--green) !important; color: var(--green) !important; }

/* ── Mobile ── */
@media (max-width: 768px) {
    .compliance-urgency { grid-template-columns: 1fr; }
    .urgency-col:first-child { border-right: none; border-bottom: 2px solid var(--border); }
    .tier-strip { grid-template-columns: 1fr; }
    .tier-col { border-right: none; border-bottom: 2px solid var(--border); }
    .tier-col:last-child { border-bottom: none; }
    .tier-grid { grid-template-columns: 1fr; }
    .decline-block { grid-template-columns: 1fr; }
    .decline-col:first-child { border-right: none; border-bottom: 2px solid var(--border); }
    .sectors-grid { grid-template-columns: 1fr; }
    .sector-cell { border-right: none; }
    .sector-cell:last-child { border-bottom: none; }
    .payment-strip { grid-template-columns: 1fr; }
    .assessment-block { grid-template-columns: 1fr; }
    .assessment-col:first-child { border-right: none; border-bottom: 2px solid var(--border); padding-bottom: 1.25rem; margin-bottom: 1.25rem; }
}
@media (max-width: 680px) {
    .deadline-bar { grid-template-columns: 1fr; }
    .deadline-col { border-right: none; border-bottom: 2px solid var(--border); }
    .deadline-col:last-child { border-bottom: none; }
    .penalty-grid { grid-template-columns: 1fr; }
    .penalty-cell { border-right: none; border-bottom: 2px solid var(--border); }
    .penalty-cell:last-child { border-bottom: none; }
    .annex-row { grid-template-columns: 40px 1fr 80px; }
    .annex-row > div:nth-child(3) { display: none; }
}
