:root{
    --azul-1:#062d57;
    --azul-2:#0d4f97;
    --azul-3:#0f61b4;
    --amarillo:#f5b700;
    --amarillo-2:#ffcc33;
    --blanco:#ffffff;
    --gris:#edf3fb;
    --texto:#113154;
    --borde:#c8d9ee;
    --error:#9f2430;
    --ok:#18794e;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    background:linear-gradient(135deg,var(--azul-1),var(--azul-2));
    color:var(--texto);
}
.site-wrap{max-width:1220px;margin:0 auto;padding:24px}
.site-header{
    display:flex;align-items:center;gap:18px;
    background:linear-gradient(135deg,#08325e,#0d5ca7);
    border:4px solid rgba(255,255,255,.85);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(0,0,0,.18);
    color:#fff;padding:18px 24px;margin-bottom:22px;
}
.site-header h1{
    margin:0;
    color:var(--amarillo-2);
    text-transform:uppercase;
    letter-spacing:.8px;
    font-size:2rem;
    line-height:1;
}
.site-header p{margin:8px 0 0;color:#ffd76e;text-transform:uppercase;font-size:1rem}
.logo{width:84px;height:auto;filter:drop-shadow(0 10px 16px rgba(0,0,0,.28))}
.panel{
    background:#f8fbff;
    border-radius:26px;
    box-shadow:0 18px 45px rgba(0,0,0,.16);
    padding:24px;
}
.panel-head h2,.section-card h3,.ficha-section h3{
    margin:0 0 10px;
    text-transform:uppercase;
    letter-spacing:.8px;
    color:var(--azul-1);
}
.panel-head p{margin:0;color:#33557b}
.with-actions{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}
.section-card{background:#fff;border:1px solid var(--borde);border-radius:22px;padding:18px;margin-bottom:18px}
.narrow{max-width:520px;margin:0 auto}
.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}
label{display:flex;flex-direction:column;gap:7px;font-size:.95rem;font-weight:700;color:#27486f}
input,select,textarea{width:100%;border:1px solid #bfd0e5;border-radius:12px;padding:11px 12px;font:inherit;color:#163b63;background:#fff}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--azul-3);box-shadow:0 0 0 3px rgba(15,97,180,.12)}
.span-2{grid-column:span 2}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.actions.center{justify-content:center}
.top-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;min-height:44px;padding:10px 18px;border-radius:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;border:none;cursor:pointer;font:inherit}
.btn-primary{background:var(--amarillo);color:#173355;box-shadow:0 8px 18px rgba(245,183,0,.28)}
.btn-secondary{background:#e8f1fb;color:#123962;border:1px solid #bfd0e5}
.alert{border-radius:20px;padding:20px;border:1px solid transparent;margin-bottom:16px}
.alert-success{background:#eefaf2;border-color:#cbead6;color:#115c39}
.alert-error{background:#fff1f2;border-color:#f1c1c6;color:#7d1f2a}
.legal-box,.legal-print{background:#f6f9fd;border:1px solid var(--borde);border-radius:16px;padding:14px 16px;margin-bottom:14px}
.legal-box p,.legal-print p{margin:0 0 10px;line-height:1.45}
.legal-box p:last-child,.legal-print p:last-child{margin-bottom:0}
.print-note{background:#f6f9fd;border:1px dashed #c6d8ef;border-radius:12px;padding:12px 14px;color:#35577f;font-weight:700}
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0}
.filter-bar select,.filter-bar input{max-width:320px}
.table-wrap{overflow:auto}
.tabla{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--borde);border-radius:16px;overflow:hidden}
.tabla th,.tabla td{border-bottom:1px solid #e1ebf6;padding:12px 10px;text-align:left;vertical-align:top;font-size:.95rem}
.tabla th{background:#0b4f95;color:#fff;text-transform:uppercase;font-size:.86rem;letter-spacing:.5px}
.text-link{color:#0b5da9;text-decoration:none;font-weight:700;margin-right:10px}
.ficha-page{background:transparent;box-shadow:none;padding:0}
.ficha-pdf-like{
    width:100%;
    max-width:980px;
    margin:0 auto;
    background:#fff;
    border:1px solid #9db7d7;
    box-shadow:0 12px 30px rgba(0,0,0,.12);
    padding:18px;
}
.doc-table{
    width:100%;
    border-collapse:collapse;
    table-layout:fixed;
    margin-bottom:10px;
    background:#fff;
}
.doc-table.outer{margin-bottom:12px}
.doc-table th,
.doc-table td{
    border:1px solid #6f8fb4;
    vertical-align:top;
    padding:6px 7px;
    font-size:13px;
    line-height:1.2;
}
.doc-table th{
    background:#dfeaf7;
    color:#113154;
    text-align:left;
    font-weight:800;
}
.logo-side{text-align:center;background:#fff}
.print-logo{width:140px;max-width:100%;height:auto}
.title-cell{text-align:center;background:#fff}
.school-name{font-size:27px;font-weight:800;color:#1f3f66;line-height:1.05}
.school-city{font-size:14px;margin-top:2px;color:#1f3f66}
.doc-title{font-size:20px;font-weight:800;margin-top:4px;color:#1f3f66}
.doc-id{font-size:12px;margin-top:5px;color:#34597f}
.field-label{font-size:11px;font-weight:700;color:#36587d;margin-bottom:4px}
.field-value{font-size:13px;color:#0f2742;min-height:18px;word-break:break-word}
.firma-box{margin-top:18px}
.firma-linea{border-top:1px solid #222;height:26px;margin:18px auto 0;max-width:460px}
.firma-etiquetas{display:flex;justify-content:space-between;gap:14px;font-size:12px;margin-top:4px}
.login-panel .grid-form{grid-template-columns:1fr}
.actions-cell{white-space:nowrap}

@media (max-width: 760px){
    .site-wrap{padding:14px}
    .site-header{flex-direction:column;text-align:center}
    .grid-form{grid-template-columns:1fr}
    .span-2{grid-column:span 1}
    .filter-bar select,.filter-bar input{max-width:none;width:100%}
    .school-name{font-size:22px}
    .doc-title{font-size:17px}
    .ficha-pdf-like{padding:10px}
    .firma-etiquetas{flex-direction:column}
}

@media print{
    @page{
        size:A4 portrait;
        margin:7mm;
    }
    html,body{
        background:#fff !important;
        margin:0 !important;
        padding:0 !important;
        width:100%;
    }
    .site-header,
    .actions,
    .top-actions,
    .filter-bar,
    .btn-primary,
    .btn-secondary{
        display:none !important;
    }
    .site-wrap,
    .panel,
    .ficha-page{
        margin:0 !important;
        padding:0 !important;
        background:#fff !important;
        box-shadow:none !important;
        border:none !important;
        max-width:none !important;
        width:100% !important;
    }
    .ficha-pdf-like{
        width:100% !important;
        max-width:none !important;
        margin:0 !important;
        padding:0 !important;
        border:none !important;
        box-shadow:none !important;
    }
    .doc-table{
        width:100% !important;
        max-width:100% !important;
        margin:0 0 6px 0 !important;
        page-break-inside:avoid;
    }
    .doc-table th,
    .doc-table td{
        font-size:11px !important;
        padding:4px 5px !important;
        border:1px solid #4c6f99 !important;
    }
    .print-logo{width:110px !important}
    .school-name{font-size:23px !important}
    .doc-title{font-size:17px !important}
    .school-city,.doc-id,.field-label,.field-value,.firma-etiquetas{
        color:#000 !important;
    }
    a[href]:after{content:none !important}
}

.student-wide .field-value{min-height:22px}
.firma-centro{display:flex;flex-direction:column;align-items:center;justify-content:center}
.firma-centro .firma-linea{width:320px;max-width:90%;margin:22px auto 10px}
.firma-etiquetas-centro{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:4px}
@media print{
    .student-wide{width:100% !important}
    .student-wide .field-label{font-size:10px !important}
    .student-wide .field-value{font-size:11px !important}
    .firma-centro .firma-linea{width:300px !important;max-width:80% !important;margin:26px auto 8px !important}
    .firma-etiquetas-centro{width:100% !important;text-align:center !important;align-items:center !important}
}


.no-print{}
.contract-print{
    max-width:820px;
    margin:0 auto;
    background:#fff;
    color:#000;
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
}
.contract-page{
    background:#fff;
    color:#000;
    padding:22px 26px;
    min-height:1120px;
    border:1px solid #d8d8d8;
    margin-bottom:16px;
}
.contract-header{
    display:flex;
    align-items:flex-start;
    gap:14px;
    margin-bottom:14px;
}
.contract-logo{width:72px;height:auto}
.contract-header-text{line-height:1.15;color:#000}
.contract-fundacion,.contract-school,.contract-number{font-size:20px;font-weight:700;color:#000}
.contract-title{
    margin:8px 0 18px;
    color:#000;
    text-align:center;
    font-size:22px;
    text-transform:uppercase;
    letter-spacing:.4px;
}
.contract-p{
    color:#000;
    font-size:16px;
    line-height:1.34;
    text-align:justify;
    margin:0 0 12px;
}
.contract-data-table{
    width:100%;
    border-collapse:collapse;
    margin:10px 0 14px;
}
.contract-data-table td{
    border-bottom:1px solid #777;
    padding:7px 6px;
    font-size:15px;
    color:#000;
    vertical-align:top;
}
.contract-data-table .label{width:210px;font-weight:700}
.contract-list{margin:6px 0 12px 20px;padding:0;color:#000}
.contract-list li{margin-bottom:8px;font-size:15px;line-height:1.3}
.contract-signatures{
    margin-top:80px;
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:24px;
}
.signature-col{flex:1;color:#000}
.left-sign{display:flex;justify-content:flex-start;align-items:flex-end}
.fundacion-box{font-size:18px;font-weight:700;line-height:1.2;max-width:240px;color:#000}
.right-sign{display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.signature-line{width:260px;max-width:90%;border-top:1px solid #000;margin-bottom:10px}
.signature-label,.contract-footer-address{color:#000;font-size:15px;text-align:center;line-height:1.25}
.contract-footer-address{margin-top:54px}

@media print{
    .no-print,.site-header{display:none !important}
    .contract-print{
        max-width:none !important;
        width:100% !important;
        margin:0 !important;
        padding:0 !important;
        background:#fff !important;
        color:#000 !important;
    }
    .contract-page{
        width:100% !important;
        min-height:auto !important;
        margin:0 !important;
        padding:8mm 8mm 10mm 8mm !important;
        border:none !important;
        box-shadow:none !important;
        page-break-after:always;
        page-break-inside:avoid;
    }
    .contract-page:last-child{page-break-after:auto}
    .contract-title{font-size:18px !important;margin:4px 0 10px !important}
    .contract-fundacion,.contract-school,.contract-number{font-size:16px !important}
    .contract-logo{width:58px !important}
    .contract-p{font-size:13px !important;line-height:1.22 !important;margin:0 0 8px !important}
    .contract-data-table{margin:6px 0 8px !important}
    .contract-data-table td{font-size:12px !important;padding:4px 4px !important}
    .contract-data-table .label{width:170px !important}
    .contract-list li{font-size:12px !important;line-height:1.2 !important;margin-bottom:5px !important}
    .contract-signatures{margin-top:54px !important}
    .signature-line{width:230px !important}
    .signature-label,.contract-footer-address{font-size:12px !important}
}


.hidden-editor{display:none}
.contract-tools{justify-content:flex-end;margin-bottom:14px}
.contrato-solo{padding-top:18px}
.contract-page{padding-top:18px}
.contract-header{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-bottom:10px;
}
.contract-logo{
    width:46px;
    height:auto;
    flex:0 0 auto;
    margin-top:2px;
}
.contract-header-text{
    line-height:1.08;
}
.contract-fundacion,.contract-school,.contract-number{
    font-size:16px;
    font-weight:700;
}
.contract-title{
    margin:10px 0 14px;
    font-size:20px;
}
.left-sign{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-end;
}
.right-sign{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    justify-content:flex-end;
}
.left-line{
    width:210px;
    max-width:90%;
    margin-bottom:10px;
}
.left-label{
    text-align:left;
}
.signature-label{
    text-align:center;
}
@media print{
    .contract-tools{display:none !important}
    .contract-logo{width:34px !important}
    .contract-fundacion,.contract-school,.contract-number{font-size:13px !important}
    .contract-title{font-size:17px !important;margin:4px 0 8px !important}
    .left-line{width:180px !important}
}


.contract-paper{max-width:850px;margin:0 auto;background:#fff}
.paper-sheet{
    width:210mm;
    min-height:297mm;
    margin:0 auto 12px auto;
    background:#fff;
    color:#000;
    padding:10mm 10mm 12mm 10mm;
    box-shadow:0 0 0 1px #ddd;
}
.paper-contract-table{
    width:100%;
    border-collapse:collapse;
    table-layout:fixed;
}
.paper-contract-table td{
    color:#000;
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:14px;
    line-height:1.25;
    vertical-align:top;
    padding:2px 0;
}
.paper-header{padding-bottom:8px !important}
.paper-header-table{width:100%;border-collapse:collapse}
.paper-logo-cell{width:62px;vertical-align:top}
.paper-headtext-cell{vertical-align:top}
.paper-logo{width:42px;height:auto;display:block}
.paper-headtext{font-size:15px;line-height:1.12;font-weight:400}
.paper-title{
    text-align:center;
    font-size:19px !important;
    font-weight:700;
    padding:14px 0 12px 0 !important;
    line-height:1.15 !important;
}
.paper-text{
    text-align:justify;
    padding:3px 0 !important;
}
.paper-label{
    width:220px;
    font-weight:700;
    padding-top:3px !important;
    padding-right:8px !important;
    vertical-align:bottom;
}
.paper-value{
    border-bottom:1px solid #000;
    min-height:18px;
    padding-top:3px !important;
}
.paper-sign-left,.paper-sign-right{
    width:50%;
    padding-top:55px !important;
    vertical-align:bottom;
}
.paper-sign-left{text-align:left;padding-right:28px !important}
.paper-sign-right{text-align:right;padding-left:28px !important}
.paper-sign-line{
    border-top:1px solid #000;
    width:220px;
}
.paper-sign-right .paper-sign-line{margin-left:auto}
.paper-sign-text{
    margin-top:6px;
    font-size:14px;
    line-height:1.15;
}
.paper-sign-text.left{text-align:left}
.paper-sign-text.right{text-align:right}
.paper-footer{
    text-align:center;
    padding-top:44px !important;
    font-size:14px !important;
}
@media print{
    .contract-paper{max-width:none !important}
    .paper-sheet{
        width:100% !important;
        min-height:auto !important;
        margin:0 !important;
        padding:8mm 8mm 10mm 8mm !important;
        box-shadow:none !important;
        page-break-after:always;
    }
    .paper-sheet:last-child{page-break-after:auto}
    .paper-contract-table td{
        font-size:12px !important;
        line-height:1.18 !important;
    }
    .paper-title{font-size:16px !important;padding:10px 0 8px 0 !important}
    .paper-logo{width:30px !important}
    .paper-headtext{font-size:12px !important}
    .paper-label{width:180px !important}
    .paper-sign-line{width:180px !important}
    .paper-footer{font-size:12px !important;padding-top:34px !important}
}


/* Ajustes finales contrato */
.contrato-panel.contrato-solo{
    background:#ffffff !important;
    border-radius:24px;
    box-shadow:0 18px 45px rgba(0,0,0,.12);
    padding:22px;
}
.contract-paper{
    max-width:900px;
    margin:0 auto;
    background:#ffffff;
    border-radius:18px;
    padding:14px;
    box-shadow:0 0 0 1px #e3e3e3;
}
.paper-sheet{
    background:#ffffff;
}
.paper-logo{
    width:52px;
    height:auto;
    display:block;
}
.paper-logo-cell{
    width:74px;
    vertical-align:top;
}
@media print{
    .contrato-panel.contrato-solo{
        background:#fff !important;
        box-shadow:none !important;
        padding:0 !important;
        border-radius:0 !important;
    }
    .contract-paper{
        max-width:none !important;
        padding:0 !important;
        box-shadow:none !important;
        border-radius:0 !important;
        background:#fff !important;
    }
    .paper-logo{
        width:38px !important;
    }
    .paper-logo-cell{
        width:54px !important;
    }
}


.aligned-buttons{
    display:flex;
    gap:10px;
    justify-content:flex-end;
    align-items:center;
}
.aligned-buttons a{
    display:inline-block;
}

/* contenedor blanco tipo documento */
.contrato-wrapper{
    background:#ffffff;
    padding:20px;
    border-radius:18px;
    box-shadow:0 10px 30px rgba(0,0,0,0.1);
    max-width:950px;
    margin:0 auto;
}
@media print{
    .contrato-wrapper{
        box-shadow:none !important;
        padding:0 !important;
        border-radius:0 !important;
    }
}


.sample-like{max-width:900px;margin:0 auto;background:#fff}
.one-flow{
    width:210mm;
    min-height:297mm;
    background:#fff;
    color:#000;
    padding:8mm 8mm 10mm 8mm;
    box-shadow:none;
}
.sample-header-table{width:100%;border-collapse:collapse;margin-bottom:4px}
.sample-logo-cell{width:42px;vertical-align:top}
.sample-logo{width:28px;height:auto;display:block}
.sample-headtext-cell{vertical-align:top}
.sample-headtext{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:13px;
    line-height:1.1;
    color:#000;
}
.sample-title{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:16px;
    line-height:1.15;
    font-weight:700;
    color:#000;
    text-align:center;
    margin:4px 0 10px;
}
.sample-text{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:13px;
    line-height:1.22;
    color:#000;
    text-align:justify;
    margin:0 0 8px 0;
}
.sample-data-table{
    width:auto;
    border-collapse:collapse;
    margin:4px 0 8px 0;
}
.sample-data-table td{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:13px;
    line-height:1.18;
    color:#000;
    padding:0 8px 2px 0;
    vertical-align:top;
}
.sample-data-table .lbl{
    font-weight:700;
    white-space:nowrap;
}
.sample-sign-table{
    width:100%;
    border-collapse:collapse;
    margin-top:18px;
}
.sig-cell{
    width:42%;
    vertical-align:bottom;
}
.sig-gap{width:16%}
.sig-line{
    border-top:1px solid #000;
    width:180px;
    margin:0 auto 4px auto;
}
.sig-text{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:13px;
    line-height:1.15;
    color:#000;
    text-align:center;
}
.sample-footer{
    font-family:"Arial Narrow","Roboto Condensed","Helvetica Neue",Arial,sans-serif;
    font-size:13px;
    line-height:1.1;
    color:#000;
    text-align:center;
    margin-top:12px;
}
@media print{
    .sample-like{max-width:none !important}
    .one-flow{
        width:100% !important;
        min-height:auto !important;
        padding:6mm 6mm 8mm 6mm !important;
        margin:0 !important;
        box-shadow:none !important;
        page-break-after:auto !important;
    }
    .sample-headtext,.sample-text,.sample-data-table td,.sig-text,.sample-footer{font-size:12px !important}
    .sample-title{font-size:15px !important}
    .sample-logo{width:24px !important}
    .sig-line{width:170px !important}
}
