@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f7f3f0;
  --surface:#ffffff;
  --surface2:#f3ede9;
  --border:#e4dcd6;
  --border2:#d6c8c0;
  --text:#2b2b2b;
  --muted:#7a6f69;
  --muted2:#a09e97;
  --primary:#8f2d3a;
  --primary-l:#f6e9eb;
  --primary-h:#7a2531;
  --primary-mid:#c06a75;
  --ok:#2d6a1f;--ok-l:#e8f5e2;
  --warn:#b07a2a;--warn-l:#fdf0e0;
  --err:#9b2626;--err-l:#fceaea;
  --info:#1358a3;--info-l:#e5f0fc;
  --r:8px;--rl:12px;--rxl:18px;
  --sh:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --sh-md:0 4px 16px rgba(0,0,0,.1);
  --sh-lg:0 12px 40px rgba(0,0,0,.15);
  --gold: #c9a14a;        
}

body{
  font-family:'DM Sans',system-ui,sans-serif;
  font-size:15px;color:var(--text);background:var(--bg);
  min-height:100vh;display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

/* NAV */
nav{
  background:var(--primary);height:54px;
  display:flex;align-items:center;gap:4px;padding:0 1.25rem;
  position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(122,31,42,.25);
}
.brand{
  font-weight:700;font-size:15px;color:#fff;text-decoration:none;
  white-space:nowrap;display:flex;align-items:center;gap:8px;
  padding-right:12px;margin-right:4px;border-right:1px solid rgba(255,255,255,.2);
}
.brand img{height:26px;width:auto;border-radius:3px}
.nav-links{display:flex;gap:1px;flex:1;flex-wrap:wrap;overflow:hidden}
.nav-links a{
  padding:6px 11px;border-radius:var(--r);color:#fff;
  text-decoration:none;font-size:14.5px;font-weight:700;transition:.15s;white-space:nowrap;
}
.nav-links a:hover{background:rgba(255,255,255,.13);color:#fff}
.nav-links a.active{background:rgba(255,255,255,.2);color:#fff;font-weight:600}
.nav-user{display:flex;align-items:center;gap:10px;font-size:14.5px;color:#fff;font-weight:700; white-space:nowrap;margin-left:6px}
.btn-link{color:#fff;text-decoration:none;font-size:14px;font-weight:700;padding:6px 12px;border-radius:var(--r);transition:.15s}
.btn-link:hover{background:rgba(255,255,255,.18);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:5px;color:#fff;font-size:22px;line-height:1}

/* MAIN */
main{flex:1;padding:1.5rem;max-width:1280px;width:100%;margin:0 auto}
h1{font-size:21px;font-weight:700;margin-bottom:1.25rem;letter-spacing:-.01em}
footer{text-align:center;padding:.75rem;font-size:12px;color:var(--muted);border-top:1px solid var(--border)}

/* ALERTS */
.alert{padding:11px 15px;border-radius:var(--r);margin-bottom:1.25rem;font-size:14px;border-left:3px solid currentColor}
.alert-ok{background:var(--ok-l);color:var(--ok)}
.alert-error{background:var(--err-l);color:var(--err)}
.alert-info{background:var(--info-l);color:var(--info)}
.alert-warn{background:var(--warn-l);color:var(--warn)}

/* CARD */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:1.25rem;box-shadow:var(--sh)}
.card-title{font-size:11px;font-weight:700;margin-bottom:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* METRICS */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:1.5rem}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:.9rem 1.1rem;box-shadow:var(--sh);transition:box-shadow .15s}
.metric:hover{box-shadow:var(--sh-md)}
.metric .lbl{font-size:11px;color:var(--muted);margin-bottom:3px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.metric .val{font-size:24px;font-weight:700;letter-spacing:-.02em}
.metric .sub{font-size:11px;color:var(--muted2);margin-top:2px}

/* BUTTONS */
.btn,.btn-p,.btn-ok,.btn-err,.btn-warn{
  display:inline-flex;align-items:center;gap:6px;padding:8px 15px;
  border-radius:var(--r);border:1.5px solid var(--border2);
  background:var(--surface);color:var(--text);
  font-size:14px;font-weight:500;font-family:inherit;
  cursor:pointer;text-decoration:none;transition:all .15s;
  white-space:nowrap;line-height:1;box-shadow:var(--sh);
}
.btn:hover{background:var(--bg);box-shadow:var(--sh-md)}
.btn-p{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px rgba(122,31,42,.28)}
.btn-p:hover{background:var(--primary-h);box-shadow:0 4px 14px rgba(122,31,42,.38)}
.btn-ok{background:var(--ok);color:#fff;border-color:var(--ok)}
.btn-ok:hover{opacity:.9}
.btn-err{color:var(--err);border-color:#e8a0a0}
.btn-err:hover{background:var(--err-l);border-color:var(--err)}
.btn-warn{background:var(--warn);color:#fff;border-color:var(--warn)}
.btn-warn:hover{opacity:.9}
.btn-sm{padding:5px 11px;font-size:13px;gap:4px;box-shadow:none}

/* TOOLBAR */
.tb{display:flex;gap:8px;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}
.tb-space{flex:1}
.search{padding:8px 12px;border:1.5px solid var(--border2);border-radius:var(--r);font-size:14px;min-width:200px;background:var(--surface);font-family:inherit;transition:.15s}
.search:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(122,31,42,.10)}
select.sel{padding:8px 11px;border:1.5px solid var(--border2);border-radius:var(--r);font-size:14px;background:var(--surface);cursor:pointer;font-family:inherit}
select.sel:focus{outline:none;border-color:var(--primary)}

/* TABLE */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:11px;font-weight:700;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;background:var(--surface2)}
td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--bg)}

/* BADGE */
.b{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600}
.b-alta,.b-ok{background:var(--ok-l);color:var(--ok)}
.b-baixa,.b-baja,.b-err{background:var(--err-l);color:var(--err)}
.b-warn{background:#f4e7cf;color:var(--warn)}
.b-info{background:var(--info-l);color:var(--info)}
.b-infantil{background:#fce8f0;color:#8b2252}
.b-major,.b-mayor{background:var(--primary-l);color:var(--primary)}
.b-jove,.b-juvenil{background:#e0f5ed;color:#0e6b50}
.b-borrador{background:var(--warn-l);color:var(--warn)}
.b-enviada{background:var(--info-l);color:var(--info)}
.b-cerrada{background:var(--ok-l);color:var(--ok)}

/* AVATAR */
.av{width:34px;height:34px;border-radius:50%;background:var(--primary-l);color:var(--primary);font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.soc-cell{display:flex;align-items:center;gap:10px}
.soc-name{font-weight:600;line-height:1.2}
.soc-sub{font-size:11px;color:var(--muted)}

/* FORM */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:.9rem}
.fg label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.fg input,.fg select,.fg textarea{padding:8px 11px;border:1.5px solid var(--border2);border-radius:var(--r);font-size:14px;background:var(--surface);color:var(--text);font-family:inherit;transition:.15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(122,31,42,.10)}
.fg textarea{resize:vertical;min-height:70px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.full{grid-column:1/-1}
.fsec{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding-bottom:6px;border-bottom:2px solid var(--primary-l);margin:1.3rem 0 .85rem}
.factions{display:flex;gap:8px;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);flex-wrap:wrap}

/* TABS */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem;gap:2px}
.tab{padding:9px 15px;font-size:14px;font-weight:500;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit;transition:.15s;border-radius:var(--r) var(--r) 0 0}
.tab:hover{color:var(--text);background:var(--bg)}
.tab.on{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}

/* PROGRESS */
.prog{height:7px;background:var(--bg);border-radius:4px;overflow:hidden}
.prog-bar{height:100%;background:var(--primary);border-radius:4px;transition:width .3s}

/* EMPTY */
.empty{text-align:center;padding:2.5rem;color:var(--muted);font-size:14px}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%)}
.login-box{background:var(--surface);border-radius:var(--rxl);padding:2.25rem;width:100%;max-width:370px;box-shadow:var(--sh-lg)}
.login-logo{text-align:center;margin-bottom:1.75rem}
.login-logo img{height:68px;width:auto}
.login-logo h1{font-size:20px;margin-top:10px;font-weight:700}
.login-logo p{font-size:13px;color:var(--muted);margin-top:4px}

/* PAGINATION */
.pag{display:flex;gap:3px;margin-top:.75rem;justify-content:center;flex-wrap:wrap}
.pag a{padding:5px 10px;border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;text-decoration:none;color:var(--text);background:var(--surface);transition:.15s}
.pag a:hover{border-color:var(--primary);color:var(--primary)}
.pag a.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* MODAL bg inline */
[id^="modal-"]{position:fixed;inset:0;background:rgba(15,14,12,.45);backdrop-filter:blur(2px);z-index:200;align-items:center;justify-content:center}

/* RESPONSIVE */
@media(max-width:768px){
  nav{padding:0 1rem;gap:6px;height:52px}
  .nav-links{
    display:none;position:fixed;top:52px;left:0;right:0;
    background:var(--primary);padding:6px;
    flex-direction:column;gap:2px;z-index:49;
    box-shadow:0 6px 20px rgba(0,0,0,.2);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:10px 14px;font-size:15px}
  .nav-toggle{display:block}
  .nav-user span{display:none}
  main{padding:1rem}
  h1{font-size:19px}
  .grid2,.grid3{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .card{padding:1rem}
  .tb{gap:6px}
  .search{min-width:0;flex:1}
  th,td{padding:8px 9px}
}
@media(max-width:480px){
  .metrics{grid-template-columns:1fr 1fr}
  .metric .val{font-size:20px}
}

.modal-bg{display:none}

/* =========================================================
   FIX MÓVIL MENÚ + INICIO
   PC no cambia
   ========================================================= */

.nav-mobile-user{
  display:none;
}

@media (max-width:900px){

  body{overflow-x:hidden}

  nav{
    height:56px !important;
    min-height:56px !important;
    padding:0 12px !important;
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
  }

  .brand{
    border-right:0 !important;
    padding-right:0 !important;
    margin-right:0 !important;
    max-width:210px !important;
    min-width:0 !important;
    flex:1 1 auto !important;
  }

  .brand img{
    width:28px !important;
    height:28px !important;
    max-width:28px !important;
    max-height:28px !important;
    object-fit:contain !important;
    border-radius:50% !important;
    flex-shrink:0 !important;
  }

  .brand span{
    max-width:155px !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
  }

  .nav-toggle{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:42px !important;
    min-width:42px !important;
    height:42px !important;
    margin-left:auto !important;
    background:rgba(255,255,255,.14) !important;
    border:0 !important;
    border-radius:8px !important;
    color:#fff !important;
    z-index:1002 !important;
    flex-shrink:0 !important;
  }

  .nav-toggle svg{
    width:26px !important;
    height:26px !important;
  }

  .nav-user{
    display:none !important;
  }

  .nav-links{
    position:fixed !important;
    top:56px !important;
    right:10px !important;
    left:auto !important;
    bottom:auto !important;
    width:280px !important;
    max-width:85vw !important;
    display:none !important;
    flex-direction:column !important;
    flex-wrap:nowrap !important;
    align-items:stretch !important;
    background:var(--surface) !important;
    color:var(--text) !important;
    padding:10px !important;
    border-radius:0 0 14px 14px !important;
    box-shadow:0 12px 30px rgba(0,0,0,.25) !important;
    z-index:1001 !important;
    overflow-y:auto !important;
    max-height:calc(100vh - 56px) !important;
  }

  .nav-links.open{
    display:flex !important;
  }

  .nav-links a{
    display:block !important;
    color:var(--text) !important;
    background:transparent !important;
    padding:12px 14px !important;
    font-size:16px !important;
    font-weight:700 !important;
    border-radius:10px !important;
  }

  .nav-links a.active,
  .nav-links a:hover{
    background:var(--primary-l) !important;
    color:var(--primary) !important;
  }

  .nav-mobile-user{
    display:block !important;
    margin-top:10px;
    padding-top:10px;
    border-top:1px solid var(--border);
  }

  .nav-mobile-name{
    font-size:14px;
    font-weight:700;
    padding:10px 12px;
    color:var(--text);
  }

  .nav-mobile-logout{
    display:block;
    padding:12px;
    margin-top:4px;
    border-radius:8px;
    background:var(--primary);
    color:#fff;
    text-decoration:none;
    font-weight:600;
    text-align:center;
  }

  main{
    padding:1rem !important;
    width:100%;
    max-width:100%;
    overflow-x:hidden;
  }
}

@media (max-width:600px){
  .brand span{
    max-width:135px !important;
  }

  .metrics{
    grid-template-columns:1fr !important;
  }

  .grid2,
  .grid3{
    grid-template-columns:1fr !important;
  }

  .tb{
    flex-direction:column;
    align-items:stretch;
  }

  .tb > *,
  .tb a,
  .tb button,
  .tb input,
  .tb select{
    width:100%;
  }
}