:root{
    --fondo:#f4f6fa;
    --panel:#ffffff;
    --borde:#e5e7eb;
    --texto:#1f2937;
    --muted:#6b7280;
    --rosa:#AA5283;
    --dorado:#B6804A;
    --malva:#A38090;
    --gris:#7E8096;
    --verde:#608336;
    --azul:#4d5e97;
    --azuloscuro:#24345d;
    --sombra:0 18px 42px rgba(36,52,93,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;background:radial-gradient(circle at 88% 0%, rgba(182,128,74,.12), transparent 32%), linear-gradient(180deg,#f8fafc 0%,var(--fondo) 44%,#eef1f6 100%);color:var(--texto);}
.shell{min-height:100vh;display:flex}
.sidebar{width:320px;background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-right:1px solid var(--borde);box-shadow:10px 0 26px rgba(15,23,42,.06);padding:22px 16px;}
.brand{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid #ececf1;border-radius:18px;padding:14px;box-shadow:0 6px 18px rgba(15,23,42,.05);margin-bottom:18px;
}
.brandicon{width:62px;height:62px;border-radius:16px;background:linear-gradient(145deg,var(--azuloscuro) 0%, var(--azul) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;box-shadow:0 8px 18px rgba(36,52,93,.18);flex:0 0 auto;}
.brandlabel{font-size:11px;color:var(--gris);text-transform:uppercase;font-weight:700;letter-spacing:.8px;margin-bottom:3px;}
.brandtitle{font-size:23px;line-height:1.02;font-weight:700;}
.brandsubtitle{font-size:14px;color:#374151;margin-top:4px;}
.navtitle{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--gris);padding:0 6px 8px;}
.navitem{width:100%;min-height:56px;border:1px solid #ececf1;border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,#f8f8fb 100%);display:flex;align-items:center;padding:0 16px;font-size:16px;font-weight:700;color:#263041;box-shadow:0 4px 12px rgba(15,23,42,.03);margin-bottom:10px;text-decoration:none;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;}
.navitem:hover{transform:translateY(-1px);border-color:#d8dce8;box-shadow:0 10px 20px rgba(15,23,42,.06);}
.navitem.active{background:linear-gradient(90deg,var(--azul) 0%,var(--rosa) 100%);color:#fff;border-color:transparent;}
.content{flex:1;min-width:0;display:flex;flex-direction:column;}
.banner{background:#e9eaee;border-bottom:1px solid #dddfe5;min-height:104px;max-height:132px;overflow:hidden;}
.banner img{width:100%;height:100%;object-fit:cover;display:block;}
.main{padding:32px;}
.card{background:rgba(255,255,255,.94);border:1px solid var(--borde);border-radius:22px;box-shadow:var(--sombra);overflow:hidden;position:relative;max-width:1280px;margin:0 auto;}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--azuloscuro),var(--azul),var(--rosa),var(--dorado));}
.head{padding:34px 34px 16px;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:30px;align-items:center;}
.head span{display:inline-flex;padding:7px 12px;border-radius:12px;background:rgba(182,128,74,.12);color:var(--dorado);font-size:12px;font-weight:700;margin-bottom:12px;}
.head h1{font-size:36px;line-height:1.08;margin-bottom:10px;}
.head p{color:var(--muted);line-height:1.7;font-size:16px;max-width:760px;}
.resume{border:1px solid rgba(77,94,151,.18);border-radius:18px;background:linear-gradient(155deg,#f8fafc 0%,#fff 52%,#fbf7f1 100%);padding:20px;box-shadow:0 12px 24px rgba(36,52,93,.07);}
.resume-title{font-size:12px;font-weight:700;color:var(--gris);text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px;}
.resume-step{display:flex;gap:10px;align-items:flex-start;margin-bottom:11px;color:#374151;font-size:14px;line-height:1.45;}
.resume-step:last-child{margin-bottom:0}
.resume-step b{width:26px;height:26px;border-radius:9px;flex:0 0 auto;background:rgba(77,94,151,.10);color:var(--azuloscuro);display:flex;align-items:center;justify-content:center;font-size:12px;}
.alerta{margin:0 34px 18px;padding:14px 16px;border-radius:14px;font-size:14px;}
.error{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3;}
.ok{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0;}
.curpmsg{margin-top:6px;font-size:13px;line-height:1.5;display:none;}
.curpmsg.error{display:block;color:#9f1239;background:#fff1f2;border:1px solid #fecdd3;border-radius:12px;padding:10px 12px;}
.curpmsg.ok{display:block;color:#166534;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:12px;padding:10px 12px;}
.helper{margin-top:6px;font-size:12px;line-height:1.5;color:var(--muted);}
.form{padding:0 34px 34px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:18px;}
.section{grid-column:1/-1;border:1px solid #e5e8ef;border-radius:18px;background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);padding:22px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:18px;box-shadow:0 8px 22px rgba(15,23,42,.04);}
.sectionhead{grid-column:1/-1;display:flex;align-items:flex-start;gap:14px;padding-bottom:4px;}
.sectionnum{width:38px;height:38px;border-radius:13px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;background:linear-gradient(145deg,var(--azuloscuro),var(--azul));box-shadow:0 10px 18px rgba(36,52,93,.16);}
.sectionhead h2{font-size:20px;line-height:1.2;margin-bottom:4px;}
.sectionhead p{color:var(--muted);font-size:13px;line-height:1.55;}
.field{display:flex;flex-direction:column;gap:8px;grid-column:span 6;}
.field.full{grid-column:1/-1;}
.field.third{grid-column:span 4;}
label{font-size:14px;font-weight:700;color:#374151;}
input, select, textarea{min-height:48px;border:1px solid #d1d5db;border-radius:13px;padding:12px 14px;font-size:15px;outline:none;background:#fff;font-family:Arial,Helvetica,sans-serif;transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;}
textarea{resize:vertical;min-height:110px;}
input:focus, select:focus, textarea:focus{border-color:var(--azul);box-shadow:0 0 0 4px rgba(77,94,151,.10);}
.inlinecheck{display:flex;align-items:center;gap:10px;min-height:48px;padding:10px 12px;color:#374151;font-size:14px;font-weight:700;border:1px solid #e5e7eb;border-radius:13px;background:#fbfcfe;margin-top:2px;}
.inlinecheck input{width:18px;height:18px;min-height:auto;padding:0;}
.grupoopciones{display:flex;flex-wrap:wrap;gap:10px;min-height:48px;align-items:center;padding:4px 0;}
.grupoopciones label{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#374151;min-height:44px;padding:0 14px;border:1px solid #e5e7eb;border-radius:13px;background:#fff;transition:border-color .18s ease, background .18s ease, color .18s ease;}
.grupoopciones label:has(input:checked){border-color:rgba(77,94,151,.38);background:rgba(77,94,151,.08);color:var(--azuloscuro);}
.grupoopciones input[type="radio"]{width:18px;height:18px;min-height:auto;padding:0;}
.oculto{display:none;}
.note{grid-column:1/-1;font-size:13px;color:var(--muted);line-height:1.6;background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);border:1px dashed #d1d5db;padding:14px 16px;border-radius:14px;}
.actions{grid-column:1/-1;display:flex;justify-content:flex-end;align-items:center;gap:14px;background:#fff;border:1px solid #e5e8ef;border-radius:18px;padding:18px;box-shadow:0 8px 22px rgba(15,23,42,.04);}
.actions p{margin-right:auto;color:var(--muted);font-size:13px;line-height:1.45;max-width:620px;}
button{height:48px;min-width:190px;padding:0 24px;border:0;border-radius:13px;background:linear-gradient(90deg,var(--azul) 0%,var(--rosa) 100%);color:#fff;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 12px 22px rgba(77,94,151,.18);transition:transform .18s ease, box-shadow .18s ease;}
button:hover{transform:translateY(-1px);box-shadow:0 16px 28px rgba(77,94,151,.24);}
button:disabled{opacity:.7;cursor:not-allowed;}
@media (max-width:980px){
    .shell{flex-direction:column}
    .sidebar{width:100%;border-right:0;border-bottom:1px solid var(--borde);box-shadow:none;}
    .main{padding:18px}
    .head{grid-template-columns:1fr;padding:28px 24px 16px}
    .form{padding-left:24px;padding-right:24px}
}
@media (max-width:780px){
    .form{grid-template-columns:1fr}
    .section{grid-template-columns:1fr}
    .field,.field.third,.field.full{grid-column:1/-1}
    .head h1{font-size:25px}
    .actions{align-items:stretch;flex-direction:column}
    .actions p{margin-right:0}
    button{width:100%}
}
@media (max-width:640px){
    .main{padding:14px}
    .head,.form{padding-left:18px;padding-right:18px}
    .section{padding:18px}
    .sectionhead h2{font-size:18px}
}