/* =============================================================================
   App stylesheet for Caballeros de la Orden de Alcantara.
   Heraldic theme lifted from the approved HTML mockups (green / paper / gold).
   Date: 2026-06-24
   ============================================================================= */
:root{--green:#1f6b45;--sidebar:#122e20;--paper:#f5f2ea;--surf:#fcfaf5;--ink:#20271f;
--muted:#6a7268;--line:#e4dece;--gold:#9c7e45;--tint:#e8f0e8;--tintb:#cfe0d2;
--serif:"Fraunces",Georgia,"Times New Roman",serif;--sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit}
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--sidebar);color:#e9e2d0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;gap:12px;align-items:center;padding:22px 20px 18px}
.brand .nm{font-family:var(--serif);font-weight:600;font-size:16px;color:#f4eedd;line-height:1.15}
.brand .sub{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#9db3a3;margin-top:2px}
.nav{padding:8px 12px;flex:1}
.nav a{display:flex;gap:11px;align-items:center;padding:10px 12px;border-radius:7px;color:#c6d2c8;text-decoration:none;font-size:13.5px;border-left:3px solid transparent}
.nav a:hover{background:rgba(255,255,255,.05);color:#eef3ee}
.nav a.on{background:rgba(156,126,69,.16);color:#fff;border-left-color:var(--gold);font-weight:500}
.nav .ic{width:18px;text-align:center;opacity:.85;font-size:15px}
.side .foot{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:10.5px;color:#8aa093;letter-spacing:.04em}
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 28px;background:var(--surf);border-bottom:1px solid var(--line)}
.crumb{font-size:12.5px;color:var(--muted)}.crumb b{color:var(--ink);font-weight:500}
.spacer{flex:1}
.topsearch{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:7px 12px;width:320px;color:var(--muted)}
.topsearch input{border:0;background:transparent;outline:0;flex:1;font-size:13px;color:var(--ink)}
.who{display:flex;align-items:center;gap:9px;font-size:13px}
.who .av{width:30px;height:30px;border-radius:50%;background:var(--tint);color:var(--green);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;border:1px solid var(--tintb)}
.who a{color:var(--muted);text-decoration:none;font-size:13px}
.content{padding:28px;max-width:1180px;width:100%}
.page-h{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px}
.page-h h1{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:-.01em}
.page-h .meta{color:var(--muted);font-size:13px;margin-top:4px}
.page-h .meta b{color:var(--green);font-weight:600}
.btn{font-family:var(--sans);font-size:13.5px;font-weight:500;border:1px solid var(--line);background:var(--surf);color:var(--ink);padding:9px 15px;border-radius:8px;cursor:pointer;display:inline-flex;gap:8px;align-items:center;text-decoration:none}
.btn:hover{border-color:var(--tintb)}
.btn.prim{background:var(--green);border-color:var(--green);color:#fff}
.btn.prim:hover{background:#185a3a}
.btn.gh{background:transparent}
.btn.danger{color:#b71c1c;border-color:#f0c9c4}
.rule{height:2px;width:46px;background:var(--gold);border-radius:2px;margin:0 0 2px}
.card{background:var(--surf);border:1px solid var(--line);border-radius:12px}
.filters{display:flex;gap:12px;align-items:center;padding:14px 16px;margin-bottom:18px;flex-wrap:wrap}
.field{display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--paper);border-radius:8px;padding:8px 12px}
.field.grow{flex:1}.field input,.field select{border:0;background:transparent;outline:0;font-size:13.5px;color:var(--ink);width:100%}
.field .ic{color:var(--muted);font-size:15px}
table{width:100%;border-collapse:collapse;background:var(--surf)}
thead th{text-align:left;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:13px 16px;border-bottom:1px solid var(--line)}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#f7f4ec}
.orden{font-variant-numeric:tabular-nums;font-weight:600;color:var(--green)}
.sig{font-family:var(--serif);font-size:13px;color:var(--muted)}
.nm{font-weight:500}.nm small{display:block;color:var(--muted);font-weight:400;font-size:12px}
.tag{display:inline-block;font-size:11.5px;padding:3px 9px;border-radius:20px;background:var(--tint);color:#16573a;border:1px solid var(--tintb)}
.rowact a{color:var(--muted);text-decoration:none;font-size:15px;padding:5px;border-radius:6px}
.rowact a:hover{color:var(--green);background:var(--tint)}
.tfoot{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;color:var(--muted);font-size:12.5px}
.pager{display:flex;gap:4px;flex-wrap:wrap}.pager span,.pager a{min-width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:7px;text-decoration:none;color:var(--ink);font-size:12.5px}
.pager .cur{background:var(--green);color:#fff;border-color:var(--green)}
.detail-h{background:var(--surf);border:1px solid var(--line);border-radius:12px;padding:22px 24px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.detail-h .nme{font-family:var(--serif);font-size:26px;font-weight:600;letter-spacing:-.01em}
.chips{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.chip{font-size:12px;color:var(--muted);background:var(--paper);border:1px solid var(--line);border-radius:7px;padding:5px 10px}
.chip b{color:var(--ink);font-weight:600}
.gen-label{font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:26px 0 12px;display:flex;align-items:center;gap:10px}
.gen-label::after{content:"";flex:1;height:1px;background:var(--line)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pcard{background:var(--surf);border:1px solid var(--line);border-radius:11px;padding:15px 16px}
.pcard.empty{background:#faf8f1;border-style:dashed}
.pcard .role{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:7px}
.pcard .pn{font-family:var(--serif);font-size:16px;font-weight:600;line-height:1.25}
.pcard .pmeta{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5}
.pcard .none{font-size:12.5px;color:#aaa39a;font-style:italic}
.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;font-size:13px}
.kv dt{color:var(--muted)}.kv dd{color:var(--ink)}
.banner{display:flex;gap:12px;align-items:flex-start;background:var(--tint);border:1px solid var(--tintb);border-radius:10px;padding:13px 16px;margin-bottom:20px;color:#16573a;font-size:13px}
.banner .ic{font-size:18px;margin-top:1px}
.banner.ok{background:#f0fdf4;border-color:#bbf7d0;color:#14532d}
.banner.err{background:#fdecea;border-color:#f0c9c4;color:#b71c1c}
.sect{background:var(--surf);border:1px solid var(--line);border-radius:12px;margin-bottom:14px;overflow:hidden}
.sect>h3{display:flex;align-items:center;gap:11px;padding:15px 18px;font-family:var(--serif);font-size:16px;font-weight:600;cursor:pointer;background:var(--surf)}
.sect>h3 .cv{margin-left:auto;color:var(--muted);font-size:13px;font-weight:400;font-family:var(--sans)}
.sect>h3 .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.sect .body{padding:6px 18px 20px;border-top:1px solid var(--line)}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 18px;margin-top:14px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.w2{grid-column:span 2}.fg.w3{grid-column:span 3}
.fg label{font-size:11.5px;color:var(--muted);font-weight:500}
.fg input,.fg textarea,.fg select{font-family:var(--sans);font-size:13.5px;color:var(--ink);border:1px solid var(--line);background:var(--paper);border-radius:7px;padding:8px 11px;outline:0;width:100%}
.fg input:focus,.fg textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,107,69,.12)}
.fg textarea{resize:vertical;min-height:60px}
.subh{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:18px 0 2px}
.formfoot{display:flex;justify-content:flex-end;gap:10px;padding:18px 0 6px}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.tabs a{padding:9px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surf);text-decoration:none;color:var(--ink);font-size:13px}
.tabs a.on{background:var(--green);color:#fff;border-color:var(--green)}
/* public (login / landing) */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#122e20,#1f6b45)}
.auth-card{background:var(--surf);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.25);width:380px;max-width:92vw;padding:34px 32px}
.auth-card h1{font-family:var(--serif);font-size:22px;font-weight:600;margin-top:14px}
.auth-card .sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.auth-card label{font-size:12px;color:var(--muted);font-weight:500;display:block;margin:12px 0 5px}
.auth-card input{width:100%;border:1px solid var(--line);background:var(--paper);border-radius:8px;padding:10px 12px;font-size:14px;outline:0}
.auth-card input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,107,69,.12)}
.auth-card .btn{width:100%;justify-content:center;margin-top:18px}
.brandmark{display:flex;gap:12px;align-items:center}
.landing{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:linear-gradient(160deg,#122e20,#1f6b45);color:#f4eedd;padding:40px}
.landing h1{font-family:var(--serif);font-size:38px;font-weight:600;margin:18px 0 6px}
.landing p{color:#cfe0d2;font-size:15px;max-width:560px;margin-bottom:8px}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:8px;width:100%;max-width:760px}
.tile{background:var(--surf);border:1px solid var(--line);border-radius:14px;padding:22px;text-decoration:none;color:var(--ink);text-align:left}
.tile:hover{border-color:var(--tintb)}
.tile .ti{font-size:24px;color:var(--green)}
.tile h3{font-family:var(--serif);font-size:18px;font-weight:600;margin:10px 0 4px}
.tile p{color:var(--muted);font-size:13px;margin:0}
@media(max-width:900px){.app{grid-template-columns:1fr}.side{display:none}.grid4{grid-template-columns:1fr 1fr}.fgrid{grid-template-columns:1fr 1fr}}
