:root{
  --bg:#08080a; --bg-soft:#101013; --ink:#f4f4f2; --ink-dim:#8d8d88; --ink-faint:#54544f;
  --line:#1f1f22; --line-bright:#2c2c30; --accent:#3b82f6;
  --display:'Jost',sans-serif; --body:'Hanken Grotesk',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
code{background:#000;padding:2px 7px;border-radius:6px;font-size:.9em}

/* ---- Topbar ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 26px;border-bottom:1px solid var(--line);background:rgba(8,8,10,.9);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50}
.topbar .brand img{display:block}
.topnav{display:flex;align-items:center;gap:22px;font-size:.9rem}
.topnav a{color:var(--ink-dim);transition:color .3s}
.topnav a:hover{color:var(--ink)}
.topnav .who{color:var(--ink-faint);font-family:var(--display);font-size:.82rem;letter-spacing:.04em}
.btn-out{border:1px solid var(--line-bright);padding:7px 16px;border-radius:999px;color:var(--ink)!important}
.btn-out:hover{background:var(--ink);color:#000!important;border-color:var(--ink)}

/* ---- Layout ---- */
.wrap{max-width:1080px;margin:0 auto;padding:48px 26px 80px}
.foot{text-align:center;color:var(--ink-faint);font-size:.78rem;padding:30px;border-top:1px solid var(--line)}

.eyebrow{font-family:var(--display);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim)}
.hero-panel{margin-bottom:48px}
.hero-panel h1{font-family:var(--display);font-weight:200;font-size:clamp(2rem,4vw,3rem);margin-top:12px}
.hero-panel p{color:var(--ink-dim);margin-top:10px;max-width:560px}

/* ---- Módulos ---- */
.modgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.mod{position:relative;border:1px solid var(--line);border-radius:18px;padding:30px 28px;background:var(--bg-soft);display:block;transition:border-color .4s,transform .4s}
.mod:not(.soon):hover{border-color:var(--line-bright);transform:translateY(-3px)}
.mod .mod-ic{font-family:var(--display);font-size:1.6rem;color:var(--ink);display:block;margin-bottom:16px}
.mod h3{font-family:var(--display);font-weight:400;font-size:1.3rem}
.mod p{color:var(--ink-dim);margin-top:8px;font-size:.95rem}
.mod .tag{display:inline-block;margin-top:16px;font-family:var(--display);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line-bright);border-radius:999px;padding:4px 11px}
.mod.soon{opacity:.6;cursor:default}
.note{color:var(--ink-faint);font-size:.86rem;margin-top:40px;text-align:center}

/* ---- Login / instalador ---- */
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 90% at 50% 0%, #131316 0%, var(--bg) 55%)}
.login-card{width:100%;max-width:380px;border:1px solid var(--line);border-radius:22px;padding:42px 36px;background:var(--bg-soft)}
.login-logo{display:block;margin:0 auto 26px}
.login-card h1{font-family:var(--display);font-weight:300;font-size:1.7rem;text-align:center}
.login-card .sub{color:var(--ink-dim);text-align:center;margin-top:8px;font-size:.95rem}
.login-card form{margin-top:26px}
.login-card label{display:block;font-family:var(--display);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);margin:16px 0 8px}
.login-card input{width:100%;background:var(--bg);border:1px solid var(--line-bright);border-radius:11px;padding:13px 14px;color:var(--ink);font-family:var(--body);font-size:1rem;transition:border-color .3s}
.login-card input:focus{outline:none;border-color:var(--ink)}
.btn{width:100%;margin-top:24px;background:var(--ink);color:#000;border:none;border-radius:999px;padding:14px;font-family:var(--display);font-size:.95rem;letter-spacing:.04em;cursor:pointer;box-shadow:0 0 26px 1px rgba(255,255,255,.4);transition:box-shadow .3s,transform .3s;display:inline-block;text-align:center}
.btn:hover{transform:translateY(-2px);box-shadow:0 0 36px 3px rgba(255,255,255,.55)}
.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}
.alert{margin-top:18px;background:rgba(220,80,80,.12);border:1px solid rgba(220,80,80,.4);color:#f0b6b6;border-radius:11px;padding:12px 14px;font-size:.9rem}
.alert.ok{background:rgba(80,200,140,.12);border-color:rgba(80,200,140,.4);color:#a8e6c4}

@media(max-width:560px){.wrap{padding:34px 20px 60px}.topnav{gap:14px}.topnav .who{display:none}}

/* ====== EMBUDO DE VENTAS ====== */
.tag.on{color:#a8e6c4;border-color:rgba(80,200,140,.4)}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.metric{border:1px solid var(--line);border-radius:14px;padding:20px 22px;background:var(--bg-soft)}
.metric span{color:var(--ink-dim);font-size:.82rem;display:block}
.metric b{font-family:var(--display);font-weight:200;font-size:1.9rem;margin-top:8px;display:block}
.metric b.accent{color:var(--accent)}
.kbar{margin:6px 0 18px}
.btn-inline{font-family:var(--display);font-size:.86rem;letter-spacing:.04em;color:var(--ink);background:none;border:1px solid var(--line-bright);border-radius:999px;padding:10px 20px;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block}
.btn-inline:hover{border-color:var(--ink)}
.btn-inline.solid{background:var(--ink);color:#000;border-color:var(--ink);box-shadow:0 0 22px 0 rgba(255,255,255,.35)}
.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(230px,1fr);gap:14px;overflow-x:auto;padding-bottom:14px}
.kcol{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;min-height:160px;display:flex;flex-direction:column}
.kcol-head{font-family:var(--display);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);padding:14px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.kcount{background:var(--bg);border:1px solid var(--line-bright);border-radius:999px;padding:1px 9px;font-size:.74rem;color:var(--ink)}
.kcol-body{padding:12px;display:flex;flex-direction:column;gap:10px;flex:1;min-height:60px}
.kcard{background:var(--bg);border:1px solid var(--line-bright);border-radius:11px;padding:14px;cursor:grab;transition:border-color .25s,transform .15s}
.kcard:hover{border-color:var(--ink-dim)}
.kcard:active{cursor:grabbing;transform:scale(.99)}
.kcard h4{font-family:var(--display);font-weight:400;font-size:1rem;line-height:1.25}
.kcard .kcli{display:block;color:var(--ink-dim);font-size:.84rem;margin-top:4px}
.kcard .kval{display:block;font-family:var(--display);color:var(--ink);font-size:.95rem;margin-top:10px}

/* Modal */
.modal{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal.open{display:flex}
.modal-box{width:100%;max-width:620px;background:var(--bg-soft);border:1px solid var(--line-bright);border-radius:20px;padding:34px;position:relative}
.modal-x{position:absolute;top:18px;right:20px;background:none;border:none;color:var(--ink-dim);font-size:1.8rem;line-height:1;cursor:pointer}
.modal-x:hover{color:var(--ink)}
.modal-box h2{font-family:var(--display);font-weight:300;font-size:1.5rem;margin-bottom:22px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ff{margin-bottom:16px}
.ff label{display:block;font-family:var(--display);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:7px}
.ff input,.ff select,.ff textarea{width:100%;background:var(--bg);border:1px solid var(--line-bright);border-radius:10px;padding:12px 13px;color:var(--ink);font-family:var(--body);font-size:.97rem;transition:border-color .3s}
.ff input:focus,.ff select:focus,.ff textarea:focus{outline:none;border-color:var(--ink)}
.ff textarea{resize:vertical}
.modal-actions{display:flex;align-items:center;gap:14px;margin-top:8px}
.btn-del{background:none;border:1px solid rgba(220,80,80,.5);color:#e89a9a;border-radius:999px;padding:10px 20px;font-family:var(--display);font-size:.86rem;cursor:pointer;transition:all .3s}
.btn-del:hover{background:rgba(220,80,80,.15)}

@media(max-width:760px){.metrics{grid-template-columns:1fr 1fr}.frow{grid-template-columns:1fr}}

/* ====== PROYECTOS ====== */
.kbar-split{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.filterbar{display:flex;gap:8px;flex-wrap:wrap}
.fbtn{font-family:var(--display);font-size:.8rem;letter-spacing:.03em;color:var(--ink-dim);background:none;border:1px solid var(--line);border-radius:999px;padding:7px 15px;cursor:pointer;transition:all .25s}
.fbtn:hover{border-color:var(--ink-dim);color:var(--ink)}
.fbtn.active{background:var(--ink);color:#000;border-color:var(--ink)}
.empty{color:var(--ink-dim);padding:30px 0;text-align:center}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.proj{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:20px;cursor:pointer;transition:border-color .25s,transform .15s;display:flex;flex-direction:column;gap:10px}
.proj:hover{border-color:var(--ink-dim);transform:translateY(-2px)}
.proj-top{display:flex;align-items:center;gap:10px}
.proj-tipo{color:var(--ink-dim);font-size:.78rem;letter-spacing:.04em}
.proj h3{font-family:var(--display);font-weight:400;font-size:1.12rem;line-height:1.25}
.proj-cli{color:var(--ink-dim);font-size:.88rem;margin-top:-4px}
.proj-meta{display:flex;justify-content:space-between;font-size:.85rem;color:var(--ink);font-family:var(--display)}
.proj-meta span:last-child{color:var(--ink-dim)}
.proj-foot{display:flex;justify-content:space-between;font-size:.76rem;color:var(--ink-dim)}
.badge{font-family:var(--display);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:999px;border:1px solid var(--line-bright)}
.badge.activo{color:#a8e6c4;border-color:rgba(80,200,140,.45);background:rgba(80,200,140,.08)}
.badge.en_pausa{color:#f0d090;border-color:rgba(220,180,80,.45);background:rgba(220,180,80,.08)}
.badge.terminado{color:#9bc4f0;border-color:rgba(110,160,220,.45);background:rgba(110,160,220,.08)}
.badge.cancelado{color:#d99;border-color:rgba(200,90,90,.4);background:rgba(200,90,90,.08)}
.pbar{height:6px;background:var(--line);border-radius:999px;overflow:hidden}
.pbar i{display:block;height:100%;background:var(--ink);border-radius:999px;transition:width .3s}
input[type=range]{width:100%;accent-color:#fff;cursor:pointer}
input[type=date]{color-scheme:dark}

/* Entregables en el modal */
.ent-block{border-top:1px solid var(--line);margin-top:6px;padding-top:16px;margin-bottom:16px}
.ent-title{display:block;font-family:var(--display);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:10px}
.ent-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.ent-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.ent-item label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.92rem;flex:1}
.ent-item input[type=checkbox]{accent-color:#a8e6c4;width:16px;height:16px}
.ent-item.done span{text-decoration:line-through;color:var(--ink-dim)}
.ent-del{background:none;border:none;color:var(--ink-dim);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 4px}
.ent-del:hover{color:#e89a9a}
.ent-add{display:flex;gap:8px}
.ent-add input{flex:1;background:var(--bg);border:1px solid var(--line-bright);border-radius:10px;padding:10px 12px;color:var(--ink);font-family:var(--body)}
.ent-add input:focus{outline:none;border-color:var(--ink)}
.ent-empty,.ent-load{color:var(--ink-dim);font-size:.86rem}

/* ====== FINANZAS ====== */
.metric b.pos{color:#a8e6c4}
.metric b.neg{color:#e89a9a}
.mes-form{display:flex;align-items:center;gap:10px}
.mes-form label{font-family:var(--display);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim)}
.mes-form select{background:var(--bg);border:1px solid var(--line-bright);border-radius:10px;padding:9px 12px;color:var(--ink);font-family:var(--body)}
.mes-form select:focus{outline:none;border-color:var(--ink)}
.fin-resumen{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:20px 22px;margin-bottom:24px;display:flex;flex-direction:column;gap:14px}
.fin-bar-row{display:grid;grid-template-columns:80px 1fr 130px;align-items:center;gap:14px}
.fin-bar-row span{color:var(--ink-dim);font-size:.85rem}
.fin-bar-row b{font-family:var(--display);font-weight:300;text-align:right}
.fin-track{height:10px;background:var(--line);border-radius:999px;overflow:hidden}
.fin-track i{display:block;height:100%;border-radius:999px;transition:width .4s}
.fin-track i.pos{background:#7fcfa3}
.fin-track i.neg{background:#d98a8a}
.fin-table{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:18px}
.fin-head,.fin-row{display:grid;grid-template-columns:104px 1.6fr 1fr 1.2fr 150px 110px;gap:12px;align-items:center;padding:13px 18px}
.fin-head{background:var(--bg-soft);font-family:var(--display);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);border-bottom:1px solid var(--line)}
.fin-row{border-top:1px solid var(--line);cursor:pointer;transition:background .2s;font-size:.92rem}
.fin-row:first-child{border-top:none}
.fin-row:hover{background:var(--bg-soft)}
.fin-row .r,.fin-head .r{text-align:right}
.fin-row .mono{font-family:var(--display)}
.fin-row .pos{color:#a8e6c4}
.fin-row .neg{color:#e89a9a}
.badge.pagado{color:#a8e6c4;border-color:rgba(80,200,140,.45);background:rgba(80,200,140,.08)}
.badge.pendiente{color:#f0d090;border-color:rgba(220,180,80,.45);background:rgba(220,180,80,.08)}
.tipo-toggle{display:flex;gap:10px;margin-bottom:18px}
.tipo-toggle .tt{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line-bright);border-radius:10px;padding:11px;cursor:pointer;font-family:var(--display);color:var(--ink-dim);transition:all .25s}
.tipo-toggle .tt:has(input:checked){border-color:var(--ink);color:var(--ink);background:var(--bg-soft)}
.tipo-toggle input{accent-color:#fff}

@media(max-width:760px){
  .fin-head{display:none}
  .fin-row{grid-template-columns:1fr 1fr;gap:6px 12px}
  .fin-row span{font-size:.88rem}
  .fin-row span[data-l]::before{content:attr(data-l) ": ";color:var(--ink-dim);font-size:.7rem}
  .fin-row .r{text-align:left}
  .fin-bar-row{grid-template-columns:70px 1fr 100px}
}
