/* =========================================================================
   Altos del Casco — Sistema de diseño compartido
   Paleta "barrio privado": verde monte + dorado antiguo + arena cálida.
   Fuentes: Fraunces (display, carácter) + Outfit (cuerpo, limpia).
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --forest-900:#232c1f;
  --forest-800:#2f3b2a;
  --forest-700:#3f5138;
  --forest-600:#4a6741;
  --gold-600:#b8923a;
  --gold-500:#c9a84c;
  --gold-300:#e3cf91;
  --sand-50:#f7f4ec;
  --sand-100:#f4f1ea;
  --sand-200:#ece7da;
  --sand-300:#ddd6c4;
  --ink:#2a2722;
  --muted:#7d786d;
  --line:#e4ddcd;
  --white:#ffffff;
  --red:#9a3b2e;
  --red-lt:#f6e6e2;
  --green:#4a6741;
  --green-lt:#e6ede2;
  --amber:#a07840;
  --amber-lt:#f2e8d5;
  --radius:14px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(60,52,30,.08);
  --shadow:0 4px 18px rgba(60,52,30,.10);
  --shadow-lg:0 16px 48px rgba(35,44,31,.22);
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Outfit',-apple-system,BlinkMacSystemFont,sans-serif;
}

* { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--sand-100);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a { color:var(--forest-600); }

/* ── AUTH (login / registro) ────────────────────────────────────── */
.auth-wrap {
  min-height:100vh;
  display:grid;
  grid-template-columns:1.05fr 1fr;
}
@media (max-width:880px){ .auth-wrap{ grid-template-columns:1fr; } }

/* Panel lateral con la marca */
.auth-aside {
  position:relative;
  background:
    linear-gradient(160deg, rgba(35,44,31,.86) 0%, rgba(47,59,42,.78) 55%, rgba(35,44,31,.9) 100%),
    url('assets/img/hero.jpg') center 55%/cover no-repeat,
    var(--forest-800);
  color:var(--sand-50);
  padding:56px 52px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
}
@media (max-width:880px){
  .auth-aside{ min-height:230px; padding:36px 32px; }
}
.auth-aside::after{
  content:''; position:absolute; right:-90px; bottom:-90px;
  width:280px; height:280px; border-radius:50%;
  background:radial-gradient(circle, rgba(201,168,76,.25), transparent 70%);
}
.brand { display:flex; align-items:center; gap:14px; position:relative; z-index:1; }
.brand-mark {
  width:50px;height:50px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.brand-name {
  font-family:var(--font-display);
  font-size:21px; font-weight:600; letter-spacing:4px; color:var(--gold-300);
  line-height:1;
}
.brand-sub {
  font-size:10.5px; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold-500); margin-top:5px;
}
.aside-pitch { position:relative; z-index:1; max-width:380px; }
.aside-pitch h2 {
  font-family:var(--font-display);
  font-size:30px; font-weight:500; line-height:1.2; color:var(--sand-50);
  letter-spacing:-.3px;
}
.aside-pitch p { color:#d9d3c4; margin-top:14px; font-size:14.5px; }
.aside-foot { position:relative; z-index:1; font-size:12px; color:#bcb6a6; letter-spacing:.4px; }

/* Panel del formulario */
.auth-main {
  display:flex; align-items:center; justify-content:center;
  padding:48px 40px; background:var(--sand-50);
}
.auth-card { width:100%; max-width:430px; }
.auth-card h1 {
  font-family:var(--font-display);
  font-size:28px; font-weight:600; letter-spacing:-.4px; color:var(--forest-800);
}
.auth-card .lead { color:var(--muted); margin-top:6px; font-size:14.5px; }
.auth-switch { margin-top:22px; font-size:14px; color:var(--muted); text-align:center; }
.auth-switch a { font-weight:600; text-decoration:none; }
.auth-switch a:hover { text-decoration:underline; }

/* ── Formularios ────────────────────────────────────────────────── */
.field { margin-top:16px; }
.field label {
  display:block; font-size:12.5px; font-weight:600; color:var(--forest-700);
  margin-bottom:6px; letter-spacing:.2px;
}
.field .req { color:var(--gold-600); }
.input {
  width:100%; padding:12px 14px; font-family:var(--font-body); font-size:14.5px;
  color:var(--ink); background:var(--white);
  border:1.5px solid var(--line); border-radius:var(--radius-sm);
  transition:border-color .15s, box-shadow .15s; outline:none;
}
.input::placeholder { color:#b3ad9e; }
.input:focus {
  border-color:var(--gold-500);
  box-shadow:0 0 0 3px rgba(201,168,76,.18);
}
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .grid-2{ grid-template-columns:1fr; } }

.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-body); font-size:14px; font-weight:600;
  padding:12px 20px; border-radius:var(--radius-sm); border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; transition:all .15s; white-space:nowrap;
}
.btn-primary { background:var(--forest-700); color:var(--sand-50); }
.btn-primary:hover { background:var(--forest-800); }
.btn-gold { background:var(--gold-500); color:var(--forest-900); }
.btn-gold:hover { background:var(--gold-600); }
.btn-block { width:100%; padding:13px; font-size:15px; margin-top:22px; }
.btn-outline { background:var(--white); color:var(--forest-700); border-color:var(--line); }
.btn-outline:hover { border-color:var(--gold-500); background:var(--sand-50); }
.btn-danger { background:var(--red); color:#fff; }
.btn-danger:hover { filter:brightness(.93); }
.btn-sm { padding:7px 13px; font-size:12.5px; }
.btn:disabled { opacity:.55; cursor:not-allowed; }

/* ── Alertas / flash ────────────────────────────────────────────── */
.alert {
  padding:11px 14px; border-radius:var(--radius-sm); font-size:13.5px;
  margin-bottom:14px; border:1px solid transparent; line-height:1.45;
}
.alert-error   { background:var(--red-lt);   color:var(--red);   border-color:#e6c4bc; }
.alert-success { background:var(--green-lt);  color:var(--green); border-color:#c9d8c0; }
.alert-info    { background:var(--amber-lt);  color:var(--amber); border-color:#e2d2b0; }

.pw-hint { font-size:12px; color:var(--muted); margin-top:6px; }

/* ── APP SHELL (dashboard / admin) ──────────────────────────────── */





.nav-link {
  color:#d9d3c4; text-decoration:none; font-size:13.5px; font-weight:500;
  padding:8px 14px; border-radius:8px; transition:all .15s;
}
.nav-link:hover { background:rgba(255,255,255,.08); color:#fff; }
.nav-link.active { background:var(--gold-500); color:var(--forest-900); font-weight:600; }

.user-chip { font-size:13px; color:#d9d3c4; }
.user-chip strong { color:#fff; font-weight:600; }
.avatar {
  width:34px;height:34px;border-radius:50%;background:var(--gold-500);
  color:var(--forest-900);display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;font-family:var(--font-display);
}

.page { max-width:1440px; margin:0 auto; padding:28px 24px 60px; }
.page-head { margin-bottom:22px; }
.page-head h1 {
  font-family:var(--font-display); font-size:26px; font-weight:600;
  color:var(--forest-800); letter-spacing:-.3px;
}
.page-head p { color:var(--muted); margin-top:4px; font-size:14px; }

/* ── Cards / stats ──────────────────────────────────────────────── */
.card {
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow-sm);
}
.stats-row {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:14px; margin-bottom:22px;
}
.stat {
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 20px; box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden;
}
.stat::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:var(--gold-500);
}
.stat-num { font-family:var(--font-display); font-size:30px; font-weight:600; line-height:1; color:var(--forest-800); }
.stat-label { font-size:12.5px; color:var(--muted); margin-top:6px; }
.stat.red::before{background:var(--red);} .stat.red .stat-num{color:var(--red);}
.stat.amber::before{background:var(--amber);} .stat.amber .stat-num{color:var(--amber);}
.stat.green::before{background:var(--green);} .stat.green .stat-num{color:var(--green);}

/* ── Tablas ─────────────────────────────────────────────────────── */
.table-wrap { overflow:hidden; border-radius:var(--radius); }
.table-scroll { overflow-x:auto; }
table.tbl { width:100%; border-collapse:collapse; }
.tbl thead th {
  background:var(--sand-100); color:var(--forest-700);
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.07em;
  text-align:left; padding:12px 16px; white-space:nowrap;
  border-bottom:1px solid var(--line);
}
.tbl tbody td { padding:13px 16px; font-size:13.5px; border-bottom:1px solid var(--sand-200); vertical-align:middle; }
.tbl tbody tr:last-child td { border-bottom:none; }
.tbl tbody tr:hover { background:var(--sand-50); }

.badge {
  display:inline-flex; align-items:center; gap:6px; padding:4px 11px;
  border-radius:20px; font-size:11.5px; font-weight:600; white-space:nowrap;
}
.badge::before{ content:''; width:6px;height:6px;border-radius:50%; }
.b-pendiente{ background:var(--amber-lt); color:var(--amber);} .b-pendiente::before{background:var(--amber);}
.b-autorizado{ background:var(--green-lt); color:var(--green);} .b-autorizado::before{background:var(--green);}
.b-rechazado{ background:var(--red-lt); color:var(--red);} .b-rechazado::before{background:var(--red);}

.empty {
  text-align:center; padding:54px 20px; color:var(--muted);
}
.empty svg { opacity:.4; margin-bottom:12px; }

/* ── Toast ──────────────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(80px);
  background:var(--forest-800); color:var(--sand-50); padding:12px 22px;
  border-radius:30px; font-size:13.5px; font-weight:500; box-shadow:var(--shadow-lg);
  opacity:0; transition:all .3s; z-index:2000; pointer-events:none;
}
.toast.show { transform:translateX(-50%) translateY(0); opacity:1; }

.muted { color:var(--muted); }
.right { text-align:right; }
.nowrap { white-space:nowrap; }
.flex { display:flex; align-items:center; gap:10px; }
.gap6{gap:6px;} .mt0{margin-top:0;}

/* Marca */




/* Usuario */










/* ── Barra de navegación: sticky, scrollable horizontal ─────── */








/* Ocultar topbar viejo si queda alguna referencia */

/* ═══ HEADER DEL PANEL (sin imagen) ═══════════════════════════ */
.site-header { box-shadow: 0 2px 8px rgba(0,0,0,.15); }

.topbar-main {
  background: var(--forest-900, #232c1f);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  height: 64px;
  gap: 16px;
}
.topbar-brand { display: flex; align-items: center; gap: 12px; }
.topbar-name  {
  font-size: 17px; font-weight: 700; letter-spacing: 3px;
  color: #e3cf91; line-height: 1;
}
.topbar-sub   {
  font-size: 10px; letter-spacing: 2.5px; text-transform: uppercase;
  color: #c9a84c; margin-top: 4px;
}
.topbar-user  { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.topbar-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--gold-500, #c9a84c);
  color: var(--forest-900, #232c1f);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px;
}
.topbar-userinfo { display: flex; flex-direction: column; line-height: 1.25; }
.topbar-username { font-size: 13px; font-weight: 600; color: #fff; }
.topbar-rol      { font-size: 11px; color: #c9a84c; }
.topbar-btn {
  font-size: 12px; font-weight: 600; padding: 6px 13px; border-radius: 7px;
  border: 1.5px solid rgba(201,168,76,.5);
  color: #e3cf91; text-decoration: none; transition: all .15s; white-space: nowrap;
}
.topbar-btn:hover { background: rgba(201,168,76,.18); color: #fff; }
.topbar-btn-out   { border-color: rgba(255,255,255,.25); color: #d9d3c4; }
.topbar-btn-out:hover { background: rgba(255,255,255,.1); color: #fff; }

/* Barra de navegación */
.panel-nav {
  background: var(--forest-800, #2f3b2a);
  border-bottom: 3px solid var(--gold-500, #c9a84c);
  position: sticky; top: 0; z-index: 100;
  overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
}
.panel-nav::-webkit-scrollbar { display: none; }
.panel-nav-inner {
  max-width: 1440px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; gap: 2px;
  white-space: nowrap; height: 46px;
}
.pnav-link {
  color: #c8c0b0; text-decoration: none;
  font-size: 13px; font-weight: 500;
  padding: 7px 12px; border-radius: 7px;
  transition: all .15s; white-space: nowrap;
}
.pnav-link:hover  { background: rgba(255,255,255,.08); color: #fff; }
.pnav-link.active {
  background: var(--gold-500, #c9a84c);
  color: var(--forest-900, #232c1f); font-weight: 700;
}
.pnav-sep {
  display: inline-block; width: 1px; height: 20px;
  background: rgba(255,255,255,.15); margin: 0 8px; vertical-align: middle;
}

/* Ocultar hero/topbar viejos */
.header-hero, .topbar { display: none !important; }
