/* Paradise ERP — design system (inspired by bolsa.me/paradise) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#0a1622;
  --bg-2:#06222b;
  --card:#10283a;
  --card-2:#0f2230;
  --border:#234a63;
  --border-soft:#173347;
  --text:#eaf4f4;
  --text-dim:#8fb0bd;
  --text-faint:#5b7b8a;
  --teal:#34b8b0;
  --teal-soft:#34b8b033;
  --gold:#e0b25e;
  --gold-light:#f5c177;
  --gold-soft:#e0b25e33;
  --danger:#e06e6e;
  --info:#7cc6e8;
  --radius:14px;
  --glass:rgba(16,40,58,.9);
  --shadow:0 10px 30px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, #10283a55, transparent 60%),
    radial-gradient(900px 500px at -10% 10%, #34b8b012, transparent 55%),
    var(--bg);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,.serif{font-family:'Fraunces',serif;font-weight:600;letter-spacing:.2px}

/* ---------- Layout shell ---------- */
.shell{display:flex;min-height:100vh}
.sidebar{
  width:248px;flex:0 0 248px;
  background:linear-gradient(180deg,#0c1f2e,#0a1622);
  border-right:1px solid var(--border-soft);
  padding:22px 14px;position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;gap:6px;
}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 18px}
.brand .logo{
  width:40px;height:40px;border-radius:11px;flex:0 0 40px;
  background:linear-gradient(135deg,var(--teal),var(--gold));
  display:grid;place-items:center;color:#06222b;font-family:'Fraunces',serif;font-weight:600;font-size:20px;
  box-shadow:0 6px 16px #34b8b03a;
}
.brand .name{font-family:'Fraunces',serif;font-size:19px;line-height:1.05}
.brand .sub{font-size:11px;color:var(--text-faint);margin-top:2px}

.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-faint);padding:14px 12px 6px}
.nav a{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;border-radius:10px;color:var(--text-dim);
  font-size:14px;font-weight:500;transition:.15s;
}
.nav a .ic{width:18px;text-align:center;opacity:.9}
.nav a:hover{background:#ffffff0a;color:var(--text)}
.nav a.active{background:var(--teal-soft);color:var(--text);box-shadow:inset 0 0 0 1px #34b8b03a}
.nav a.active .ic{color:var(--teal)}
.sidebar .spacer{flex:1}
.user-chip{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:11px;
  background:#0e2230;border:1px solid var(--border-soft);
}
.user-chip .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--teal));
  display:grid;place-items:center;color:#06222b;font-weight:700;font-size:13px}
.user-chip .u-name{font-size:13px;font-weight:600;line-height:1.1}
.user-chip .u-role{font-size:11px;color:var(--text-faint)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 30px;border-bottom:1px solid var(--border-soft);
  background:var(--glass);backdrop-filter:blur(10px);position:sticky;top:0;z-index:5;
}
.topbar .title h1{font-size:24px;margin:0}
.topbar .title .crumb{font-size:12.5px;color:var(--text-faint);margin-top:3px}
.live{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-dim);
  background:#0e2230;border:1px solid var(--border-soft);padding:6px 11px;border-radius:999px}
.live .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px #34b8b033}
.content{padding:26px 30px 60px;max-width:1400px;width:100%}

/* ---------- Cards & grid ---------- */
.grid{display:grid;gap:16px}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1100px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.cols-4,.cols-3,.cols-2{grid-template-columns:1fr}.sidebar{display:none}}

.card{
  background:linear-gradient(180deg,var(--card),var(--card-2));
  border:1px solid var(--border-soft);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow);
}
.card h2,.card h3{margin:0 0 4px;font-size:16px}
.card .card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card .card-head h2{font-size:17px}

/* metric */
.metric .label{font-size:12.5px;color:var(--text-dim);display:flex;align-items:center;gap:8px}
.metric .label .ic{color:var(--teal)}
.metric .value{font-family:'Fraunces',serif;font-size:34px;line-height:1.1;margin-top:8px}
.metric .value small{font-size:15px;color:var(--text-faint);font-family:'Inter',sans-serif}
.metric .sub{font-size:12px;color:var(--text-faint);margin-top:6px}
.metric.gold .value{color:var(--gold-light)}
.metric.teal .value{color:var(--teal)}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{
  text-align:left;font-weight:600;color:var(--text-faint);font-size:11.5px;
  text-transform:uppercase;letter-spacing:.6px;padding:9px 12px;border-bottom:1px solid var(--border-soft);
}
tbody td{padding:11px 12px;border-bottom:1px solid #11293a}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#ffffff05}
.t-strong{font-weight:600}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  padding:4px 10px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.b-ok{background:#34b8b01f;color:#6fcaa0;border-color:#34b8b03a}
.b-info{background:#7cc6e81f;color:#93bbff;border-color:#7cc6e833}
.b-warn{background:#e0b25e1f;color:var(--gold-light);border-color:#e0b25e33}
.b-danger{background:#e06e6e1f;color:#fda4af;border-color:#fb718533}
.b-faint{background:#5b7b8a1f;color:var(--text-dim);border-color:#234a63}

/* ---------- Buttons & forms ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:inherit;font-size:13.5px;
  font-weight:600;padding:9px 16px;border-radius:10px;border:1px solid var(--border);
  background:#0e2230;color:var(--text);transition:.15s}
.btn:hover{border-color:var(--teal);color:#fff}
.btn-primary{background:linear-gradient(135deg,var(--teal),#2aa39b);border-color:transparent;color:#04212a}
.btn-primary:hover{filter:brightness(1.08);color:#04212a}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));border-color:transparent;color:#3a2a08}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-ghost{background:transparent}

label.field{display:block;margin-bottom:14px}
label.field .lab{display:block;font-size:12.5px;color:var(--text-dim);margin-bottom:6px;font-weight:500}
input,select,textarea{
  width:100%;font-family:inherit;font-size:14px;color:var(--text);
  background:#0b1f2c;border:1px solid var(--border);border-radius:10px;padding:10px 12px;outline:none;transition:.15s}
input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px #34b8b022}
select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),linear-gradient(135deg,var(--text-dim) 50%,transparent 50%);
  background-position:calc(100% - 18px) 17px,calc(100% - 13px) 17px;background-size:5px 5px;background-repeat:no-repeat}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > *{flex:1;min-width:160px}

/* ---------- Flash ---------- */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:16px;font-size:13.5px;border:1px solid}
.flash.ok{background:#34b8b015;border-color:#34b8b03a;color:#9fe0d9}
.flash.err{background:#e06e6e15;border-color:#fb718533;color:#fda4af}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:400px;background:linear-gradient(180deg,var(--card),var(--card-2));
  border:1px solid var(--border-soft);border-radius:18px;padding:34px 32px;box-shadow:var(--shadow)}
.login-card .brand{justify-content:center;padding-bottom:6px}
.login-card .tag{text-align:center;color:var(--text-faint);font-size:12.5px;margin-bottom:24px}

/* misc */
.section-title{font-size:13px;color:var(--text-faint);text-transform:uppercase;letter-spacing:1px;margin:26px 0 12px}
.empty{color:var(--text-faint);font-size:13.5px;padding:18px 4px;text-align:center}
.list-line{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #11293a;font-size:13.5px}
.list-line:last-child{border-bottom:none}
.muted{color:var(--text-faint)}
.right{text-align:right}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Ama de Llaves: daily board ---------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.date-nav{display:flex;align-items:center;gap:8px}
.date-nav input[type=date]{width:auto;padding:8px 12px}
.date-nav .navbtn{padding:8px 12px;font-size:15px;line-height:1}
.filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.filters select{width:auto;padding:8px 30px 8px 12px}

.thumb{width:46px;height:34px;border-radius:7px;overflow:hidden;display:inline-block;border:1px solid var(--border);vertical-align:middle}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-empty{width:46px;height:34px;border-radius:7px;display:inline-grid;place-items:center;
  border:1px dashed var(--border);color:var(--text-faint);font-size:15px}
.thumb-row{display:flex;gap:4px;flex-wrap:wrap;max-width:170px}

.staff-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
@media(max-width:1100px){.staff-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.staff-grid{grid-template-columns:1fr}}
.staff-card{background:#0e2230;border:1px solid var(--border-soft);border-radius:12px;padding:13px 14px;transition:.15s}
.staff-card.sel{border-color:var(--teal);box-shadow:inset 0 0 0 1px #34b8b03a}
.staff-card .sid{font-size:11px;color:var(--text-faint);letter-spacing:.5px}
.staff-card .snm{font-family:'Fraunces',serif;font-size:15px;margin:2px 0 9px}
.staff-card .scount{font-size:13px;color:var(--text-dim)}
.staff-card .scount b{color:var(--teal);font-family:'Fraunces',serif;font-size:18px}
.bar{height:6px;border-radius:999px;background:#0a1622;margin-top:9px;overflow:hidden}
.bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--gold))}
.cell-note{color:var(--text-faint);font-size:12.5px}
.danos-cell{color:#fda4af;font-weight:500}

/* ---------- Employee sub-app (mobile-first) ---------- */
.emp-shell{max-width:540px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}
.emp-top{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:15px 18px;border-bottom:1px solid var(--border-soft);
  background:var(--glass);backdrop-filter:blur(10px);position:sticky;top:0;z-index:5}
.emp-main{flex:1;padding:22px 18px}
.emp-foot{text-align:center;padding:20px;font-size:12px}
.hello{font-family:'Fraunces',serif;font-size:27px;line-height:1.15;margin:4px 0 2px}
.big-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  padding:16px;font-size:16px;border-radius:14px;margin-top:20px}
.big-btn[disabled]{opacity:.5;cursor:not-allowed;filter:grayscale(.3)}

/* registrar wizard */
.choice-card{display:flex;align-items:center;gap:14px;width:100%;padding:18px;margin-top:12px;
  background:linear-gradient(180deg,var(--card),var(--card-2));border:1px solid var(--border-soft);
  border-radius:14px;font-size:16px;font-weight:600;color:var(--text);transition:.15s}
.choice-card:hover,.choice-card:active{border-color:var(--teal)}
.choice-card .cic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  font-size:21px;background:var(--teal-soft);color:var(--teal);flex:0 0 46px}
.choice-card .arr{margin-left:auto;color:var(--text-faint);font-size:22px}
.wiz-step{font-size:11.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:1.2px;margin:2px 0 2px}
.back-link{display:inline-flex;gap:6px;align-items:center;color:var(--text-dim);font-size:13.5px;margin-bottom:10px}
.cond{display:none}
.minibar{display:flex;flex-direction:column;gap:6px;background:#0b1f2c;border:1px solid var(--border);border-radius:10px;padding:8px 12px}
.mb-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:5px 0;border-bottom:1px solid #11293a}
.mb-row:last-child{border-bottom:none}
.mb-row span{font-size:14.5px}
.mb-row select{width:74px;padding:7px 24px 7px 12px}
input[type=file]{padding:9px 12px;color:var(--text-dim);font-size:13px}
input[type=file]::file-selector-button{font-family:inherit;font-weight:600;font-size:13px;margin-right:10px;
  padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:#0e2230;color:var(--text);cursor:pointer}
