:root {
    --primary: #1d70b7;
    --accent: #f8b133;
    --text: #131313;
    --blue-soft: rgba(29, 112, 183, 0.1);
    --blue-20: rgba(29, 112, 183, 0.2);
}

* { box-sizing: border-box; font-family: 'Heebo', sans-serif; }
body { margin: 0; background: #f4f6f8; color: var(--text); }
.container { max-width: 1000px; margin: auto; background: #fff; }

.no-print { padding: 20px; border-bottom: 5px solid var(--primary); }
.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-top: 10px; }
label { font-size: 13px; font-weight: 600; display: block; margin-bottom: 3px; }
input, select { width: 100%; padding: 8px; border: 1px solid #ccc; border-radius: 5px; }
.main-btn { margin-top: 15px; padding: 12px; width: 100%; background: var(--primary); color: #fff; border: none; font-weight: 700; cursor: pointer; border-radius: 6px; }
.btn-p { padding: 12px 30px; background: #2e7d32; color: #fff; border: none; border-radius: 6px; cursor: pointer; font-weight: 700; }

.page {
    width: 210mm;
    height: 297mm;
    margin: 0 auto;
    position: relative;
    display: flex;
    flex-direction: column;
    background: #fff !important;
    overflow: hidden;
    page-break-after: always;
}

header { background: var(--primary) !important; color: #fff !important; display: flex; justify-content: space-between; align-items: center; padding: 12px 30px; }
header img { max-height: 40px; }
.h2-A4 { margin:0; font-size: 20px; color: #fff !important; }

footer { background: var(--primary) !important; color: #fff !important; padding: 10px 30px; position: absolute; bottom: 0; width: 100%; }
.footer-grid { display: grid; grid-template-columns: 1fr 1fr 2fr; font-size: 9px; align-items: center; color: #fff !important; }

.content { padding: 15px 30px; flex-grow: 1; }
.capa-container { width: 100%; aspect-ratio: 80 / 22; overflow: hidden; }
.capa-container img { width: 100%; height: 100%; object-fit: cover; }

.cards-grid { display: flex !important; gap: 15px !important; margin-top: 10px; }
.card { padding: 15px; border-radius: 15px; flex: 1; }
.card.primary { background: var(--primary) !important; color: #fff !important; }
.card.soft { background: var(--blue-20) !important; }
.card.light { background: #fbfbfb !important; border: 1px solid #eee; }

.card-title { font-size: 18px; font-weight: 700; margin: 0 0 10px 0; color: #fff !important; }
.card-title-blue { font-size: 18px; font-weight: 700; margin: 0 0 10px 0; color: var(--primary) !important; }

.compare-flex { display: flex !important; flex-direction: row !important; gap: 10px !important; align-items: flex-end !important; }
.comp-item { flex: 1; text-align: center; }
.val-big { font-size: 18px; font-weight: 700; color: #fff !important; }
.val-small { font-size: 11px; color: #fff !important; opacity: 0.9; margin-bottom: 5px; }
.bar-outer { width: 100%; background: rgba(255,255,255,0.2) !important; border-radius: 5px; height: 70px; display: flex; align-items: flex-end; overflow: hidden; }
.bar-inner { width: 100% !important; background: var(--accent) !important; }
.bar-txt { font-size: 10px; margin: 5px 0 0 0; color: #fff !important; }

.grid-2x2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.eco-item { background: #fff !important; padding: 8px; border-radius: 8px; text-align: center; }
.eco-item p { font-size: 9px; margin: 0; color: #666; font-weight: 700; }
.eco-item span { color: var(--primary) !important; font-weight: 700; font-size: 16px; display: block; }
.info-box p { font-size: 12px; margin: 5px 0; }

.step-box { display: flex; align-items: flex-start; background: var(--blue-soft) !important; margin-bottom: 8px; padding: 10px; border-radius: 8px; }
.step-circle { background: var(--primary) !important; color: #fff !important; width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; margin-right: 12px; flex-shrink: 0; }
.step-text h4 { margin: 0; color: var(--primary) !important; font-size: 14px; }
.step-text p { margin: 2px 0; font-size: 11px; line-height: 1.2; color: #444 !important; }
.legis-box-mini { background: #f8f9fa !important; padding: 10px; border-radius: 8px; border: 1px solid #ddd; }

.contrato-area { font-family: 'Times New Roman', serif; font-size: 14px; color: #000 !important; line-height: 1.4; }
.sign-area { margin-top: 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; text-align: center; }
.sign-line { border-top: 1px solid #000; padding-top: 5px; margin-top: 25px; font-weight: 600; font-size: 12px; }

@media print {
    .no-print { display: none !important; }
    .page { margin: 0; border: none; }
    @page { size: A4; margin: 0; }
}