/* ───────── MONEL Costos PWA · estilo mobile-first ───────── */
:root{
  --bg:#0F172A;       /* fondo dark slate */
  --panel:#1E293B;
  --panel-2:#334155;
  --fg:#F1F5F9;
  --muted:#94A3B8;
  --accent:#0D9488;   /* teal MONEL costos */
  --accent-dark:#0F766E;
  --danger:#DC2626;
  --warn:#D97706;
  --ok:#15803D;
  --bd:#334155;
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,"Segoe UI",sans-serif;
  background:var(--bg);color:var(--fg);min-height:100vh;-webkit-text-size-adjust:100%}
body{padding-bottom:max(env(safe-area-inset-bottom),12px)}

/* ── Views (router por hash) ── */
.view{display:none;padding:14px 14px 24px;min-height:100vh}
.view.active{display:block}

/* ── Login ── */
.hero{text-align:center;padding:36px 12px 14px}
.hero-logo{width:96px;height:96px;border-radius:24px;box-shadow:0 8px 24px rgba(13,148,136,.25)}
.hero h1{margin:14px 0 2px;font-size:22px;letter-spacing:.5px}
.hero-sub{margin:0;color:var(--muted);font-size:14px}
.card{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);
  padding:18px;margin:18px auto;max-width:420px;display:flex;flex-direction:column;gap:12px}
label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--muted)}
input,select,textarea{font:inherit;font-size:16px;padding:11px 12px;border:1px solid var(--bd);
  border-radius:8px;background:var(--panel-2);color:var(--fg);width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(13,148,136,.25)}
textarea{resize:vertical;min-height:48px}
.btn-primary{background:var(--accent);color:#fff;border:0;border-radius:8px;
  padding:13px;font-size:16px;font-weight:700;cursor:pointer;margin-top:4px}
.btn-primary:active{background:var(--accent-dark)}
.btn-primary:disabled{opacity:.6}
.error{color:var(--danger);font-size:14px;margin:0;text-align:center}
.hidden{display:none !important}
.hint{text-align:center;color:var(--muted);font-size:12px;margin:8px 0}

/* ── Topbar ── */
#topbar{position:sticky;top:0;z-index:5;background:var(--accent);color:#fff;
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  padding-top:max(env(safe-area-inset-top),10px)}
#topbar h2{flex:1;margin:0;font-size:17px;font-weight:700;text-align:center}
.icon-btn{background:transparent;border:0;color:#fff;font-size:22px;padding:4px 8px;cursor:pointer}
.menu-drop{position:absolute;right:8px;top:calc(env(safe-area-inset-top,0px) + 50px);z-index:10;
  background:var(--panel);border:1px solid var(--bd);border-radius:10px;
  box-shadow:0 8px 22px rgba(0,0,0,.4);min-width:220px}
.menu-drop button{display:block;width:100%;text-align:left;background:transparent;
  color:var(--fg);border:0;padding:13px 16px;font-size:15px;cursor:pointer}
.menu-drop button:active{background:var(--panel-2)}

/* ── Search ── */
.searchbar{padding:8px 0 12px}
.searchbar input{background:var(--panel-2)}

/* ── Lista (proyectos / mis costos) ── */
.list{display:flex;flex-direction:column;gap:10px}
.item-card{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);
  padding:14px;cursor:pointer;transition:transform .08s}
.item-card:active{transform:scale(.99);background:var(--panel-2)}
.item-card .title{font-weight:700;font-size:15px}
.item-card .sub{color:var(--muted);font-size:12px;margin-top:4px}
.item-card .meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;font-size:12px}
.tag{background:var(--panel-2);padding:2px 8px;border-radius:6px}
.tag.ok{background:rgba(21,128,61,.25);color:#86EFAC}
.tag.pend{background:rgba(217,119,6,.25);color:#FCD34D}
.tag.rej{background:rgba(220,38,38,.25);color:#FCA5A5}

/* ── Form costo ── */
.form-grid{display:flex;flex-direction:column;gap:14px;max-width:480px;margin:0 auto}
.row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.banner{background:linear-gradient(90deg,var(--accent),var(--accent-dark));color:#fff;
  border-radius:var(--radius);padding:10px 14px;font-weight:700;font-size:14px}
.total-bar{display:flex;justify-content:space-between;align-items:center;
  background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);
  padding:12px 16px;font-size:15px;color:var(--muted)}
.total-bar strong{color:var(--fg);font-size:18px}
#foto-preview-wrap{display:block;margin-top:6px}
#foto-preview{display:none;max-width:100%;max-height:240px;border-radius:8px;border:1px solid var(--bd)}
#foto-preview[src]{display:block}

/* ── Loader / Toast ── */
.loader{position:fixed;inset:0;background:rgba(15,23,42,.55);
  display:flex;align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(2px)}
.spinner{width:42px;height:42px;border:4px solid var(--panel-2);border-top-color:var(--accent);
  border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  background:var(--panel);color:var(--fg);padding:12px 18px;border-radius:30px;
  border:1px solid var(--bd);box-shadow:0 8px 22px rgba(0,0,0,.4);z-index:60;font-size:14px}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--danger)}

/* ── Tablet+ ── */
@media (min-width: 720px){
  .view{padding:24px}
  .list{max-width:680px;margin:0 auto}
}
