:root{--bg:#f4f6fa;--panel:#fff;--primary:#2d4ef5;--primary-dark:#1f3bc4;--primary-light:#eaeefe;--border:#dde2ec;--text:#1c2533;--muted:#6b7787;--accent:#00b88d;--shadow:0 1px 3px rgba(20,30,60,.08);--shadow-lg:0 8px 28px rgba(20,30,60,.12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid var(--border);padding:12px 24px;position:sticky;top:0;z-index:50}.topbar h1{font-size:20px;font-weight:800;letter-spacing:-.5px;cursor:pointer}.topbar h1 span{color:var(--primary)}.topbar-right{display:flex;align-items:center;gap:12px}.badge{font-size:12px;padding:4px 10px;border-radius:20px;background:#eee;color:var(--muted);font-weight:600}.badge.ok{background:#e3f9f1;color:#00926f}.badge.err{background:#fdecea;color:#c0392b}.upload-btn{background:var(--primary);color:#fff;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .15s;border:none}.upload-btn:hover{background:var(--primary-dark)}.upload-btn.small{padding:6px 12px;font-size:13px}main{display:flex;min-height:calc(100vh - 57px)}.sidebar{width:240px;background:var(--panel);border-right:1px solid var(--border);padding:16px;overflow-y:auto}.nav-item{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:10px 12px;border-radius:8px;font:inherit;font-weight:600;color:var(--text);margin-bottom:12px}.nav-item:hover,.nav-item.active{background:var(--primary-light);color:var(--primary)}.sidebar h2{font-size:12px;text-transform:uppercase;color:var(--muted);margin-bottom:12px;letter-spacing:.5px}.project-list{list-style:none}.project-list li{padding:10px 12px;border-radius:8px;cursor:pointer;margin-bottom:4px;border:1px solid transparent}.project-list li:hover{background:var(--bg)}.project-list li.active{background:var(--primary-light);border-color:var(--primary)}.project-list .pname{font-weight:600;display:block;font-size:13px}.project-list .pmeta{font-size:12px;color:var(--muted)}.content{flex:1;padding:28px 32px;overflow-y:auto}.hero{background:linear-gradient(135deg,#2d4ef5 0%,#6a3df5 100%);color:#fff;border-radius:16px;padding:32px 36px;margin-bottom:24px;box-shadow:var(--shadow-lg)}.hero h2{font-size:26px;font-weight:800;margin-bottom:8px}.hero p{opacity:.9;max-width:640px}.active-label{margin-top:12px!important;font-weight:600;opacity:1!important;background:rgba(255,255,255,.18);display:inline-block;padding:6px 14px;border-radius:20px}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow)}.stat .sv{font-size:26px;font-weight:800;color:var(--primary)}.stat .sl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-top:4px}.stat .sv.accent{color:var(--accent)}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-head h3{font-size:16px}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;padding:10px 16px;font-size:12px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}.data-table th.num,.data-table td.num{text-align:right}.data-table td{padding:12px 16px;border-bottom:1px solid #eef1f6}.data-table tbody tr:hover{background:var(--bg)}.data-table .pname{font-weight:600;cursor:pointer}.data-table .pname:hover{color:var(--primary)}.data-table .imp{font-weight:700;font-variant-numeric:tabular-nums}.row-actions{display:flex;gap:6px;justify-content:flex-end}.icon-btn{background:none;border:1px solid var(--border);border-radius:7px;cursor:pointer;padding:5px 9px;font-size:13px}.icon-btn:hover{background:var(--bg)}.icon-btn.danger:hover{background:#fdecea;border-color:#f5b7b1}.ws-head{display:flex;align-items:center;gap:16px;margin-bottom:20px}.ws-title{flex:1}.ws-title h2{font-size:22px}.ws-actions{display:flex;align-items:center;gap:12px}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.tool-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:22px;cursor:pointer;transition:transform .12s , box-shadow .12s , border-color .12s;position:relative;display:flex;flex-direction:column;gap:8px}.tool-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.tool-card.disabled{opacity:.5;pointer-events:none}.tool-card .ti{font-size:34px;line-height:1}.tool-card .tt{font-size:17px;font-weight:700}.tool-card .td{font-size:13px;color:var(--muted);line-height:1.35}.tool-card .soon{position:absolute;top:14px;right:14px;font-size:10px;font-weight:700;background:var(--accent);color:#fff;padding:3px 8px;border-radius:12px}.tool-card.featured{border-color:var(--accent)}.tool-card.featured .ti{color:var(--accent)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;margin-top:24px;box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.panel-head h3{font-size:17px}#panel-body{padding:20px}.btn{background:var(--primary);color:#fff;padding:8px 16px;border-radius:8px;text-decoration:none;font-weight:600;font-size:13px;cursor:pointer;border:none;display:inline-block}.btn:hover{background:var(--primary-dark)}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn.ghost:hover{background:var(--bg)}.btn.accent{background:var(--accent)}.btn.small{padding:6px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.total{font-size:18px;font-weight:800;color:var(--accent)}.meta{color:var(--muted);font-size:13px}.tree-table-head,.tree-row{display:grid;grid-template-columns:150px 1fr 100px 100px 120px;align-items:center;gap:8px}.tree-table-head{padding:8px 12px;font-size:12px;text-transform:uppercase;color:var(--muted);border-bottom:2px solid var(--border);font-weight:600}.tree-table-head .col-num{text-align:right}.tree{border:1px solid var(--border);border-radius:8px;overflow:hidden}.tree-row{padding:8px 12px;border-bottom:1px solid #eef1f6;cursor:pointer}.tree-row:hover{background:var(--bg)}.tree-row.capitulo{background:var(--primary-light);font-weight:600}.tree-row .col-code{font-family:"SF Mono",Menlo,monospace;font-size:12px;color:var(--muted)}.tree-row .col-resumen{display:flex;align-items:center;gap:6px;overflow:hidden}.tree-row .resumen-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-row .col-num{text-align:right;font-variant-numeric:tabular-nums}.tree-row .importe{font-weight:600}.toggle{width:16px;display:inline-block;text-align:center;color:var(--muted);font-size:10px;flex-shrink:0}.toggle.empty{visibility:hidden}.row-check{margin-right:4px}.flat-table{width:100%;border-collapse:collapse;font-size:13px}.flat-table th{text-align:left;background:var(--primary-light);padding:8px;position:sticky;top:0}.flat-table td{padding:6px 8px;border-bottom:1px solid #eef1f6}.flat-table td.num{text-align:right;font-variant-numeric:tabular-nums}.flat-table tr.cap td{background:#f6f8fe;font-weight:700}.planos-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.att-code{padding:7px 10px;border:1px solid var(--border);border-radius:6px}.hint{color:var(--muted);font-size:12px}.att-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.att-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}.att-thumb{height:120px;background: #eef1f6 center/cover no-repeat;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:32px}.att-card .att-body{padding:8px 10px}.att-card .att-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.att-card .att-meta{font-size:11px;color:var(--muted);margin-top:2px}.att-card .att-del{color:#c0392b;cursor:pointer;font-size:11px}.form-grid{display:grid;gap:12px;max-width:520px}.form-grid label{font-size:13px;color:var(--muted);display:block}.form-grid input,.form-grid textarea,.form-grid select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;margin-top:4px;font:inherit}.checklist{list-style:none;margin:0 0 20px;display:grid;gap:8px}.checklist li{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:10px}.checklist .ck{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;flex-shrink:0}.checklist .ck.ok{background:var(--accent)}.checklist .ck.no{background:#cfd6e2}.ck-inline{display:inline-flex;align-items:center;gap:6px;color:var(--text)}.ck-inline input{width:auto;margin:0}.form-grid input[type="color"]{height:38px;padding:2px;cursor:pointer}.checklist .ctext b{display:block}.checklist .ctext span{font-size:12px;color:var(--muted)}.modal{position:fixed;inset:0;background:rgba(15,22,40,.45);display:flex;align-items:center;justify-content:center;z-index:200}.modal[hidden]{display:none}[hidden]{display:none!important}.modal-box{background:#fff;border-radius:14px;padding:24px;width:460px;max-width:90vw;box-shadow:var(--shadow-lg)}.modal-box h3{margin-bottom:12px}.modal-box label{display:block;font-size:13px;color:var(--muted);margin-top:12px}.modal-box input[type="text"],.modal-box input[type="number"],.modal-box textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;margin-top:4px;font:inherit;box-sizing:border-box}.modal-box textarea{resize:vertical}.contact-list{list-style:none;max-height:200px;overflow-y:auto;margin-top:8px;border:1px solid var(--border);border-radius:8px}.contact-list:empty{display:none}.contact-list li{padding:8px 12px;cursor:pointer;border-bottom:1px solid #eef1f6}.contact-list li:hover,.contact-list li.sel{background:var(--primary-light)}.modal-row{display:flex;gap:16px;align-items:flex-end}.modal-row label.check{display:flex;align-items:center;gap:6px;margin-top:12px}.modal-row label.check input{width:auto;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.modal-box.wide{width:620px}.brand-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.brand-grid label{margin-top:0}.brand-grid .span2{grid-column: 1 / 3}.brand-grid input[type="color"]{height:38px;padding:2px;cursor:pointer}.brand-logo{display:flex;align-items:center;gap:14px;margin-top:14px}.brand-logo img{max-height:48px;max-width:160px;border:1px solid var(--border);border-radius:6px;padding:4px;background:#fff}.brand-logo img:not([src]), .brand-logo img[src=""] {display:none}.subtabs{display:flex;gap:6px;margin-bottom:14px}.subtab{padding:7px 16px;border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none;background:var(--bg);cursor:pointer;font-weight:600;color:var(--muted)}.subtab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.att-card .att-view{color:var(--primary);cursor:pointer;font-size:11px;font-weight:600}.att-badge{display:inline-block;background:var(--accent);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;margin-left:4px}.viewer-box{width:92vw;max-width:1100px}.viewer-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.viewer-tools{display:flex;align-items:center;gap:8px}.viewer-stage{position:relative;max-height:70vh;overflow:auto;background:#f0f2f6;border:1px solid var(--border);border-radius:8px;margin-top:8px;display:flex;justify-content:center}.viewer-canvas-wrap{position:relative;display:inline-block}.viewer-canvas-wrap img,.viewer-canvas-wrap canvas{display:block;max-width:100%}.pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:5}.pin .pin-dot{width:22px;height:22px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.4)}.pin .pin-num{position:absolute;top:2px;left:0;right:0;text-align:center;color:#fff;font-size:11px;font-weight:700;transform:rotate(0deg)}.pin .pin-label{position:absolute;left:16px;top:-6px;white-space:nowrap;background:#222;color:#fff;font-size:11px;padding:2px 7px;border-radius:5px;max-width:220px;overflow:hidden;text-overflow:ellipsis}.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:#fff;padding:12px 18px;border-radius:10px;box-shadow:var(--shadow-lg);z-index:300;max-width:360px}.toast.error{background:#c0392b}.empty-hint{color:var(--muted);padding:20px;text-align:center}.g-section{margin-bottom:8px}.g-flow{list-style:none;margin:0;padding:16px 20px;display:grid;gap:14px}.g-flow li{display:flex;gap:14px;align-items:flex-start}.g-step{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px}.g-flow li div{display:flex;flex-direction:column}.g-flow li b{font-size:14px}.g-flow li span:last-child{color:var(--muted);font-size:13px;margin-top:2px}.g-h{font-size:17px;margin:26px 0 14px}.g-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}.g-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;gap:14px;box-shadow:var(--shadow)}.g-card .g-ic{font-size:26px;line-height:1;flex-shrink:0}.g-card h4{font-size:15px;margin-bottom:4px;color:var(--primary)}.g-card p{font-size:13px;color:var(--text);line-height:1.45}.g-tips{margin:0;padding:14px 20px 16px 38px;display:grid;gap:8px}.g-tips li{font-size:13px;color:var(--text);line-height:1.45}.login-screen{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d4ef5 0%,#6a3df5 100%)}.login-box{background:#fff;border-radius:16px;padding:36px 32px;width:360px;max-width:90vw;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.login-box h1{font-size:26px;font-weight:800;letter-spacing:-.5px}.login-box h1 span{color:var(--primary)}.login-box .meta{margin-bottom:18px}.login-box label{font-size:13px;color:var(--muted);margin-top:12px;display:block}.login-box input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;margin-top:4px;font:inherit}.login-box .btn{margin-top:20px;padding:11px;text-align:center;font-size:15px}.login-error{color:#c0392b;font-size:13px;margin-top:12px;text-align:center}