﻿:root{
 --bd:#1a2e6e;--bm:#1e4db7;--bl:#2d7dd2;--bp:#e8f1fb;--br:#d6eaf8;
 --grn:#1e8449;--red:#c0392b;--org:#e67e22;--gray:#f4f6f9;--bdr:#c5d8f0;--txt:#1a1a2e;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Barlow',sans-serif;background:linear-gradient(145deg,#0b1640 0%,#1a3a8f 55%,#094f8a 100%);min-height:100vh;padding:24px 14px;color:var(--txt)}
.hdr{text-align:center;margin-bottom:22px;color:#fff;position:relative}
/* Modo presentación */
body.modo-presentacion .costo-panel { display:none !important; }
body.modo-presentacion #pago-modo-wrap { display:none !important; }
body.modo-presentacion #gen-btn-save { display:none !important; }
body.modo-presentacion .presentacion-oculto { display:none !important; }
#btn-presentacion.activo { background:rgba(255,220,0,.25); border-color:rgba(255,220,0,.6); color:#ffe066; }
.hdr h1{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:900;letter-spacing:2px;text-transform:uppercase}
.hdr p{font-size:.85rem;opacity:.65;margin-top:4px}
.firebase-status{
 position:absolute;
 top:10px;
 right:10px;
 display:flex;
 align-items:center;
 gap:8px;
 background:rgba(255,255,255,.1);
 backdrop-filter:blur(10px);
 border:1.5px solid rgba(255,255,255,.2);
 border-radius:20px;
 padding:6px 14px;
 font-size:.75rem;
 font-weight:600;
 transition:all .3s;
}
.firebase-status.connecting{
 border-color:rgba(255,193,7,.4);
 background:rgba(255,193,7,.15);
}
.firebase-status.connected{
 border-color:rgba(76,175,80,.4);
 background:rgba(76,175,80,.15);
}
.firebase-status.disconnected{
 border-color:rgba(244,67,54,.4);
 background:rgba(244,67,54,.15);
}
.firebase-status .status-dot{
 width:8px;
 height:8px;
 border-radius:50%;
 animation:pulse 2s infinite;
}
.firebase-status.connecting .status-dot{background:#ffc107}
.firebase-status.connected .status-dot{background:#4caf50}
.firebase-status.disconnected .status-dot{background:#f44336}
.firebase-status .status-text{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}
@keyframes pulse{
 0%,100%{opacity:1;transform:scale(1)}
 50%{opacity:.6;transform:scale(1.1)}
}
.card{background:#fff;border-radius:16px;max-width:820px;margin:0 auto;padding:28px 32px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.sec{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;color:var(--bd);text-transform:uppercase;letter-spacing:.5px;border-left:4px solid var(--bm);padding:10px 12px 10px 12px;margin:10px 0 0;background:#f0f4ff;border-radius:0 8px 8px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;user-select:none;transition:background .15s}
.sec:hover{background:#e0eaff}
.sec:first-child{margin-top:0}
.sec .sec-arrow{font-size:.75rem;color:var(--bm);transition:transform .25s;display:inline-block}
.sec.collapsed .sec-arrow{transform:rotate(-90deg)}
.sec-body{overflow:hidden;transition:max-height .3s ease,opacity .2s ease;max-height:2000px;opacity:1}
.sec-body.collapsed{max-height:0;opacity:0;pointer-events:none}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.s2{grid-column:span 2}
label{display:block;font-size:.72rem;font-weight:700;color:#666;margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}
input,select,textarea{width:100%;border:1.5px solid var(--bdr);border-radius:7px;padding:8px 11px;font-family:'Barlow',sans-serif;font-size:.88rem;color:var(--txt);background:#fafcff;transition:border-color .18s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--bm);box-shadow:0 0 0 3px rgba(30,77,183,.1)}
input[readonly]{background:#f0f4ff;color:#555}
textarea{resize:vertical;min-height:60px}
.rtbl{width:100%;border-collapse:collapse;margin-top:6px;font-size:.84rem}
.rtbl thead tr{background:var(--bd);color:#fff}
.rtbl thead th{padding:7px 9px;font-weight:700;text-align:center;font-size:.76rem;text-transform:uppercase;letter-spacing:.3px}
.rtbl tbody tr:nth-child(even) td{background:var(--bp)}
.rtbl tbody td{padding:4px 4px;vertical-align:middle}
.rtbl tfoot td{background:var(--bd);color:#fff;font-weight:700;padding:7px 9px;text-align:center;font-size:.8rem}
.rtbl input{padding:5px 7px;font-size:.82rem}
.del-r{background:none;border:none;color:#e74c3c;cursor:pointer;font-size:.95rem;padding:2px 6px;border-radius:4px}
.del-r:hover{background:#fdecea}
.add-r{background:none;border:1.5px dashed var(--bl);color:var(--bl);padding:5px 14px;border-radius:6px;cursor:pointer;font-size:.78rem;font-weight:700;margin-top:6px;transition:all .15s}
.add-r:hover{background:var(--bp)}
.tc-row{display:flex;gap:12px;align-items:flex-end;background:var(--bp);border-radius:9px;padding:11px 14px;margin-top:14px}
.tc-row>div{flex:1}
.preview{background:linear-gradient(135deg,var(--bd),var(--bm));border-radius:12px;padding:16px 18px;margin-top:18px;color:#fff}
.preview h3{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;opacity:.85}
.pvg{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.pvb{background:rgba(255,255,255,.12);border-radius:8px;padding:9px 11px;text-align:center}
.pvb .lbl{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;opacity:.7;margin-bottom:2px}
.pvb .val{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:900;line-height:1}
.pvb .sub{font-size:.65rem;opacity:.65;margin-top:2px}
.pvb.hl .val{color:#7affb2}
.pvb.warn .val{color:#ffd166}
.cob-btn{flex:1;padding:7px 4px;border:1.5px solid var(--bdr);border-radius:7px;background:#fafcff;font-family:'Barlow Condensed',sans-serif;font-size:.9rem;font-weight:700;color:#888;cursor:pointer;transition:all .15s;text-align:center}
.cob-btn.active{background:var(--bm);color:#fff;border-color:var(--bm)}
.gen-btn{display:block;width:100%;margin-top:22px;background:linear-gradient(135deg,var(--bd),var(--bm));color:#fff;border:none;border-radius:11px;padding:14px;font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 20px rgba(30,77,183,.4)}
.gen-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(30,77,183,.5)}
.gen-btn:disabled{opacity:.6;cursor:wait;transform:none}
#dl-area{max-width:820px;margin:18px auto 0;display:none}
.dl-btn{display:block;width:100%;background:linear-gradient(135deg,#145a32,#1e8449);color:#fff;border:none;border-radius:11px;padding:14px;font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;box-shadow:0 6px 20px rgba(30,132,73,.4);transition:transform .15s}
.dl-btn:hover{transform:translateY(-2px)}
.costo-panel{background:#fff9e6;border:1.5px solid #f59e0b;border-radius:10px;padding:14px 16px;margin-top:14px}
.costo-panel h4{font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:800;color:#92400e;text-transform:uppercase;margin-bottom:10px}
.cg{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.cb2{background:#fffbeb;border-radius:7px;padding:8px 10px;border:1px solid #fcd34d}
.cb2 .cl{font-size:.68rem;font-weight:700;color:#92400e;text-transform:uppercase}
.cb2 .cv{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:900;color:#78350f}
#pdf-wrap{position:fixed;left:-9999px;top:0;width:794px;background:#fff;font-family:'Barlow',sans-serif}
.pp{width:794px;min-height:1123px;background:#fff;display:flex;flex-direction:column;overflow:hidden}
.ph{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 34px 12px;border-bottom:1px solid #dde8f5;margin-bottom:14px}
.ph-r{text-align:right}
.ph-r .ct{font-family:'Barlow Condensed',sans-serif;font-size:1.4rem;font-weight:900;color:var(--bd);letter-spacing:1px}
.ph-r .cn{font-size:.92rem;font-weight:700;color:var(--bm)}
.ph-r .cs{font-size:.73rem;color:var(--bl);font-style:italic}
.ph-r .cfd{font-size:.76rem;font-weight:700;color:var(--bd);margin-top:6px}
.pb{padding:0 34px;flex:1}
.pff{padding:11px 34px;border-top:1.5px solid var(--bdr);display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.pff .fc{font-size:.68rem;color:#777;line-height:1.8}
.pff .fb{font-family:'Barlow Condensed',sans-serif;font-weight:700;color:var(--bd);font-size:.8rem;text-align:right}
.pff .fp{font-size:.7rem;color:#aaa;margin-top:2px}
.psh{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;color:var(--bm);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:3px;border-bottom:2px solid var(--bp)}
.pkv{display:flex;margin-bottom:3px;font-size:.82rem}
.pkv strong{width:195px;flex-shrink:0;font-weight:700}
.sbg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
.sb{background:var(--bp);border-radius:7px;padding:8px 12px}
.sb .sl{font-size:.67rem;font-weight:700;color:var(--bm);text-transform:uppercase;letter-spacing:.3px}
.sb .sv{font-size:1rem;font-weight:800;color:var(--bd);margin-top:1px}
.sb.grn .sv{color:var(--grn)}
.ptb{width:100%;border-collapse:collapse;font-size:.79rem;margin-bottom:10px}
.ptb thead tr{background:var(--bd);color:#fff}
.ptb thead th{padding:6px 8px;font-weight:700;text-align:center}
.ptb tbody tr:nth-child(even){background:var(--br)}
.ptb tbody td{padding:5px 8px;text-align:center}
.ptb tfoot tr{background:var(--bd);color:#fff;font-weight:700}
.ptb tfoot td{padding:6px 8px;text-align:center}
.etbl{width:100%;border-collapse:collapse;margin-top:6px}
.etbl thead tr{background:var(--bd);color:#fff}
.etbl thead th{padding:6px;font-size:.76rem;font-weight:700;text-align:center}
.etbl tbody tr{background:var(--bp)}
.etbl tbody td{padding:7px;text-align:center}
.etbl .bn{font-size:1.35rem;font-weight:900;color:var(--bd)}
.etbl tfoot tr{background:var(--bd);color:#fff}
.etbl tfoot td{padding:6px;text-align:center;font-size:.72rem;font-weight:700}
.cbs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin:14px 0}
.cbb{border-radius:8px;padding:12px;background:var(--gray);text-align:center}
.cbb .cbt{font-weight:800;font-size:.8rem;color:#555;text-transform:uppercase;letter-spacing:.4px}
.cbb .cbs2{font-size:.7rem;color:#999;margin-bottom:4px}
.cbb .cbv{font-family:'Barlow Condensed',sans-serif;font-size:1.45rem;font-weight:900}
.cbb.sin .cbv{color:var(--red)}.cbb.con .cbv{color:var(--bm)}.cbb.aho .cbv{color:var(--grn)}
.a25{background:var(--gray);border-radius:9px;padding:14px 16px;margin-top:11px}
.a25t{text-align:center;font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:900;color:var(--bd);margin-bottom:2px}
.a25s{text-align:center;font-size:.74rem;color:var(--bl);margin-bottom:9px}
.a25g{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:stretch}
.a25b{display:flex;flex-direction:column;justify-content:flex-end;text-align:center;min-height:100px}
.a25b .abt{font-weight:800;font-size:.76rem;text-transform:uppercase;color:#666;margin-bottom:6px}
.a25b .abs{font-size:.7rem;color:#999;margin-bottom:8px}
.a25b .abv{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:900}
.abv.red{color:var(--red)}.abv.blue{color:var(--bm)}.abv.grn{color:var(--grn)}
.alc{margin-bottom:13px}
.alch{background:var(--bd);color:#fff;font-weight:700;font-size:.8rem;padding:6px 11px;text-align:center;border-radius:4px 4px 0 0;text-transform:uppercase;letter-spacing:.5px}
.alcr{display:flex;justify-content:space-between;padding:6px 11px;font-size:.81rem;background:#fff;border:1px solid var(--bdr);border-top:none}
.alcr:nth-child(even){background:var(--bp)}
.alcr:last-child{border-radius:0 0 4px 4px}
.ptrc{width:100%;border-collapse:collapse;margin:11px 0 16px}
.ptrc tr{border-bottom:1px solid var(--bdr)}
.ptrc tr:nth-child(even){background:var(--bp)}
.ptrc td{padding:16px 13px;font-size:1rem}
.ptrc td:last-child{text-align:right;font-weight:700}
.ptrc thead th{background:var(--bd);color:#fff;padding:14px 13px;font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.4px}
.ptrc .ttr td{font-size:1.15rem;font-weight:900;color:var(--bd);background:var(--bp);padding:18px 13px}
.ctbl{width:58%;border-collapse:collapse;margin-bottom:14px}
.ctbl tr:nth-child(even){background:var(--bp)}
.ctbl td{padding:6px 11px;font-size:.82rem;border:1px solid var(--bdr)}
.ctbl td:first-child{font-weight:800;width:65px;text-align:center}
.excl li{list-style:none;font-size:.81rem;padding:6px 11px;border-bottom:1px solid var(--bdr)}
.excl li:nth-child(even){background:var(--bp)}
.bmt{font-family:'Barlow Condensed',sans-serif;font-size:1.35rem;font-weight:900;color:var(--bm);text-align:center;text-transform:uppercase;margin-top:16px;letter-spacing:1.2px;line-height:1.3}
.img-upload-box{border:2px dashed var(--bdr);border-radius:10px;padding:14px;cursor:pointer;transition:all .2s;text-align:center;background:#fff;min-height:110px;display:flex;align-items:center;justify-content:center}
.img-upload-box:hover{border-color:var(--bm);background:var(--bp)}
.img-upload-box.loaded{border-style:solid;border-color:var(--grn);background:#f0faf4}
.img-preview{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}
.img-preview img{max-height:70px;max-width:100%;object-fit:contain;border-radius:5px;background:#fff}
.img-icon{font-size:1.8rem;line-height:1}
.img-label{font-size:.78rem;font-weight:700;color:var(--bd);text-align:center}
.img-hint{font-size:.68rem;color:#999;text-align:center}
.img-change{font-size:.65rem;color:var(--bm);margin-top:2px;font-weight:600}
.hist-wrap{background:#fff;border-radius:16px;max-width:820px;margin:20px auto 0;padding:24px 32px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.hist-item{cursor:pointer}
.hist-item:hover .hist-folio{color:var(--bm);text-decoration:underline}
.hist-head{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;color:var(--bd);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.hist-empty{text-align:center;color:#aaa;font-size:.85rem;padding:20px 0}
.hist-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;background:var(--gray);margin-bottom:8px}
.hist-item:hover{background:var(--bp)}
.hist-info{flex:1}
.hist-folio{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;color:var(--bd)}
.hist-cliente{font-size:.82rem;color:#555;margin-top:1px}
.hist-meta{text-align:right;white-space:nowrap}
.hist-price{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;color:var(--grn);display:block}
.hist-fecha{font-size:.72rem;color:#999}
.hist-dl{padding:7px 14px;background:var(--bm);color:#fff;border:none;border-radius:7px;font-family:'Barlow Condensed',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer}
.hist-dl:hover{background:var(--bd)}
.hist-del{padding:6px 10px;background:none;color:#ccc;border:none;cursor:pointer;font-size:.8rem;border-radius:6px}
.hist-del:hover{color:var(--red);background:#fdecea}
.tab-bar{
 display:flex;
 max-width:820px;
 margin:0 auto;
 align-items:flex-end;
 gap:2px;
 padding:0 4px;
 position:relative;
}
.tab-btn{
 display:flex;
 align-items:center;
 gap:7px;
 padding:9px 16px 10px;
 background:rgba(255,255,255,.15);
 color:rgba(255,255,255,.65);
 border:none;
 border-radius:10px 10px 0 0;
 font-family:'Barlow Condensed',sans-serif;
 font-size:.92rem;
 font-weight:700;
 text-transform:uppercase;
 letter-spacing:.3px;
 cursor:pointer;
 transition:all .18s;
 white-space:nowrap;
 max-width:200px;
 overflow:hidden;
 text-overflow:ellipsis;
 position:relative;
 border-bottom:none;
 flex-shrink:0;
}
.tab-btn:hover{background:rgba(255,255,255,.25);color:#fff}
.tab-btn.active{
 background:#fff;
 color:var(--bd);
 border-radius:10px 10px 0 0;
 padding-bottom:12px;
 margin-bottom:-2px;
 z-index:2;
}
.tab-btn .tab-close{
 display:inline-flex;
 align-items:center;
 justify-content:center;
 width:16px;height:16px;
 border-radius:50%;
 font-size:.7rem;
 line-height:1;
 margin-left:2px;
 flex-shrink:0;
 opacity:.6;
 transition:all .15s;
 background:transparent;
 border:none;
 cursor:pointer;
 color:inherit;
 padding:0;
}
.tab-btn.active .tab-close{opacity:.5;color:var(--bd)}
.tab-btn .tab-close:hover{background:rgba(0,0,0,.15);opacity:1 !important}
.tab-btn.active .tab-close:hover{background:#e0e0e0}
.tab-content{display:none}
.tab-content.active{display:block}
.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:22px}
.btn-row .gen-btn{margin-top:0}
.btn-save{background:linear-gradient(135deg,#145a32,#1e8449) !important;box-shadow:0 6px 20px rgba(30,132,73,.4) !important}
.btn-save:hover{box-shadow:0 10px 28px rgba(30,132,73,.5) !important}
.btn-dl{background:linear-gradient(135deg,var(--bd),var(--bm)) !important}
.roi-panel{background:#fffdf5;border:1.5px solid #f59e0b;border-radius:10px;padding:14px 18px;margin-top:14px}
.roi-panel h4{font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:800;color:#92400e;text-transform:uppercase;margin-bottom:10px;letter-spacing:.5px}
.roi-panel ul{list-style:none;padding:0;margin:0}
.roi-panel ul li{font-size:.83rem;color:#555;padding:3px 0;border-bottom:1px solid #fde68a}
.roi-panel ul li:last-child{border-bottom:none}
.roi-panel ul li strong{color:#1a1a2e}
.roi-ok strong{color:#1e8449 !important}
.roi-warn strong{color:#c0392b !important}
.mat-prefix{background:#e8eaf0;border:1px solid #ccc;border-right:none;border-radius:6px 0 0 6px;padding:8px 10px;font-weight:700;color:#555;font-size:.82rem;white-space:nowrap;user-select:none;display:inline-flex;align-items:center}
.mat-inp{border-radius:0 6px 6px 0 !important;width:120px !important;margin:0 !important}
.modal-overlay{position:fixed;inset:0;background:rgba(10,20,60,.65);backdrop-filter:blur(3px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-box{background:#fff;border-radius:18px;max-width:660px;width:100%;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.modal-hdr{background:linear-gradient(135deg,var(--bd),var(--bm));color:#fff;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.modal-hdr h2{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:900;text-transform:uppercase;letter-spacing:1px;margin:0}
.modal-hdr .folio{font-size:.8rem;opacity:.75;margin-top:2px}
.modal-close{background:rgba(255,255,255,.18);border:none;color:#fff;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.modal-close:hover{background:rgba(255,255,255,.32)}
.modal-body{overflow-y:auto;padding:20px 24px;flex:1}
.modal-cat{font-family:'Barlow Condensed',sans-serif;font-size:.82rem;font-weight:800;color:var(--bm);text-transform:uppercase;letter-spacing:.5px;margin:14px 0 4px;padding-bottom:3px;border-bottom:2px solid var(--bp)}
.modal-cat:first-child{margin-top:0}
.mat-row{display:grid;grid-template-columns:1fr auto auto auto;gap:0;align-items:center;font-size:.83rem;padding:5px 0;border-bottom:1px solid #f0f4ff}
.mat-row:last-child{border-bottom:none}
.mat-row .mn{color:#333}
.mat-row .mq{color:#888;font-size:.75rem;text-align:right;padding:0 12px;white-space:nowrap}
.mat-row .mu{color:#aaa;font-size:.72rem;text-align:right;padding-right:12px;white-space:nowrap}
.mat-row .mp{font-weight:700;color:var(--bd);text-align:right;white-space:nowrap}
.mat-row .mp.modal-total{background:linear-gradient(135deg,var(--bd),var(--bm));border-radius:10px;padding:14px 18px;margin-top:14px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.mt-box{text-align:center;color:#fff}
.mt-box .mtl{font-size:.65rem;font-weight:700;text-transform:uppercase;opacity:.7;letter-spacing:.3px}
.mt-box .mtv{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:900;margin-top:1px}
.mt-box .mtv.grn{color:#7affb2}
.mat-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.14);border:1.5px solid rgba(255,255,255,.35);color:#fff;border-radius:8px;padding:6px 14px;font-family:'Barlow Condensed',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:all .15s;margin-top:10px}
.mat-btn:hover{background:rgba(255,255,255,.25)}
.crm-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:800;padding:3px 9px;border-radius:20px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.3px;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}
.crm-pendiente{background:#fef9e7;color:#9a7d0a;border:1.5px solid #f9e79f}
.crm-enviada{background:#e8f1fb;color:#1a4db7;border:1.5px solid #b5d0f0}
.crm-cerrada{background:#eafaf1;color:#1e8449;border:1.5px solid #a9dfbf}
.crm-perdida{background:#fdecea;color:#922b21;border:1.5px solid #f5c6cb}
.crm-wrap{position:relative;display:inline-block}
.crm-menu{position:absolute;left:0;top:calc(100%+4px);background:#fff;border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.18);z-index:9999;min-width:160px;overflow:hidden;border:1px solid #eee;display:none}
.crm-wrap.open .crm-menu{display:block}
.crm-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;font-size:.82rem;font-weight:600;transition:background .12s}
.crm-menu-item:hover{background:var(--bp)}
.hist-nota{font-size:.74rem;color:#777;margin-top:2px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
.pkg-card{border:2px solid var(--bdr);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .18s;text-align:center;background:#fff}
.pkg-card:hover{border-color:var(--bm);background:var(--bp)}
.pkg-card.active{border-color:var(--bm);background:var(--bm);color:#fff}
.pkg-card.active .pkg-paneles{color:#fff}
.pkg-card.active .pkg-precio{color:#7affb2}
.pkg-card.active .pkg-kw{color:rgba(255,255,255,.8)}
.pkg-paneles{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:900;color:var(--bd);line-height:1}
.pkg-kw{font-size:.8rem;color:#888;margin:2px 0 6px}
.pkg-precio{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:800;color:var(--grn)}
.pkg-editor-row{display:grid;grid-template-columns:auto 1fr 1fr 1fr;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--bdr);font-size:.85rem}
.pkg-editor-row:last-child{border-bottom:none}
.pago-toggle{display:flex;gap:0;border-radius:9px;overflow:hidden;border:2px solid var(--bm);margin-bottom:14px}
.pago-btn{flex:1;padding:10px 16px;border:none;font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .18s;background:#fff;color:var(--bm)}
.pago-btn.active{background:var(--bm);color:#fff}
.pago-btn:first-child{border-right:1px solid var(--bm)}
.fin-panel{background:linear-gradient(135deg,#f5f0ff,#ede8fb);border:1.5px solid #7c6fd4;border-radius:12px;padding:16px 18px;margin-top:14px}
.fin-panel h4{font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:800;color:#3b2f8a;text-transform:uppercase;margin-bottom:12px;letter-spacing:.5px}
.fin-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.fin-inputs label{font-size:.7rem;font-weight:700;color:#5b4db0;text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;display:block}
.fin-inputs input{border:1.5px solid #c4b8f0;border-radius:7px;padding:7px 10px;font-family:'Barlow',sans-serif;font-size:.88rem;background:#fff;width:100%}
.fin-inputs input:focus{outline:none;border-color:#7c6fd4;box-shadow:0 0 0 3px rgba(124,111,212,.15)}
.fin-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.fin-box{border-radius:9px;padding:11px 13px;text-align:center}
.fin-box .fl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px}
.fin-box .fv{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:900;line-height:1}
.fin-box .fs{font-size:.65rem;margin-top:2px;opacity:.75}
.fin-box.cfe{background:#fdecea}.fin-box.cfe .fl{color:#922b21}.fin-box.cfe .fv{color:#c0392b}
.fin-box.men{background:#eaf4fb}.fin-box.men .fl{color:#1a5276}.fin-box.men .fv{color:#1a5276}
.fin-box.aho{background:#eafaf1}.fin-box.aho .fl{color:#1d6a3a}.fin-box.aho .fv{color:#1e8449}
.fin-veredicto{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:.82rem;font-weight:600;text-align:center;display:none}
.fin-veredicto.ok{background:#eafaf1;color:#1e8449;border:1px solid #a9dfbf;display:block}
.fin-veredicto.warn{background:#fef9e7;color:#9a7d0a;border:1px solid #f9e79f;display:block}
#sol-popup-overlay{position:fixed;inset:0;background:rgba(10,20,60,.55);backdrop-filter:blur(4px);z-index:99999;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .18s}
#sol-popup-overlay.show{opacity:1;pointer-events:all}
#sol-popup-box{background:#fff;border-radius:16px;max-width:440px;width:100%;box-shadow:0 24px 80px rgba(0,0,0,.45);transform:translateY(12px);transition:transform .18s;overflow:hidden}
#sol-popup-overlay.show #sol-popup-box{transform:translateY(0)}
#sol-popup-icon{font-size:2rem;text-align:center;padding:22px 0 0}
#sol-popup-msg{font-family:'Barlow',sans-serif;font-size:.95rem;color:#333;padding:14px 28px 20px;text-align:center;line-height:1.5;white-space:pre-line}
#sol-popup-btns{display:flex;border-top:1px solid #eee}
#sol-popup-btns button{flex:1;padding:14px;border:none;font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:background .15s}
#sol-popup-btns .pop-cancel{background:#f5f5f5;color:#666;border-right:1px solid #eee}
#sol-popup-btns .pop-cancel:hover{background:#ebebeb}
#sol-popup-btns .pop-ok{background:var(--bm);color:#fff}
#sol-popup-btns .pop-ok:hover{background:var(--bd)}
#sol-popup-btns .pop-ok.danger{background:#c0392b}
#sol-popup-btns .pop-ok.danger:hover{background:#922b21}

#wa-modal-overlay{display:none;position:fixed;inset:0;background:rgba(10,20,60,.55);z-index:10000;align-items:center;justify-content:center;padding:20px}
#wa-modal-overlay.show{display:flex}
#wa-modal-box{background:#fff;border-radius:16px;width:100%;max-width:500px;box-shadow:0 24px 60px rgba(0,0,0,.35);overflow:hidden}
#wa-modal-header{background:linear-gradient(135deg,#128C7E,#25D366);padding:16px 20px;display:flex;align-items:center;gap:10px}
#wa-modal-header span{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.1rem;color:#fff;letter-spacing:.5px;text-transform:uppercase}
#wa-modal-body{padding:16px 20px}
#wa-modal-textarea{width:100%;height:280px;border:1.5px solid #d1d5db;border-radius:10px;padding:12px;font-family:'Barlow',sans-serif;font-size:.84rem;line-height:1.6;color:#1a1a2e;resize:none;background:#f9fafb}
#wa-modal-footer{padding:12px 20px 16px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid #e5e7eb}
#wa-copy-btn{background:linear-gradient(135deg,#128C7E,#25D366);color:#fff;border:none;border-radius:9px;padding:10px 24px;font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:900;letter-spacing:.5px;cursor:pointer;transition:opacity .15s}
#wa-copy-btn:hover{opacity:.88}
#wa-close-btn{background:none;border:1.5px solid #d1d5db;border-radius:9px;padding:10px 18px;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:700;color:#555;cursor:pointer}

