/* =====================================================================
   PlaneaIA · Identidad Gobierno de México (guinda) · Plan 2022
   Los temas se inyectan vía variables en :root desde el layout.
   ===================================================================== */
:root{
  --guinda:#611232; --guinda-2:#7a1a40; --guinda-3:#9b2247;
  --dorado:#b38e5d; --dorado-2:#a57f2c; --verde:#235b4e;
  --crema:#f7f3ec; --crema-2:#efe8db; --tinta:#2d2a28; --gris:#6b6258;
  --linea:#e3ddd2; --blanco:#fff; --ok:#1f7a52; --warn:#b5651d; --bg:#f4f1ec;
  --radio:14px;
  --sombra:0 1px 2px rgba(45,42,40,.06),0 8px 24px rgba(45,42,40,.08);
  --sombra-sm:0 1px 2px rgba(45,42,40,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--tinta);-webkit-font-smoothing:antialiased;line-height:1.45}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--tinta)}
a{color:var(--guinda);text-decoration:none}
.hidden{display:none !important}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--guinda);color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;font-size:14px;transition:transform .08s,background .15s}
.btn:hover{background:var(--guinda-2)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:#fff;color:var(--guinda);border:1.5px solid var(--linea)}
.btn.ghost:hover{border-color:var(--guinda);background:var(--crema)}
.btn.gold{background:var(--dorado);color:var(--guinda)}
.btn.gold:hover{background:var(--dorado-2);color:#fff}
.btn.sm{padding:8px 13px;font-size:13px}
.btn.block{width:100%;justify-content:center}
.btn svg{width:17px;height:17px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Top bar ---------- */
.gob-strip{height:6px;background:linear-gradient(90deg,var(--guinda) 0 33%,var(--dorado) 33% 66%,var(--verde) 66% 100%)}
.topbar{background:var(--guinda);color:#fff;display:flex;align-items:center;gap:16px;padding:0 22px;height:60px;position:sticky;top:0;z-index:40}
.topbar .brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.2px;color:#fff}
.topbar .brand .mark{width:30px;height:30px;border-radius:8px;background:var(--dorado);display:grid;place-items:center;color:var(--guinda);font-weight:800;font-size:15px;flex:none}
.topbar .brand small{display:block;font-weight:500;font-size:10.5px;opacity:.78;letter-spacing:.3px;text-transform:uppercase}
.topbar .spacer{flex:1}
.topbar .ciclo-pill{background:rgba(255,255,255,.14);padding:6px 13px;border-radius:30px;font-size:12.5px;font-weight:600}
.topbar .iconbtn{width:38px;height:38px;border-radius:10px;color:#fff;display:grid;place-items:center;transition:background .15s}
.topbar .iconbtn:hover{background:rgba(255,255,255,.13)}
.topbar .user{display:flex;align-items:center;gap:9px;padding:5px 6px 5px 12px;border-radius:30px;background:rgba(255,255,255,.1);font-size:13px;font-weight:600;color:#fff}
.topbar .avatar{width:30px;height:30px;border-radius:50%;background:var(--dorado);color:var(--guinda);display:grid;place-items:center;font-weight:800;font-size:12px}

.container{max-width:1180px;margin:0 auto;padding:28px 22px 60px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1100px 500px at 85% -5%,rgba(179,142,93,.16),transparent 60%),linear-gradient(160deg,#5a1030 0%,#611232 45%,#4a0e26 100%)}
.login-card{width:100%;max-width:880px;background:#fff;border-radius:22px;overflow:hidden;display:grid;grid-template-columns:1.05fr 1fr;box-shadow:0 30px 80px rgba(0,0,0,.35)}
.login-aside{background:linear-gradient(165deg,var(--guinda) 0%,#4c0e26 100%);color:#fff;padding:42px 38px;display:flex;flex-direction:column}
.login-aside .mark{width:46px;height:46px;border-radius:12px;background:var(--dorado);color:var(--guinda);display:grid;place-items:center;font-weight:800;font-size:22px}
.login-aside h1{font-size:28px;font-weight:800;margin-top:26px;letter-spacing:-.6px;line-height:1.14}
.login-aside p{opacity:.85;font-size:14px;margin-top:14px;line-height:1.55}
.login-aside ul{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:12px}
.login-aside li{display:flex;gap:10px;font-size:13.5px;align-items:flex-start;opacity:.95}
.login-aside .foot{margin-top:auto;font-size:11.5px;opacity:.6;padding-top:24px}
.login-form{padding:46px 42px;display:flex;flex-direction:column;justify-content:center}
.login-form h2{font-size:22px;font-weight:800;letter-spacing:-.3px}
.login-form .sub{color:var(--gris);font-size:13.5px;margin-top:6px;margin-bottom:24px}
.demo-note{margin-top:16px;background:var(--crema);border:1px dashed var(--dorado);border-radius:10px;padding:11px 13px;font-size:12px;color:var(--gris)}

/* ---------- Campos ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:7px;color:var(--tinta)}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--linea);border-radius:10px;background:#fff;transition:border .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--guinda);box-shadow:0 0 0 3px rgba(97,18,50,.1)}
.field .err{color:#b5302b;font-size:11.5px;margin-top:5px}
textarea{resize:vertical;min-height:78px;line-height:1.5}
.help{font-size:11.5px;color:var(--gris);margin-top:5px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.full{grid-column:1/-1}

/* ---------- Encabezado de página ---------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.page-head h2{font-size:25px;font-weight:800;letter-spacing:-.5px}
.page-head .muted{color:var(--gris);font-size:14px;margin-top:3px}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--dorado-2)}
.backlink{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--guinda);margin-bottom:16px;cursor:pointer}
.backlink svg{width:16px;height:16px}

/* ---------- Stats / dashboard ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.stat{background:#fff;border:1px solid var(--linea);border-radius:var(--radio);padding:16px 18px;box-shadow:var(--sombra-sm)}
.stat .n{font-size:27px;font-weight:800;color:var(--guinda);letter-spacing:-.5px}
.stat .l{font-size:12.5px;color:var(--gris);margin-top:2px;font-weight:500}
.cycle-block{margin-bottom:26px}
.cycle-head{display:flex;align-items:center;gap:12px;margin-bottom:13px}
.cycle-head h3{font-size:16px;font-weight:700}
.cycle-head .tag{background:var(--crema-2);color:var(--guinda);font-size:11.5px;font-weight:700;padding:3px 11px;border-radius:20px}
.cycle-head .rule{flex:1;height:1px;background:var(--linea)}
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px}
.plan-card{background:#fff;border:1px solid var(--linea);border-radius:var(--radio);padding:17px 18px;box-shadow:var(--sombra-sm);display:flex;flex-direction:column;transition:box-shadow .15s,transform .1s,border-color .15s}
.plan-card:hover{box-shadow:var(--sombra);transform:translateY(-2px);border-color:var(--dorado)}
.plan-card .pc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.campo-dot{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none;color:#fff;font-weight:800;font-size:12px}
.chip{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.chip.estado-listo{background:#e6f3ec;color:var(--ok)}
.chip.estado-borrador{background:#fbeede;color:var(--warn)}
.plan-card h4{font-size:15px;font-weight:700;margin:11px 0 4px;line-height:1.3}
.plan-card .meta{font-size:12.5px;color:var(--gris);display:flex;flex-wrap:wrap;gap:4px 10px;margin-bottom:13px}
.plan-card .meta b{color:var(--tinta);font-weight:600}
.plan-card .pc-actions{margin-top:auto;display:flex;gap:7px;flex-wrap:wrap;padding-top:11px;border-top:1px solid var(--linea)}
.tinybtn{font-size:12px;font-weight:600;color:var(--guinda);padding:6px 10px;border-radius:8px;background:var(--crema);display:inline-flex;gap:5px;align-items:center;border:none}
.tinybtn:hover{background:var(--crema-2)}
.tinybtn svg{width:14px;height:14px}
.new-card{border:1.5px dashed var(--dorado);background:linear-gradient(160deg,#fff,var(--crema));display:grid;place-items:center;text-align:center;cursor:pointer;min-height:180px;border-radius:var(--radio)}
.new-card:hover{background:var(--crema);border-color:var(--guinda)}
.new-card .plus{width:48px;height:48px;border-radius:14px;background:var(--guinda);color:#fff;display:grid;place-items:center;margin:0 auto 11px}
.new-card .plus svg{width:24px;height:24px}
.new-card b{font-size:15px}.new-card span{display:block;font-size:12.5px;color:var(--gris);margin-top:3px}

/* ---------- Wizard ---------- */
.wizard-wrap{max-width:980px;margin:0 auto}
.steps{display:flex;gap:6px;margin-bottom:26px;background:#fff;border:1px solid var(--linea);padding:8px;border-radius:14px;box-shadow:var(--sombra-sm)}
.step{flex:1;display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:10px;font-size:13px;font-weight:600;color:var(--gris)}
.step .sn{width:24px;height:24px;border-radius:50%;background:var(--crema-2);color:var(--gris);display:grid;place-items:center;font-size:12px;font-weight:700;flex:none}
.step.active{background:var(--guinda);color:#fff}
.step.active .sn{background:var(--dorado);color:var(--guinda)}
.step.done .sn{background:var(--ok);color:#fff}
.step.done{color:var(--tinta)}
.wcard{background:#fff;border:1px solid var(--linea);border-radius:18px;padding:30px 32px;box-shadow:var(--sombra)}
.wcard h3{font-size:19px;font-weight:800;letter-spacing:-.3px}
.wcard .wsub{color:var(--gris);font-size:13.5px;margin-top:5px;margin-bottom:24px}
.wnav{display:flex;justify-content:space-between;margin-top:26px;gap:12px}
.auto-hint{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--verde);background:#e7f1ee;padding:2px 8px;border-radius:20px;margin-left:7px;vertical-align:middle}
.eje-chips{display:flex;flex-wrap:wrap;gap:8px}
.eje{border:1.5px solid var(--linea);border-radius:24px;padding:7px 13px;font-size:12.5px;font-weight:600;color:var(--gris);transition:all .12s;user-select:none;cursor:pointer}
.eje:hover{border-color:var(--dorado)}
.eje.on{background:var(--guinda);color:#fff;border-color:var(--guinda)}
.modesel{display:inline-flex;background:var(--crema-2);border-radius:30px;padding:4px;gap:4px;margin-bottom:20px}
.modesel label{padding:7px 15px;border-radius:24px;font-size:12.5px;font-weight:600;color:var(--gris);cursor:pointer}
.modesel input{display:none}
.modesel input:checked+span{background:#fff;color:var(--guinda);box-shadow:var(--sombra-sm);border-radius:24px;padding:7px 15px;display:inline-block}
.modesel span{padding:7px 15px;display:inline-block;border-radius:24px}

/* ---------- Editor + preview ---------- */
.editor-grid{display:grid;grid-template-columns:minmax(360px,1fr) minmax(420px,1.05fr);gap:20px;align-items:start}
.ed-panel{background:#fff;border:1px solid var(--linea);border-radius:16px;box-shadow:var(--sombra-sm);overflow:hidden}
.ed-panel-head{padding:14px 18px;border-bottom:1px solid var(--linea);display:flex;align-items:center;justify-content:space-between;background:var(--crema)}
.ed-panel-head b{font-size:14px;font-weight:700}
.ed-scroll{padding:18px;max-height:calc(100vh - 220px);overflow:auto}
.accordion{border:1px solid var(--linea);border-radius:12px;margin-bottom:11px;overflow:hidden}
.acc-head{width:100%;text-align:left;padding:12px 15px;background:#fff;display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:13.5px;cursor:pointer}
.acc-head:hover{background:var(--crema)}
.acc-head .ai{display:flex;align-items:center;gap:9px}
.acc-head .badge{font-size:10.5px;font-weight:700;color:var(--dorado-2);background:var(--crema-2);padding:2px 8px;border-radius:20px}
.acc-head svg{width:16px;height:16px;transition:transform .2s;color:var(--gris)}
.acc-body{padding:0 15px;max-height:0;overflow:hidden;transition:max-height .25s ease,padding .25s}
.accordion.open .acc-body{max-height:4000px;padding:6px 15px 16px}
.accordion.open .acc-head svg{transform:rotate(180deg)}
.acc-body label{display:block;font-size:11.5px;font-weight:600;color:var(--gris);margin:11px 0 5px}
.acc-body input,.acc-body textarea{width:100%;padding:9px 11px;border:1.5px solid var(--linea);border-radius:9px}
.list-edit{display:flex;flex-direction:column;gap:7px}
.list-edit .row{display:flex;gap:7px;align-items:flex-start}
.list-edit textarea{min-height:44px;font-size:13px}
.list-edit .del{flex:none;width:32px;height:32px;border-radius:8px;background:var(--crema);color:var(--guinda-3);display:grid;place-items:center;margin-top:2px;border:none}
.list-edit .del:hover{background:#f6dede}
.addline{font-size:12px;font-weight:600;color:var(--guinda);margin-top:8px;display:inline-flex;gap:5px;align-items:center;background:none;border:none;cursor:pointer}
.ed-actions{padding:14px 18px;border-top:1px solid var(--linea);display:flex;gap:9px;flex-wrap:wrap;background:var(--crema)}
.preview-pane{background:#fff;border:1px solid var(--linea);border-radius:16px;box-shadow:var(--sombra-sm);overflow:hidden;position:sticky;top:80px}
.preview-head{padding:12px 18px;border-bottom:1px solid var(--linea);background:var(--crema);display:flex;align-items:center;justify-content:space-between}
.preview-head b{font-size:13px}
.preview-scroll{max-height:calc(100vh - 170px);overflow:auto;background:#e9e4db;padding:16px}

/* ---------- Documento oficial (vista previa = PDF) ---------- */
.doc-page{background:#fff;width:100%;max-width:780px;margin:0 auto 16px;box-shadow:0 2px 10px rgba(0,0,0,.12);padding:34px 38px;font-size:12px;color:#1c1c1c}
.doc-page *{line-height:1.4}
.doc-portada{min-height:560px;display:flex;flex-direction:column;border:3px solid var(--guinda);padding:0;overflow:hidden}
.portada-bar{background:var(--guinda);color:#fff;padding:7px 0;text-align:center;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700}
.portada-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:36px 30px;gap:8px}
.portada-logo{width:96px;height:96px;border-radius:14px;border:2px solid var(--dorado);object-fit:contain;background:#fff;margin-bottom:8px}
.portada-logo.placeholder{display:grid;place-items:center;color:var(--gris);font-size:10px;text-align:center;padding:8px;background:var(--crema)}
.portada-body h1{font-family:'Noto Serif',serif;font-size:30px;color:var(--guinda);letter-spacing:-.5px}
.portada-body .pf{font-size:14px;color:var(--dorado-2);font-weight:700;letter-spacing:1px;text-transform:uppercase}
.portada-meta{margin-top:18px;width:100%;max-width:440px;border-top:1px solid var(--linea)}
.portada-meta .r{display:flex;justify-content:space-between;padding:8px 4px;border-bottom:1px solid var(--linea);font-size:12px}
.portada-meta .r span:first-child{color:var(--gris);font-weight:600}
.portada-meta .r span:last-child{font-weight:700;text-align:right}
.portada-foot{background:var(--crema);padding:14px;text-align:center;font-size:10px;color:var(--gris);border-top:2px solid var(--dorado)}
.gob-mini{display:inline-block;height:5px;width:120px;border-radius:3px;background:linear-gradient(90deg,var(--guinda) 0 33%,var(--dorado) 33% 66%,var(--verde) 66% 100%);margin-bottom:7px}
.doc-h{font-family:'Noto Serif',serif;text-align:center;font-size:17px;color:var(--guinda);font-weight:700;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--dorado)}
table.doc-t{width:100%;border-collapse:collapse;margin-bottom:14px}
table.doc-t td,table.doc-t th{border:1px solid #b9b3a8;padding:6px 8px;vertical-align:top;font-size:11px}
table.doc-t th{background:var(--guinda);color:#fff;font-weight:700;text-align:left}
table.doc-t td.k{background:var(--crema-2);font-weight:700;width:130px;color:var(--guinda)}
.ses-card{border:1px solid #b9b3a8;margin-bottom:13px;overflow:hidden;page-break-inside:avoid}
.ses-head{background:var(--verde);color:#fff;padding:6px 10px;font-weight:700;font-size:12px;display:flex;justify-content:space-between}
.ses-sub{background:var(--crema-2);padding:5px 10px;font-size:10.5px;display:flex;gap:16px;flex-wrap:wrap;border-bottom:1px solid #b9b3a8}
.ses-sub b{color:var(--guinda)}
.ses-body{padding:9px 11px}
.ses-body .blk{margin-bottom:9px}
.ses-body .blk h5{font-size:11px;color:var(--guinda);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-weight:700}
.ses-body ul{margin:0 0 0 16px;font-size:11px}
.ses-body ul li{margin-bottom:2px}
.ses-foot{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid #b9b3a8}
.ses-foot div{padding:7px 9px;font-size:10px;border-right:1px solid #b9b3a8}
.ses-foot div:last-child{border-right:none}
.ses-foot h6{font-size:10px;color:var(--guinda);text-transform:uppercase;margin-bottom:3px;font-weight:700}
.firma-row{display:flex;justify-content:space-around;margin-top:40px;gap:30px}
.firma{text-align:center;font-size:11px;flex:1}
.firma .line{border-top:1.5px solid #555;margin-bottom:5px;padding-top:5px}

/* ---------- Configuración ---------- */
.set-grid{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:start}
.set-nav{display:flex;flex-direction:column;gap:4px;position:sticky;top:80px}
.set-nav a{text-align:left;padding:10px 13px;border-radius:10px;font-size:13.5px;font-weight:600;color:var(--gris);display:flex;gap:9px;align-items:center}
.set-nav a.on{background:var(--guinda);color:#fff}
.set-nav a:not(.on):hover{background:var(--crema-2)}
.set-card{background:#fff;border:1px solid var(--linea);border-radius:16px;padding:26px 28px;box-shadow:var(--sombra-sm);margin-bottom:18px}
.set-card h3{font-size:16px;font-weight:800;margin-bottom:4px}
.set-card .cdesc{color:var(--gris);font-size:13px;margin-bottom:20px}
.swatches{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:8px}
.swatch{width:46px;height:46px;border-radius:12px;cursor:pointer;border:3px solid transparent;position:relative;transition:transform .1s;display:block}
.swatch:hover{transform:scale(1.07)}
.swatch.on{border-color:var(--tinta)}
.logo-drop{border:2px dashed var(--linea);border-radius:14px;padding:24px;text-align:center;background:var(--crema)}
.logo-drop img{max-height:90px;max-width:160px;margin:0 auto 10px;display:block;border-radius:8px}
.provider-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:18px}
.prov{border:1.5px solid var(--linea);border-radius:12px;padding:14px;cursor:pointer;transition:all .12s;display:block}
.prov:hover{border-color:var(--dorado)}
.prov.on{border-color:var(--guinda);background:var(--crema);box-shadow:0 0 0 3px rgba(97,18,50,.08)}
.prov .pn{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:7px}
.prov .pd{font-size:11.5px;color:var(--gris);margin-top:4px}
.prov .reco{font-size:10px;font-weight:700;color:#fff;background:var(--verde);padding:2px 7px;border-radius:20px}
.keyrow{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.json-box{background:#1f1a18;color:#d8cfc4;border-radius:12px;padding:16px;font-family:ui-monospace,Menlo,monospace;font-size:11.5px;line-height:1.6;overflow:auto;max-height:420px;white-space:pre-wrap}

/* ---------- Flash / alerts ---------- */
.flash{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--tinta);color:#fff;padding:12px 20px;border-radius:30px;font-size:13.5px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.25);z-index:100;display:flex;gap:9px;align-items:center;animation:flashIn .25s ease}
@keyframes flashIn{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

@media(max-width:920px){
  .stats{grid-template-columns:1fr 1fr}
  .editor-grid{grid-template-columns:1fr}.preview-pane{position:static}
  .grid2,.grid3{grid-template-columns:1fr}
  .login-card{grid-template-columns:1fr}.login-aside{display:none}
  .set-grid{grid-template-columns:1fr}.set-nav{position:static;flex-direction:row;overflow:auto}
  .provider-cards{grid-template-columns:1fr}
  .steps{overflow:auto}
}

/* =====================================================================
   Rol de director(a): distintivos, autoría y vista de solo lectura
   ===================================================================== */
.role-pill{display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.3px;
  text-transform:uppercase;padding:2px 8px;border-radius:20px;vertical-align:middle}
.role-pill.dir{background:var(--dorado);color:#3a2c10}
.role-pill.dir.topbar{margin-right:8px}
.role-pill.ro{background:#ece7df;color:var(--gris);margin-left:6px}

/* Autoría en las tarjetas (panel del director) */
.autor{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;
  color:var(--guinda);margin:-2px 0 10px}
.autor-ini{display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:var(--guinda);color:#fff;
  font-size:10px;font-weight:800;letter-spacing:.2px;flex:0 0 auto}
.autor-ini.sm{width:20px;height:20px;font-size:9.5px}

/* Aviso de alcance para el director(a) */
.dir-note{display:flex;align-items:center;gap:10px;background:#fff;
  border:1px solid var(--linea);border-left:4px solid var(--dorado);
  border-radius:12px;padding:12px 16px;font-size:13px;color:var(--tinta);
  box-shadow:var(--sombra-sm);margin-bottom:22px}
.dir-note svg{width:18px;height:18px;color:var(--dorado-2);flex:0 0 auto}
.dir-note b{color:var(--guinda)}

/* Contenedor de la vista de solo lectura del documento */
.doc-viewport{background:var(--crema-2);border:1px solid var(--linea);
  border-radius:16px;padding:22px;box-shadow:var(--sombra-sm)}

/* Selector de rol en el registro */
.rol-pick{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rol-opt{position:relative;display:flex;flex-direction:column;gap:2px;
  border:1.5px solid var(--linea);border-radius:12px;padding:12px 12px 12px 40px;
  cursor:pointer;transition:.15s;background:#fff}
.rol-opt input{position:absolute;opacity:0;pointer-events:none}
.rol-opt svg{position:absolute;left:12px;top:13px;width:20px;height:20px;color:var(--gris)}
.rol-opt b{font-size:13.5px;color:var(--tinta)}
.rol-opt span{font-size:11.5px;color:var(--gris);line-height:1.25}
.rol-opt.on{border-color:var(--guinda);background:#fbf4f6;box-shadow:0 0 0 3px rgba(97,18,50,.08)}
.rol-opt.on svg{color:var(--guinda)}
.rol-opt.on b{color:var(--guinda)}
@media(max-width:520px){.rol-pick{grid-template-columns:1fr}}
