/* Portal URBIFINCAS — diseño profesional.
   Sin dependencias externas (la CSP prohíbe recursos de fuera): tipografía del
   sistema, iconos SVG inline, todo self-hosted. Pensado también para gente mayor:
   tamaños grandes y buen contraste. */

:root{
  --navy:#0e3457; --navy-2:#0a2540;
  --brand:#215f9e; --brand-strong:#184e85;
  --ink:#0f1f2e; --muted:#5c6b7a; --faint:#8a97a5;
  --line:#e6ecf2; --bg:#eef2f7; --card:#ffffff;
  --r:14px;
  --shadow:0 10px 30px rgba(15,42,72,.10);
  --shadow-sm:0 2px 8px rgba(15,42,72,.07);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg); font-size:16px; line-height:1.5;
  min-height:100vh;
}
a{color:var(--brand)}
img{border:0}

/* ---------- Topbar (portal) ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(100deg,#0e3457,#14507f);padding:15px 28px;
}
.topbar .brand{height:30px;width:auto;display:block}
.topbar .right{display:flex;align-items:center;gap:16px}
.topbar .who{color:#cfe1f1;font-size:.92rem}
.topbar .who b{color:#fff;font-weight:600}
.topbar .out{
  color:#dcebf8;border:1px solid rgba(255,255,255,.3);border-radius:9px;
  padding:8px 15px;font-size:.85rem;text-decoration:none;background:rgba(255,255,255,.06);
}
.topbar .out:hover{background:rgba(255,255,255,.14)}

/* ---------- Portal body ---------- */
.container{max-width:900px;margin:0 auto;padding:34px 20px 60px}
.phead{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:22px}
.phead h1{margin:0 0 4px;font-size:1.7rem;font-weight:750;color:var(--ink);letter-spacing:-.02em}
.phead p{margin:0;color:var(--muted);font-size:.95rem}
.count{background:#e8f0f8;color:#1b5088;border-radius:999px;padding:6px 14px;font-size:.82rem;font-weight:650;white-space:nowrap}

.doclist{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.doc{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line);transition:background .12s;cursor:pointer}
.doc:last-child{border-bottom:none}
.doc:hover{background:#f6f9fc}
.ficon{flex:none;width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;color:#fff;letter-spacing:.03em}
.ficon.pdf{background:linear-gradient(160deg,#e05a5a,#c73b3b)}
.ficon.doc2{background:linear-gradient(160deg,#3f7fc4,#295f9e)}
.doc .meta{flex:1;min-width:0}
.doc .meta .n{font-weight:600;color:var(--ink);font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc .meta .s{color:var(--faint);font-size:.82rem;margin-top:3px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.open{flex:none;display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #d8e2ec;color:var(--brand-strong);font-weight:650;font-size:.88rem;padding:9px 16px;border-radius:10px;cursor:pointer}
.doc:hover .open{background:var(--brand);border-color:var(--brand);color:#fff}

.notice{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:40px 24px;text-align:center;color:var(--muted)}
.notice svg{color:#c4d0dc;margin-bottom:10px}
.notice.error{color:#b3261e}

.footer{text-align:center;margin-top:30px;color:var(--faint);font-size:.82rem}
.footer b{color:#4a6b8a;letter-spacing:.06em;font-weight:700}

/* ---------- Auth (login / mensajes) ---------- */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 18px;
  background:radial-gradient(1100px 460px at 50% -8%, #17456e 0%, transparent 60%), linear-gradient(160deg,#0e3457,#0a2540);}
.login-card{width:100%;max-width:430px;background:var(--card);border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(4,20,40,.4)}
.login-head{background:linear-gradient(160deg,#0e3457,#124370);padding:34px 32px 26px;text-align:center}
.login-head img{height:58px;width:auto;max-width:78%;display:inline-block}
.login-head .sub{color:#9fc0e0;font-size:.72rem;letter-spacing:.2em;margin-top:14px;font-weight:600}
.login-body{padding:34px 34px 28px}
.login-body h1{margin:0 0 8px;font-size:1.42rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.login-body p.lead{margin:0 0 22px;color:var(--muted);font-size:.96rem}
.field{position:relative;margin-bottom:16px}
.field .i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--faint);display:flex}
.field input{width:100%;padding:15px 14px 15px 44px;border:1.5px solid var(--line);border-radius:11px;font-size:1rem;background:#fbfcfe;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(33,95,158,.12)}
.btn{display:block;width:100%;border:none;cursor:pointer;background:linear-gradient(180deg,#2a6fb0,#1d5893);color:#fff;font-size:1.02rem;font-weight:650;padding:15px;border-radius:11px;box-shadow:0 6px 16px rgba(27,78,133,.28)}
.btn:hover{filter:brightness(1.05)}
.btn-link{display:inline-block;margin-top:6px;text-decoration:none;background:linear-gradient(180deg,#2a6fb0,#1d5893);color:#fff;font-weight:650;padding:13px 22px;border-radius:11px}
.trust{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:18px;color:var(--faint);font-size:.8rem}
.login-foot{text-align:center;color:var(--faint);font-size:.8rem;padding:0 32px 28px}
.msg-icon{display:flex;justify-content:center;margin-bottom:6px;color:var(--brand)}

/* ---------- Modal visor ---------- */
.modal-overlay{position:fixed;inset:0;height:100vh;height:100dvh;z-index:50;display:none;align-items:center;justify-content:center;padding:26px;background:rgba(8,18,30,.66)}
.modal-overlay.open{display:flex}
.modal{width:100%;max-width:920px;height:100%;max-height:90vh;background:#fff;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 70px rgba(0,0,0,.45)}
.modal-head{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);background:#fff;flex:none;z-index:2;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.modal-head .ic{width:34px;height:34px;border-radius:8px;background:linear-gradient(160deg,#e05a5a,#c73b3b);color:#fff;font-size:.5rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex:none}
.modal-head .mt{flex:1;min-width:0;font-weight:650;color:var(--ink);font-size:.96rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dl{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,#2a6fb0,#1d5893);color:#fff;border:none;font-weight:650;font-size:.88rem;padding:9px 16px;border-radius:10px;cursor:pointer;text-decoration:none}
.dl:hover{filter:brightness(1.05)}
.xbtn{width:42px;height:42px;border-radius:10px;border:1px solid var(--line);background:#f3f6f9;color:#33475b;cursor:pointer;font-size:1.15rem;line-height:1;flex:none}
.xbtn:hover{background:#e7edf2}
.modal-body{flex:1;background:#e9edf1;min-height:0}
.modal-body iframe{width:100%;height:100%;border:0;display:block}

/* ---------- Responsive ---------- */
@media (max-width:600px){
  .topbar{padding:13px 18px}
  .topbar .who{display:none}
  .phead h1{font-size:1.4rem}
  .doc{padding:14px 14px}
  .open span{display:none}
  .modal-overlay{padding:0}
  .modal{max-height:100dvh;height:100dvh;border-radius:0}
  .modal-head .mt{font-size:.9rem}
  .xbtn{width:44px;height:44px}
}
