:root{
  --bg:#101827; --bg2:#172033; --panel:#1d293d; --panel2:#243249; --line:#334155;
  --text:#ecf3ff; --muted:#9fb0c8; --soft:#c8d3e5; --primary:#7c3aed; --primary2:#22d3ee;
  --green:#34d399; --amber:#fbbf24; --red:#fb7185; --blue:#60a5fa; --shadow:0 18px 50px rgba(0,0,0,.28);
}
*{box-sizing:border-box} html,body{min-height:100%;margin:0} body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#25385e 0,#101827 35%,#0b1120 100%);color:var(--text)}
a{color:inherit;text-decoration:none} button,input,select,textarea{font:inherit} input,select,textarea{width:100%;border:1px solid var(--line);background:#111a2c;color:var(--text);border-radius:14px;padding:13px 14px;outline:none} textarea{min-height:110px;resize:vertical} input:focus,select:focus,textarea:focus{border-color:#8b5cf6;box-shadow:0 0 0 4px rgba(124,58,237,.14)}
.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px max(16px,env(safe-area-inset-left)) 13px max(16px,env(safe-area-inset-left));backdrop-filter:blur(18px);background:rgba(15,23,42,.78);border-bottom:1px solid rgba(148,163,184,.15)}.brand{display:flex;align-items:center;gap:10px;font-weight:900;font-size:18px}.brand-mark{display:grid;place-items:center;width:36px;height:36px;border-radius:13px;background:linear-gradient(135deg,var(--primary),var(--primary2));box-shadow:0 8px 25px rgba(124,58,237,.35)}.top-actions{display:flex;gap:8px}.nav-pill{padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.08);font-weight:800;font-size:13px}.nav-pill.muted{color:var(--muted)}
.container{width:min(100%,980px);margin:0 auto;padding:18px 14px 48px}.hero-dashboard,.detail-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;margin:10px 0 18px}.hero-dashboard h1,.detail-hero h1,.form-page h1{margin:3px 0;font-size:clamp(28px,5vw,42px);letter-spacing:-.04em}.hero-dashboard p,.detail-hero p,.page-subtitle{margin:0;color:var(--muted)}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:#a78bfa!important;font-size:12px;font-weight:900}.btn{border:0;border-radius:15px;padding:12px 16px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn.primary{background:linear-gradient(135deg,var(--primary),#4f46e5);color:white;box-shadow:0 12px 30px rgba(124,58,237,.3)}.btn.ghost,.icon-btn{background:rgba(255,255,255,.08);border:1px solid rgba(148,163,184,.18);color:var(--text)}.btn.full{width:100%}.icon-btn{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-weight:900}.icon-btn.danger{background:rgba(251,113,133,.12);border-color:rgba(251,113,133,.24)}.inline-form{display:inline}.back-link{display:inline-flex;margin:4px 0 14px;color:var(--muted);font-weight:800}.panel,.login-card{background:linear-gradient(180deg,rgba(29,41,61,.96),rgba(25,35,53,.96));border:1px solid rgba(148,163,184,.17);border-radius:24px;box-shadow:var(--shadow);padding:18px;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stat-card{background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.14);border-radius:20px;padding:14px}.stat-icon{font-size:22px}.stat-value{font-size:18px;font-weight:950;margin-top:8px}.stat-label{color:var(--muted);font-size:12px}.violet .stat-value{color:#c4b5fd}.amber .stat-value{color:var(--amber)}.green .stat-value{color:var(--green)}.red .stat-value,.danger-text{color:var(--red)!important}.blue .stat-value{color:var(--blue)}.success-text{color:var(--green)!important}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px}.section-head h2,.section-head h3{margin:0}.section-head p{margin:4px 0 0;color:var(--muted);font-size:14px}.search-input{max-width:300px}.card-list{display:grid;gap:12px}.client-card,.job-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.14);border-radius:19px;padding:15px;transition:.15s}.client-card:hover,.job-card:hover{transform:translateY(-2px);border-color:rgba(167,139,250,.55)}.avatar{flex:none;width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,#7c3aed,#06b6d4);display:grid;place-items:center;font-weight:950}.avatar.big{width:64px;height:64px;font-size:28px}.client-main{flex:1;min-width:0}.client-main strong{display:block;font-size:17px}.client-main span,.muted-text,.empty-line{display:block;color:var(--muted);font-size:14px}.client-money,.job-money{text-align:right;display:grid;gap:4px}.client-money span,.job-money span,.job-money small{color:var(--muted);font-size:13px}.job-title-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.badge.active{background:rgba(52,211,153,.12);color:var(--green)}.badge.done{background:rgba(96,165,250,.12);color:var(--blue)}.badge.paused{background:rgba(251,191,36,.12);color:var(--amber)}.badge.cancelled{background:rgba(251,113,133,.12);color:var(--red)}.hero-buttons{display:flex;gap:8px;align-items:center}.form-stack{display:grid;gap:14px}.form-stack label span{display:block;color:var(--soft);font-weight:800;margin-bottom:7px}.form-grid{display:grid;gap:14px}.form-grid.two{grid-template-columns:repeat(2,1fr)}.readonly>div{background:rgba(255,255,255,.05);border-radius:16px;padding:14px}.readonly span{display:block;color:var(--muted);font-size:13px}.login-card{width:min(100%,430px);margin:11vh auto;text-align:center}.login-logo{font-size:50px}.tiny{font-size:12px;color:var(--muted)}code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:7px}.flash-stack{display:grid;gap:8px;margin-bottom:12px}.flash{padding:12px 14px;border-radius:15px;font-weight:800}.flash.success{background:rgba(52,211,153,.14);color:var(--green)}.flash.error{background:rgba(251,113,133,.14);color:var(--red)}.empty-state{text-align:center;padding:42px;color:var(--muted)}.empty-state div{font-size:48px}.empty-state h3{color:var(--text)}.empty-state.small{padding:20px}.finance-panel{display:grid;gap:10px}.finance-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(148,163,184,.12);padding:8px 0}.finance-row:last-child{border-bottom:0}.expense-form{display:grid;grid-template-columns:1.1fr 1.5fr 110px 150px auto;gap:9px;margin-bottom:14px}.expense-list{display:grid;gap:9px}.expense-row{display:flex;justify-content:space-between;gap:12px;background:rgba(255,255,255,.05);border-radius:16px;padding:12px}.expense-row span{display:block;color:var(--muted);font-size:13px}.expense-right{display:flex;gap:8px;align-items:center}.mini-danger{border:0;background:rgba(251,113,133,.14);color:var(--red);border-radius:10px;padding:6px 9px;font-weight:900}.simple-list{display:grid;gap:8px}.simple-list a{display:flex;justify-content:space-between;gap:12px;background:rgba(255,255,255,.05);border-radius:15px;padding:13px}.simple-list span{color:var(--muted)}.notes-text{line-height:1.6;white-space:pre-wrap;color:var(--soft)}.camera-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.file-tile{display:grid!important;place-items:center;border:1px dashed rgba(148,163,184,.34);border-radius:16px;min-height:48px;background:rgba(255,255,255,.04);cursor:pointer}.file-tile input{display:none}.camera-live{display:grid;gap:10px}.camera-live video{width:100%;max-height:420px;border-radius:18px;background:#000}.camera-actions{display:flex;gap:10px}.hidden{display:none!important}.preview-wrap{background:rgba(52,211,153,.09);border:1px solid rgba(52,211,153,.18);border-radius:18px;padding:10px}.preview-wrap img{width:100%;border-radius:14px;max-height:360px;object-fit:contain;background:#0b1120}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:12px;margin-top:12px}.photo-card{background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.14);border-radius:17px;padding:10px}.photo-card img,.pdf-tile{width:100%;height:125px;object-fit:cover;border-radius:13px;background:#0b1120}.pdf-tile{display:grid;place-items:center;font-size:28px;font-weight:950}.photo-meta{display:grid;gap:2px;margin:8px 0}.photo-meta small{color:var(--muted);font-size:11px}.budget-table-wrap{overflow:auto;border:1px solid rgba(148,163,184,.16);border-radius:18px}.budget-table{width:100%;border-collapse:collapse;min-width:840px}.budget-table th,.budget-table td{text-align:left;border-bottom:1px solid rgba(148,163,184,.12);padding:10px}.budget-table th{color:var(--muted);font-size:12px;text-transform:uppercase}.budget-table input,.budget-table select{padding:9px;border-radius:10px}.budget-total-box,.totals-box{margin-top:14px;margin-left:auto;width:min(100%,360px);display:grid;gap:8px}.budget-total-box,.totals-box>div{background:rgba(255,255,255,.06);border-radius:15px;padding:12px;display:flex;justify-content:space-between}.totals-box .grand{background:linear-gradient(135deg,rgba(124,58,237,.35),rgba(34,211,238,.18));font-size:20px}.comments-box{margin-top:16px;background:rgba(255,255,255,.05);border-radius:16px;padding:14px}.wide{max-width:1100px;margin:auto}
@media(max-width:760px){.topbar{padding-left:12px;padding-right:12px}.brand span:last-child{display:none}.container{padding:14px 10px 40px}.hero-dashboard,.detail-hero{align-items:flex-start}.hero-dashboard{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr);gap:9px}.stat-card{padding:12px}.client-card,.job-card{align-items:flex-start}.client-money,.job-money{text-align:left}.form-grid.two,.camera-grid{grid-template-columns:1fr}.expense-form{grid-template-columns:1fr}.section-head{align-items:flex-start;flex-direction:column}.search-input{max-width:none}.hero-buttons{margin-left:auto}.detail-hero{gap:10px}.avatar.big{width:54px;height:54px}.simple-list a{display:grid}.panel{border-radius:20px;padding:14px}}

/* Gastos & Ganancias */
.finance-filter{display:grid;grid-template-columns:1.1fr 1fr 1fr auto;gap:12px;align-items:end}.finance-accounts-form{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end}.finance-filter label span,.finance-entry-form label span,.finance-accounts-form label span{display:block;color:var(--soft);font-weight:800;margin-bottom:7px}.finance-entry-form{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:end}.finance-entry-form .span-two{grid-column:span 2}.chart-wrap{width:100%;overflow:hidden;border:1px solid rgba(148,163,184,.14);background:rgba(255,255,255,.04);border-radius:18px;padding:12px}.chart-wrap canvas{width:100%;display:block}.finance-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.category-summary{display:grid;gap:9px}.category-summary>div{display:flex;justify-content:space-between;gap:12px;background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.12);border-radius:15px;padding:12px}.category-summary span{color:var(--soft);font-weight:800}.ledger-list{display:grid;gap:9px}.ledger-row{display:flex;justify-content:space-between;align-items:center;gap:14px;background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.12);border-radius:16px;padding:13px}.ledger-row.income{border-left:4px solid var(--green)}.ledger-row.expense{border-left:4px solid var(--red)}.ledger-row span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.ledger-right{display:flex;align-items:center;gap:10px;text-align:right;white-space:nowrap}
@media(max-width:760px){.finance-filter,.finance-entry-form,.finance-accounts-form,.finance-columns{grid-template-columns:1fr}.finance-entry-form .span-two{grid-column:auto}.ledger-row{align-items:flex-start}.ledger-right{align-items:flex-end;flex-direction:column}.top-actions{flex-wrap:wrap;justify-content:flex-end}.nav-pill{padding:8px 10px}}

/* Planes / Rutinas */
.plan-member-form{display:grid;grid-template-columns:1.2fr 1fr auto;gap:12px;align-items:end}
.plan-member-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:14px}
.plan-member-card{display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.14);border-radius:18px;padding:12px}
.plan-member-card strong{display:block}.plan-member-card span{color:var(--muted);font-size:13px}
.plan-type-badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;background:rgba(124,58,237,.16);color:#c4b5fd}
.plan-progress{height:10px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;margin-top:8px}.plan-progress span{display:block;height:100%;background:linear-gradient(135deg,var(--primary),var(--primary2));border-radius:999px}
.plan-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;color:var(--muted);font-size:13px}.plan-card-actions{display:flex;gap:8px;align-items:center}
.plan-items-textarea{min-height:220px;font-family:inherit;line-height:1.5}
.plan-check-wrap{overflow:auto;border:1px solid rgba(148,163,184,.16);border-radius:18px;background:rgba(255,255,255,.03)}
.plan-check-table{width:100%;border-collapse:collapse;min-width:760px}.plan-check-table th,.plan-check-table td{border-bottom:1px solid rgba(148,163,184,.12);border-right:1px solid rgba(148,163,184,.08);padding:9px;text-align:center}.plan-check-table th:first-child,.plan-check-table td:first-child{text-align:left;min-width:260px}.plan-check-table th{color:var(--soft);font-size:12px;text-transform:uppercase}.plan-check-table small{display:block;color:var(--muted);font-size:11px;text-transform:none}.plan-task-input{min-width:240px;padding:9px;border-radius:10px}.plan-check-cell input{width:24px;height:24px;accent-color:#7c3aed}.plan-new-items{margin-top:14px}.plan-print-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
@media(max-width:760px){.plan-member-form{grid-template-columns:1fr}.plan-card-actions{width:100%;justify-content:flex-end}.plan-check-table{min-width:680px}.plan-member-grid{grid-template-columns:1fr}}


/* Finance account highlight cards */
.finance-account-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin:4px 0 16px;
}
.finance-account-card{
  position:relative;
  overflow:hidden;
  min-height:132px;
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 22px 55px rgba(0,0,0,.34);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.finance-account-card:hover{
  transform:translateY(-3px);
  box-shadow:0 28px 70px rgba(0,0,0,.42);
  border-color:rgba(255,255,255,.42);
}
.finance-account-card::after{
  content:"";
  position:absolute;
  right:-46px;
  top:-46px;
  width:145px;
  height:145px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
}
.finance-account-card.bank{background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 48%,#38bdf8 100%)}
.finance-account-card.cash{background:linear-gradient(135deg,#b45309 0%,#f59e0b 48%,#fde047 100%)}
.finance-account-card.total{background:linear-gradient(135deg,#047857 0%,#10b981 48%,#34d399 100%)}
.account-card-icon{
  width:48px;
  height:48px;
  flex:none;
  display:grid;
  place-items:center;
  border-radius:17px;
  background:rgba(255,255,255,.20);
  font-size:26px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);
}
.finance-account-card span,
.finance-account-card small{display:block;color:rgba(255,255,255,.88);font-weight:850}
.finance-account-card strong{
  display:block;
  margin:7px 0 5px;
  color:#fff;
  font-size:clamp(24px,4.2vw,34px);
  font-weight:1000;
  letter-spacing:-.04em;
}
.finance-account-card small{color:rgba(255,255,255,.76);font-size:13px}
.finance-period-stats{grid-template-columns:repeat(4,1fr)}
.finance-filter-note{margin:12px 0 0;color:var(--muted);font-size:14px}
.finance-filter-note a{color:#a78bfa;font-weight:900;text-decoration:underline;text-underline-offset:3px}

/* Finance page with account cards + fixed side calculator */
.finance-page-wide{
  width:min(1280px, calc(100vw - 28px));
  margin-left:50%;
  transform:translateX(-50%);
}
.finance-workspace{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 330px;
  gap:18px;
  align-items:start;
}
.finance-main{min-width:0}
.side-calculator{
  position:sticky;
  top:92px;
}
.side-calculator-card{
  background:linear-gradient(180deg,#1d293d,#111827);
  border:1px solid rgba(148,163,184,.24);
  border-radius:26px;
  padding:18px;
  box-shadow:0 28px 80px rgba(0,0,0,.28);
}
.side-calculator-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:14px;
}
.side-calculator-head h3{
  margin:0;
  font-size:24px;
}
.side-calculator-head p{
  margin:4px 0 0;
  color:var(--muted);
  font-size:13px;
}
.calc-display{
  width:100%;
  text-align:right;
  font-size:30px;
  font-weight:950;
  letter-spacing:.02em;
  padding:15px;
  border-radius:18px;
  margin-bottom:12px;
  background:#0b1120;
}
.calc-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:9px;
}
.calc-grid button{
  min-height:54px;
  border:0;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  color:var(--text);
  font-weight:950;
  font-size:20px;
  cursor:pointer;
}
.calc-grid button:hover{background:rgba(124,58,237,.28)}
.calc-grid button[data-calc-equals]{
  background:linear-gradient(135deg,#7c3aed,#4f46e5);
  color:#fff;
}
.calc-grid button[data-calc-clear],
.calc-grid button[data-calc-back]{
  background:rgba(251,113,133,.16);
  color:var(--red);
}

@media(max-width:1100px){
  .finance-page-wide{
    width:100%;
    margin-left:0;
    transform:none;
  }
  .finance-workspace{grid-template-columns:1fr}
  .side-calculator{
    position:static;
    order:-1;
  }
}
@media(max-width:760px){
  .finance-account-cards,.finance-period-stats{grid-template-columns:1fr}
  .finance-account-card{min-height:118px}
}


/* Multiple finance accounts */
.finance-account-strip{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:10px;
  margin:-4px 0 16px;
}
.finance-mini-account{
  border:1px solid rgba(148,163,184,.16);
  background:rgba(255,255,255,.055);
  border-radius:18px;
  padding:12px;
  display:grid;
  gap:3px;
}
.finance-mini-account span{color:var(--soft);font-weight:900}
.finance-mini-account strong{font-size:18px}
.finance-mini-account small{color:var(--muted)}
.finance-mini-account.bank{border-left:4px solid var(--blue)}
.finance-mini-account.cash{border-left:4px solid var(--amber)}
.finance-mini-account.other{border-left:4px solid #c4b5fd}
.finance-accounts-form.multi{
  grid-template-columns:repeat(3,1fr);
  align-items:end;
}
.finance-accounts-form.multi .accounts-save{
  min-height:48px;
}
.finance-account-list{
  display:grid;
  gap:8px;
  margin:14px 0;
}
.finance-account-list-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(148,163,184,.12);
  border-radius:16px;
  padding:12px;
}
.finance-account-list-row strong{display:block}
.finance-account-list-row span{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.finance-account-list-row.bank{border-left:4px solid var(--blue)}
.finance-account-list-row.cash{border-left:4px solid var(--amber)}
.finance-account-list-row.other{border-left:4px solid #c4b5fd}
.finance-add-account{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid rgba(148,163,184,.14);
}
.finance-add-account h3{
  margin:0 0 10px;
}
.finance-new-account-form{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr auto;
  gap:12px;
  align-items:end;
}
.finance-new-account-form label span{
  display:block;
  color:var(--soft);
  font-weight:800;
  margin-bottom:7px;
}

@media(max-width:900px){
  .finance-accounts-form.multi,.finance-new-account-form{
    grid-template-columns:1fr;
  }
}

/* Assign existing finance entries to an exact account */
.ledger-main-info{min-width:0;display:grid;gap:6px}
.ledger-account-form{margin-top:4px;max-width:260px}
.ledger-account-form label span{display:block;color:var(--muted);font-size:11px;font-weight:900;margin-bottom:4px;text-transform:uppercase;letter-spacing:.08em}
.ledger-account-form select{padding:8px 10px;border-radius:11px;font-size:13px;background:#111a2c}
@media(max-width:760px){.ledger-account-form{max-width:100%}.ledger-account-form select{width:100%}}
