*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --app-page-bg:#f4f4f4;
  --app-surface:#ffffff;
  --app-surface-soft:#fafafa;
  --app-surface-muted:#f5f5f5;
  --app-surface-accent:#f1f1f1;
  --app-surface-accent-hover:#e9e9e9;
  --app-border:#dddddd;
  --app-border-strong:#cccccc;
  --app-text:#333333;
  --app-text-muted:#616161;
  --app-primary:#1E4C50;
  --app-primary-hover:#143336;
  --app-secondary:#1565c0;
  --app-secondary-hover:#0d47a1;
  --app-success:#43a047;
  --app-success-hover:#2e7d32;
  --app-danger:#d32f2f;
  --app-danger-hover:#b71c1c;
  --app-warning:#ff9800;
  --app-warning-hover:#f57c00;
  --app-highlight:#fff9c4;
}
body{font-family:'Roboto',sans-serif;background:var(--app-page-bg);padding:10px;color:var(--app-text);}
.container{position:relative;width:100%;max-width:1200px;margin:0 auto;background:var(--app-surface);padding:20px;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,0.1);}
.logo{display:block;margin:0 auto 10px;max-width:180px;}
h1{text-align:center;margin-bottom:20px;color:var(--app-primary);}
.user-menu-container{position:absolute;top:15px;right:20px;z-index:110;}
.user-menu-btn{background-color:var(--app-surface-accent);border:1px solid var(--app-border);padding:6px 12px;border-radius:16px;cursor:pointer;display:flex;align-items:center;font-size:14px;font-weight:500;color:var(--app-text);transition:background-color 0.2s ease;}
.user-menu-btn:hover{background-color:var(--app-surface-accent-hover);}
.user-menu-btn .menu-arrow{width:20px;height:20px;fill:var(--app-text);margin-left:4px;transition:transform 0.2s ease-out;}
.user-menu-dropdown{display:none;position:absolute;top:100%;right:0;background-color:var(--app-surface);border:1px solid var(--app-border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,0.1);min-width:200px;overflow:hidden;padding:5px 0;}
.user-menu-dropdown.show{display:block;}
.user-menu-container.open .user-menu-btn .menu-arrow{transform:rotate(180deg);}
.user-menu-dropdown a{display:block;padding:10px 15px;color:var(--app-text);text-decoration:none;font-size:15px;transition:background-color 0.2s ease;}
.user-menu-dropdown a:hover{background-color:var(--app-surface-muted);color:var(--app-primary);}
.user-menu-dropdown a.admin-link{background-color:var(--app-surface-muted);color:var(--app-primary);font-weight:500;}
.user-menu-dropdown a.admin-link:hover{background-color:var(--app-surface-accent-hover);}
.user-menu-dropdown .menu-separator{height:1px;background-color:var(--app-border);margin:5px 0;}
.row-container{display:flex;flex-wrap:wrap;gap:15px;align-items:flex-end;margin-bottom:15px;}
.input-group{display:flex;flex-direction:column;margin-bottom:10px;flex:1 1 200px;}
.input-group label{margin-bottom:5px;font-weight:500;}
.input-group label[for="altura"]::after{content:" (mín. 1)";}
input[type="number"],input[type="text"],input[type="email"],input[type="password"],select,textarea{width:100%;padding:8px;font-size:16px;border:1px solid var(--app-border-strong);border-radius:4px;transition:border-color 0.3s ease;font-family:'Roboto',sans-serif;}
input[type="number"]:focus,input[type="text"]:focus,input[type="email"]:focus,input[type="password"]:focus,select:focus,textarea:focus{border-color:var(--app-primary);outline:none;}
textarea{resize:vertical;min-height:80px;}
.btn-calcular{padding:10px 20px;font-size:18px;font-weight:bold;background-color:var(--app-primary);color:white;border:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease,transform 0.2s ease,-webkit-transform 0.2s ease;margin-top:10px;height:40px;flex-shrink:0;}
.btn-calcular:hover{background-color:var(--app-primary-hover);transform:scale(1.02);}
#btnCalcular{display:none;}
.actions-container{margin-top:20px;text-align:center;display:flex;flex-wrap:wrap;justify-content:center;gap:10px;}
.actions-container button{padding:10px 20px;font-size:18px;border:none;border-radius:4px;color:white;cursor:pointer;transition:background-color 0.3s ease,transform 0.2s ease,-webkit-transform 0.2s ease;}
.actions-container button:disabled{background-color:#9e9e9e;cursor:not-allowed;}
.btn-export{background-color:var(--app-primary);}
.btn-export:hover:not(:disabled){background-color:var(--app-primary-hover);}
.btn-mail{background-color:var(--app-secondary);}
.btn-mail:hover:not(:disabled){background-color:var(--app-secondary-hover);}
.btn-presupuesto{background-color:var(--app-success);}
.btn-presupuesto:hover:not(:disabled){background-color:var(--app-success-hover);}
.checkboxes{margin-bottom:15px;font-size:15px;display:flex;flex-wrap:wrap;gap:15px;align-items:center;padding:10px;background-color:var(--app-surface-muted);border-radius:4px;}
.checkboxes label{cursor:pointer;white-space:nowrap;}
.checkboxes .options-right{margin-left:auto;display:flex;gap:15px;align-items:center;}
.checkboxes label.opcion-extra{font-weight:500;padding:5px 10px;background-color:var(--app-surface-accent);border-radius:12px;}
#pasoPeatonOptionsContainer{display:flex;gap:10px;align-items:center;}
#pasoPeatonOptionsContainer label{font-size:14px;}
#pasoPeatonOptionsContainer select{padding:4px;font-size:14px;}
.main-controls{margin-bottom:15px;}
#shape-options-container{background-color:var(--app-surface-soft);padding:15px;border-radius:6px;border:1px solid var(--app-border);margin-bottom:15px;}
.shape-option-group .input-group{max-width:300px;}
#tramos-builder-container{display:flex;flex-direction:column;gap:12px;}
.tramo-group{background-color:var(--app-surface);border:1px solid var(--app-border);border-radius:5px;padding:12px 15px;box-shadow:0 1px 3px rgba(0,0,0,0.05);}
.tramo-group .input-group{flex-basis:100%;}
.tramo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;cursor:pointer;gap:10px;}
.tramo-header-left{display:flex;align-items:center;gap:15px;flex-wrap:wrap;}
.tramo-header h4{display:flex;align-items:center;color:var(--app-primary-hover);margin:0;font-size:18px;}
.tramo-header h4::before{content:'▼';font-size:12px;margin-right:8px;transition:transform 0.2s ease-out;}
.tramo-group.collapsed .tramo-header h4::before{transform:rotate(-90deg);}
.tramo-content{max-height:2000px;transition:max-height 0.3s ease-in-out,opacity 0.2s ease-in-out,padding 0.3s ease-in-out,margin 0.3s ease-in-out;overflow:hidden;opacity:1;border-top:1px solid var(--app-border);margin-top:12px;padding-top:15px;}
.tramo-group.collapsed .tramo-content{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin-top:0;border-top:none;}
.tramo-row{display:flex;flex-direction:column;gap:10px;margin-bottom:10px;}
/* --- Añadir al final de styles.css para soporte del Admin Panel --- */

/* Contenedor de Reportes */
.reports-container { width: 90%; max-width: 1200px; margin: 20px auto; background: var(--app-surface); padding: 20px; border-radius: 8px; box-shadow: 0 2px 6px rgba(0,0,0,0.1); }

/* Items de Reporte */
.report-item { border: 1px solid var(--app-border); border-radius: 6px; margin-bottom: 15px; background: var(--app-surface-soft); overflow: hidden; }
.report-header { padding: 10px 15px; background: var(--app-surface-muted); display: flex; flex-direction: column; align-items: flex-start; gap: 6px; border-bottom: 1px solid var(--app-border); }
.report-header h3 { margin: 0; color: var(--app-primary); font-size: 16px; }
.report-header-meta { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; gap: 6px; font-size: 12px; color: var(--app-text-muted); text-align: left; }
.report-header-line { display: inline-flex; align-items: center; }
.report-header-separator { color: var(--app-border-strong); font-weight: 600; }
.report-header-line-success { color: var(--app-success-hover); font-weight: 600; }
.report-body { padding: 15px; font-size: 14px; }
.report-body pre { background: var(--app-surface-muted); padding: 10px; border: 1px solid var(--app-border); overflow-x: auto; white-space: pre-wrap; margin-top: 5px; }

/* Acciones de Reporte */
.report-actions { padding: 10px 15px; text-align: right; border-top: 1px solid var(--app-border); background: var(--app-surface); display: flex; gap: 5px; justify-content: flex-end; }
.report-actions button { padding: 5px 10px; font-size: 12px; cursor: pointer; border: none; border-radius: 4px; color: white; transition: background 0.2s; }
.report-admin-comment { margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--app-border); }
.report-admin-comment p { margin: 0; }
.report-comment-input { min-height: 90px; margin-top: 8px; font-size: 13px; }
.report-comment-meta { margin-top: 8px; font-size: 12px; color: var(--app-text-muted); min-height: 16px; }

/* Botones Específicos */
.btn-delete-report { background-color: var(--app-danger); }
.btn-delete-report:hover { background-color: var(--app-danger-hover); }
.btn-toggle-status { background-color: var(--app-warning); }
.btn-toggle-status:hover { background-color: var(--app-warning-hover); }
.btn-load-design { background-color: var(--app-primary); }
.btn-load-design:hover { background-color: var(--app-primary-hover); }
.btn-save-report-comment { background-color: var(--app-secondary); }
.btn-save-report-comment:hover { background-color: var(--app-secondary-hover); }
.btn-save-report-comment:disabled { background-color: #90a4ae; cursor: not-allowed; }

/* Estados */
.report-item.pendiente .report-header { background: #ffebee; }
.report-item.pendiente .report-header h3 { color: #b71c1c; }
.report-item.resuelto .report-header { background: #e8f5e9; }
.report-item.resuelto .btn-toggle-status { background-color: var(--app-success); }
.report-item.resuelto .btn-toggle-status:hover { background-color: var(--app-success-hover); }
.tramo-row .input-group{margin-bottom:0;}
.tramo-length-feedback{font-size:18px;font-weight:500;color:var(--app-primary);background-color:var(--app-surface-muted);padding:4px 8px;border-radius:4px;white-space:nowrap;}
.tramo-length-feedback strong{font-weight:500;}
.remove-tramo-btn{background-color:#ef5350;color:white;border:none;border-radius:50%;width:24px;height:24px;font-size:20px;font-weight:bold;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;padding:0;}
.remove-tramo-btn:hover{background-color:var(--app-danger);}
.add-tramo-wrapper{text-align:center;margin-top:15px;padding-top:15px;border-top:1px dashed var(--app-border);}
#addTramoBtn{background-color:var(--app-success);color:white;border:none;padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;}
#addTramoBtn:hover{background-color:var(--app-success-hover);}
.tramo-modulos-container{margin-top:15px;text-align:center;background-color:var(--app-surface-soft);padding:12px;border-radius:4px;}
.tramo-modulos-container h3{margin-bottom:10px;color:var(--app-primary);font-size:16px;}
.tramo-modulos-container table{margin:10px auto;border-collapse:collapse;width:100%;}
.tramo-modulos-container th,.tramo-modulos-container td{border:1px solid var(--app-border-strong);padding:8px 12px;text-align:center;}
.tramo-modulos-container th{background-color:var(--app-surface-accent);color:var(--app-text);font-size:14px;}
.tramo-modulos-container td label{display:none;}
.tramo-modulos-container .quantity-control{display:flex;align-items:center;justify-content:center;}
.tramo-modulos-container .quantity-btn{display:none;}
.tramo-modulos-container .modulo-input{width:70px;text-align:center;padding:5px;border-radius:3px;border:1px solid var(--app-border-strong);}
#parts-container{position:relative;border:1px solid var(--app-border);border-radius:6px;padding:15px;background:var(--app-surface-soft);margin-top:20px;}
#placementControls{background-color:var(--app-surface-soft);padding:15px;border-radius:4px;margin-bottom:20px;display:flex;flex-direction:column;align-items:stretch;gap:10px;}
#placementControls label{font-weight:500;color:var(--app-primary);}
#placementControls select{width:100%;max-width:none;}
#placementHelpText{display:block;min-height:18px;}
#vr-controls-panel{display:flex;flex-direction:column;gap:10px;}
.piezas h3{margin-bottom:15px;color:var(--app-primary);}
.piezas{overflow-x:auto;}
.piezas table{width:100%;min-width:780px;border-collapse:collapse;margin-top:10px;font-size:14px;}
.piezas th,.piezas td{border:1px solid var(--app-border-strong);padding:10px;text-align:center;vertical-align:middle;}
.piezas th{background-color:var(--app-primary);color:#fff;font-weight:500;}
.piezas tr:nth-child(even){background-color:var(--app-surface-soft);}
.piezas tr:hover{background-color:var(--app-surface-muted);}
.piezas tbody tr.row-selected{background-color:var(--app-highlight) !important;font-weight:500;}
.piezas tfoot td{font-weight:bold;background-color:var(--app-surface-accent);}
.piezas .col-peso-unit{display:none;}
.piezas .col-precio-unit,.piezas .col-precio-total{white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;}
.piezas th.col-precio-unit,.piezas th.col-precio-total{text-align:center;}
.bom-commercial-section{margin-top:24px;padding:0;border:0;border-radius:0;background:transparent;}
.bom-commercial-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;flex-wrap:wrap;}
.bom-commercial-header h4{margin:0 0 4px;color:var(--app-primary);display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.bom-commercial-header p{margin:0;color:var(--app-text-muted);font-size:13px;}
.bom-commercial-subheader{margin:18px 0 8px;}
.bom-commercial-subheader h4{margin:0;color:var(--app-primary);}
.bom-commercial-controls{display:flex;justify-content:flex-end;margin:14px 0;}
.bom-commercial-controls label{display:flex;flex-direction:column;gap:6px;min-width:180px;color:var(--app-primary);font-weight:500;}
.bom-commercial-controls input{width:100%;}
.bom-commercial-table-wrap{overflow-x:auto;}
.tabla-comercial{width:100%;min-width:720px;border-collapse:collapse;margin-top:10px;font-size:14px;}
.tabla-comercial th,.tabla-comercial td{border:1px solid var(--app-border-strong);padding:9px;text-align:center;vertical-align:middle;}
.tabla-comercial th{background-color:var(--app-primary);color:#fff;font-weight:500;}
.tabla-comercial tbody tr:nth-child(even){background-color:var(--app-surface-soft);}
.tabla-comercial input{width:100%;min-width:90px;}
.tabla-comercial select{width:100%;min-width:240px;}
.tabla-comercial input[readonly]{background-color:var(--app-surface-muted);cursor:default;}
.tabla-comercial-resumen td:nth-child(n+2){text-align:right;font-variant-numeric:tabular-nums;}
.tabla-comercial-resumen .bom-summary-weight-col{width:118px;min-width:118px;}
.tabla-comercial-resumen .bom-summary-value-col{width:112px;min-width:112px;}
.tabla-comercial-resumen .bom-summary-discount-input-col{width:96px;min-width:96px;}
.tabla-comercial-resumen .bom-summary-discount-value-col{width:110px;min-width:110px;}
.tabla-comercial-resumen .bom-summary-transport-col{width:98px;min-width:98px;}
.tabla-comercial-resumen .bom-summary-total-col{width:112px;min-width:112px;}
.bom-commercial-summary-discount-input-cell{vertical-align:middle !important;}
.bom-commercial-summary-discount-input-cell input{min-width:0;width:100%;text-align:center;}
.tabla-comercial-resumen td.col-precio-total input{min-width:0;text-align:center;}
.bom-commercial-discount-value{display:block;}
.bom-commercial-note{margin-top:8px;text-align:right;color:var(--app-text-muted);font-size:13px;}
.bom-commercial-actions-cell{white-space:nowrap;}
.bom-commercial-empty td{color:var(--app-text-muted);font-style:italic;}
#tablaPiezasExtra{min-width:1080px;}
#tablaPiezasExtra .bom-commercial-code-col{width:170px;min-width:170px;}
#tablaPiezasExtra .bom-commercial-name-col{width:280px;min-width:280px;}
#tablaPiezasExtra .bom-commercial-qty-col{width:80px;min-width:80px;}
#tablaPiezasExtra .bom-commercial-weight-col{width:92px;min-width:92px;white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;}
#tablaPiezasExtra .col-precio-unit{width:86px;min-width:86px;}
#tablaPiezasExtra .col-precio-total{width:96px;min-width:96px;white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;}
#tablaPiezasExtra .bom-commercial-actions-cell{width:86px;min-width:86px;}
#tablaPiezasExtra th.bom-commercial-code-col,#tablaPiezasExtra td.bom-commercial-code-col,#tablaPiezasExtra th.bom-commercial-qty-col,#tablaPiezasExtra td.bom-commercial-qty-col{text-align:center;}
#tablaPiezasExtra th.bom-commercial-name-col,#tablaPiezasExtra td.bom-commercial-name-col{text-align:left;}
#tablaPiezasExtra tfoot td{background-color:var(--app-surface-soft);font-weight:600;}
#tablaPiezasExtra select,#tablaPiezasExtra input{min-width:0;}
#tablaPiezasExtra .bom-commercial-code-col select{min-width:150px;}
#tablaPiezasExtra .bom-commercial-qty-col input,#tablaPiezasExtra td.col-precio-unit input{min-width:0;text-align:center;}
#tablaPiezasExtra .bom-commercial-static{display:block;padding:6px 0;line-height:1.3;}
#tablaPiezasExtra .bom-commercial-static-price{text-align:right;font-variant-numeric:tabular-nums;}
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:100;display:flex;justify-content:center;align-items:center;}
.modal-content{background:var(--app-surface);padding:25px;border-radius:8px;width:90%;max-width:500px;box-shadow:0 5px 15px rgba(0,0,0,0.3);}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;}
.modal-header h2{color:var(--app-primary);}
.modal-close{font-size:24px;font-weight:bold;cursor:pointer;border:none;background:none;}
.modal-body .input-group{margin-bottom:15px;}
.modal-body p{font-size:15px;line-height:1.5;margin-bottom:15px;}
.status-message,#errorStatusMessage{font-size:14px;margin-top:10px;text-align:left;font-weight:500;}
.modal-footer{text-align:right;margin-top:20px;}
.modal-footer button{padding:10px 20px;}
.modal-footer .btn-cancel{background-color:#757577;}
.modal-footer .btn-cancel:hover{background-color:var(--app-text-muted);}
.hidden{display:none !important;}
body.legal-modal-open{overflow:hidden;}
#legalNoticeModal{z-index:1500;}
.legal-notice-modal .modal-content{max-width:760px;max-height:85vh;display:flex;flex-direction:column;}
.legal-notice-modal .modal-body{max-height:min(60vh,520px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-right:8px;border-top:1px solid #eee;border-bottom:1px solid #eee;}
.legal-notice-modal .legal-notice-hint{font-size:13px;color:var(--app-text-muted);background:var(--app-surface-soft);padding:8px 10px;border-radius:6px;}
.legal-notice-modal .legal-notice-subtitle{font-size:16px;margin:14px 0 8px;color:var(--app-primary);}
.legal-notice-list{margin:0 0 15px 18px;padding:0;}
.legal-notice-list li{margin-bottom:8px;line-height:1.4;}
.legal-notice-modal .legal-notice-status{min-height:18px;font-size:13px;margin-top:10px;color:var(--app-danger-hover);}
.legal-notice-modal .modal-footer{text-align:center;}
.legal-notice-modal .modal-footer .btn-presupuesto{min-width:220px;font-weight:500;}
.legal-notice-modal .modal-footer .btn-presupuesto:disabled{background-color:#9e9e9e;cursor:not-allowed;}
#cargarDisenoModal .modal-content{max-width:760px;padding:0;overflow:hidden;border:1px solid rgba(18,55,58,0.12);box-shadow:0 24px 60px rgba(10,44,47,0.18);}
#cargarDisenoModal .modal-header{padding:20px 24px 16px;border-bottom:1px solid #dbe7e7;background:linear-gradient(135deg,#f8fbfb 0%,#eef5f5 100%);align-items:flex-start;}
#cargarDisenoModal .modal-header h2{margin:0;font-size:24px;color:#12373a;}
#cargarDisenoModal .modal-body{padding:20px 24px 0;max-height:min(68vh,620px);overflow-y:auto;background:linear-gradient(180deg,#fbfcfc 0%,#f5f8f8 100%);}
#cargarDisenoModal .modal-footer{margin-top:0;padding:16px 24px 22px;border-top:1px solid #e1ebeb;background:var(--app-surface);}
#cargarDisenoModal .modal-footer .btn-cancel{min-width:120px;border-radius:999px;}
.design-load-shell{display:grid;gap:16px;padding-bottom:20px;}
.design-load-shell p{margin:0;}
.design-load-summary{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;padding:16px 18px;border:1px solid #dbe8e8;border-radius:16px;background:linear-gradient(135deg,#f8fbfb 0%,#ffffff 100%);box-shadow:0 10px 24px rgba(18,55,58,0.05);}
.design-load-summary-loading{box-shadow:none;}
.design-load-summary-title{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#607d80;}
.design-load-summary-text{font-size:14px;line-height:1.5;color:#455a64;max-width:52ch;}
.design-load-count{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border-radius:999px;background:#12373a;color:#fff;font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap;}
.design-load-list{display:grid;gap:12px;}
.design-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:15px 16px;border:1px solid #dbe8e8;border-radius:18px;background:linear-gradient(180deg,#ffffff 0%,#fbfdfd 100%);box-shadow:0 8px 20px rgba(18,55,58,0.06);transition:transform 0.18s ease,box-shadow 0.18s ease,border-color 0.18s ease;}
.design-card:hover{transform:translateY(-1px);border-color:#c2d6d6;box-shadow:0 14px 28px rgba(18,55,58,0.1);}
.design-card.is-current{border-color:#8fb8b7;background:linear-gradient(180deg,#f7fbfb 0%,#ffffff 100%);box-shadow:0 14px 28px rgba(30,76,80,0.12);}
.design-card-main{display:grid;gap:10px;min-width:0;padding:0;border:none;background:none;color:inherit;text-align:left;cursor:pointer;font:inherit;}
.design-card-main:focus-visible,.design-card-action:focus-visible,.design-load-state-action:focus-visible{outline:3px solid rgba(21,101,192,0.22);outline-offset:3px;}
.design-card-name-row{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;}
.design-card-name{min-width:0;font-size:18px;font-weight:600;line-height:1.3;color:#12373a;word-break:break-word;}
.design-card-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#e4f0f0;color:#1E4C50;font-size:12px;font-weight:700;letter-spacing:0.03em;text-transform:uppercase;}
.design-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#546e7a;font-size:13px;}
.design-card-meta-label{font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#607d80;}
.design-card-actions{display:flex;flex-direction:column;gap:8px;align-self:center;}
.design-card-action{min-width:118px;padding:10px 14px;border-radius:12px;border:1px solid transparent;cursor:pointer;font:inherit;font-size:14px;font-weight:600;transition:transform 0.18s ease,background-color 0.18s ease,border-color 0.18s ease,color 0.18s ease;}
.design-card-action:hover,.design-load-state-action:hover{transform:translateY(-1px);}
.design-card-action-load{background:var(--app-primary);color:#fff;}
.design-card-action-load:hover{background:var(--app-primary-hover);}
.design-card-action-delete{background:#fff3f1;color:#a23d32;border-color:#efc3bc;}
.design-card-action-delete:hover{background:#ffe7e2;border-color:#e5a69b;color:#8c2d25;}
.design-load-state{display:grid;gap:10px;justify-items:start;padding:22px;border:1px dashed #c5d6d6;border-radius:18px;background:linear-gradient(180deg,#fbfcfc 0%,#ffffff 100%);}
.design-load-state-error{border-style:solid;border-color:#e9c6bf;background:linear-gradient(180deg,#fff8f6 0%,#ffffff 100%);}
.design-load-state-eyebrow{font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#607d80;}
.design-load-state-title{margin:0;font-size:24px;line-height:1.15;color:#12373a;}
.design-load-state-text{font-size:14px;line-height:1.6;color:#546e7a;max-width:52ch;}
.design-load-state-action{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border:none;border-radius:999px;background:var(--app-secondary);color:#fff;font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:transform 0.18s ease,background-color 0.18s ease;}
.design-load-state-action:hover{background:var(--app-secondary-hover);}
.design-load-skeleton{display:grid;gap:12px;}
.design-load-skeleton-card{height:96px;border-radius:18px;background:linear-gradient(90deg,#eef4f4 0%,#f8fbfb 50%,#eef4f4 100%);background-size:200% 100%;animation:design-load-pulse 1.6s ease-in-out infinite;}
@keyframes design-load-pulse{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
#status-message{font-size:14px;margin-top:10px;text-align:left;font-weight:500;}
#diagrama3dContainer{width:100%;height:550px;border:1px solid var(--app-border-strong);margin-top:20px;position:relative;background-color:var(--app-surface-muted);border-radius:4px;overflow:hidden;cursor:default;}
#diagrama3dContainer.placement-active{cursor:crosshair !important;}
#diagrama3d{width:100%;height:100%;display:block;}
#editor3d-controls{position:absolute;bottom:80px;right:10px;z-index:10;display:flex;align-items:center;}
.btn-eliminar-3d{padding:8px 16px;font-size:14px;background-color:var(--app-danger);color:white;border:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease;}
.btn-eliminar-3d:hover{background-color:var(--app-danger-hover);}
.btn-undo-3d{padding:8px;background-color:var(--app-warning);color:white;border:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease;margin-right:10px;display:flex;align-items:center;justify-content:center;}
.btn-undo-3d:hover{background-color:var(--app-warning-hover);}
.btn-undo-3d:disabled{background-color:#9e9e9e;cursor:not-allowed;}
.btn-undo-3d svg{width:18px;height:18px;}
#columnLabelsContainer{position:absolute;bottom:10px;left:10px;right:10px;background:transparent;padding:8px;border-radius:4px;border:none;z-index:10;display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;min-height:60px;box-shadow:none;}
.column-label-item{border:1px solid rgba(176,190,197,0.8);padding:5px 8px;text-align:center;background:rgba(255,255,255,0.85);border-radius:3px;min-width:75px;flex-shrink:0;cursor:move;display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:14px;transition:background-color 0.2s ease,border-color 0.2s ease,opacity 0.2s ease;box-shadow:0 1px 3px rgba(0,0,0,0.12);}
.column-label-item:hover{background-color:rgba(245,245,245,0.95);}
.column-label-item span{display:block;margin-bottom:4px;font-weight:500;color:#37474f;}
.column-label-item label{font-size:12px;cursor:pointer;display:flex;align-items:center;color:#546e7a;}
.column-label-item input[type="checkbox"]{margin-right:4px;cursor:pointer;vertical-align:middle;}
.dragging{opacity:0.4 !important;background-color:var(--app-surface-muted) !important;border-color:var(--app-border) !important;}
.drag-over{border-left:3px solid var(--app-primary) !important;background-color:var(--app-surface-muted) !important;}
.fullscreen-btn{position:absolute;top:10px;right:10px;z-index:20;background-color:rgba(255,255,255,0.8);border:1px solid var(--app-border-strong);border-radius:50%;width:36px;height:36px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background-color 0.3s ease,transform 0.2s ease,-webkit-transform 0.2s ease;}
.fullscreen-btn:hover{background-color:var(--app-surface);-webkit-transform:scale(1.1);transform:scale(1.1);}
.fullscreen-btn svg{width:20px;height:20px;fill:var(--app-text);}
#xr-action-bar{display:flex;flex-direction:column;gap:8px;align-items:stretch;width:100%;margin-top:4px;}
#btn-vr-3d,#btn-ar-3d{width:100%;min-height:42px;padding:10px 14px;border:none;border-radius:10px;color:#fff;font-weight:600;font-size:14px;letter-spacing:0.01em;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;transition:transform 0.2s ease,background-color 0.2s ease,opacity 0.2s ease;}
#btn-vr-3d{background:var(--app-primary);}
#btn-ar-3d{background:var(--app-secondary);}
#btn-vr-3d:hover{transform:translateY(-1px);background:var(--app-primary-hover);}
#btn-ar-3d:hover{transform:translateY(-1px);background:var(--app-secondary-hover);}
#btn-ar-3d.xr-button--unavailable{background:#5b6672;}
#btn-ar-3d.xr-button--unavailable:hover{transform:none;background:#5b6672;}
#btn-vr-3d:disabled,#btn-ar-3d:disabled{opacity:0.55;cursor:not-allowed;transform:none;}
#diagrama3dContainer:not(:fullscreen) #btn-vr-3d,
#diagrama3dContainer.xr-session-active #btn-vr-3d{display:none !important;}
#diagrama3dContainer.xr-session-active #btn-ar-3d{display:none !important;}
#diagrama3dContainer.vr-active::after{content:'';position:absolute;top:0;bottom:0;left:50%;width:8px;background:linear-gradient(to right,transparent,rgba(255,255,255,0.22) 40%,rgba(255,255,255,0.22) 60%,transparent);transform:translateX(-50%);z-index:22;pointer-events:none;}
#diagrama3dContainer.xr-session-active .fullscreen-btn,
#diagrama3dContainer.xr-session-active #fullscreen-controls-panel,
#diagrama3dContainer.xr-session-active #toggle-panel-btn,
#diagrama3dContainer.xr-session-active #columnLabelsContainer,
#diagrama3dContainer.xr-session-active #editor3d-controls{display:none !important;}
/* VR toast de error */
.vr-toast{position:absolute;bottom:64px;left:50%;transform:translateX(-50%);max-width:calc(100% - 32px);padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;text-align:center;z-index:40;pointer-events:none;animation:vr-toast-in 0.25s ease forwards;}
.vr-toast--error{background:rgba(175,28,28,0.92);color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
@keyframes vr-toast-in{from{opacity:0;transform:translateX(-50%) translateY(8px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
/* VR fade de entrada */
.vr-entry-fade{position:absolute;inset:0;background:#000;z-index:30;pointer-events:none;opacity:1;transition:opacity 0.5s ease;}
.vr-entry-fade--out{opacity:0;}
/* VR hint de controles */
.vr-hint{position:absolute;bottom:14%;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:35;pointer-events:none;opacity:1;transition:opacity 0.55s ease;}
.vr-hint--fade{opacity:0;}
.vr-hint__line{background:rgba(0,0,0,0.6);color:rgba(255,255,255,0.93);font-size:13px;padding:5px 14px;border-radius:20px;white-space:nowrap;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);}
#diagrama3dContainer:fullscreen,#parts-container:fullscreen{width:100vw;height:100vh;padding:20px;overflow-y:auto;background:var(--app-surface-soft);}
#diagrama3dContainer:fullscreen{background:var(--app-surface-muted);}
#fullscreen-controls-panel{position:absolute;top:0;left:0;width:320px;height:100%;background-color:rgba(250,250,250,0.95);border-right:1px solid var(--app-border);padding:20px;box-shadow:2px 0 10px rgba(0,0,0,0.1);-webkit-transform:translateX(-100%);transform:translateX(-100%);transition:transform 0.3s ease-in-out,-webkit-transform 0.3s ease-in-out;z-index:25;overflow-y:auto;}
#diagrama3dContainer:fullscreen #fullscreen-controls-panel{-webkit-transform:translateX(0);transform:translateX(0);}
#fullscreen-controls-panel.closed{-webkit-transform:translateX(-100%) !important;transform:translateX(-100%) !important;}
#toggle-panel-btn{position:absolute;top:50%;left:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);z-index:30;width:25px;height:60px;background-color:rgba(250,250,250,0.95);border:1px solid var(--app-border);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;display:none;justify-content:center;align-items:center;transition:left 0.3s ease-in-out;}
#diagrama3dContainer:fullscreen #toggle-panel-btn{display:flex;left:320px;}
#fullscreen-controls-panel.closed + #toggle-panel-btn{left:0;}
#toggle-panel-btn svg{width:18px;height:18px;fill:var(--app-text);transition:transform 0.3s ease,-webkit-transform 0.3s ease;}
#fullscreen-controls-panel.closed + #toggle-panel-btn svg{-webkit-transform:rotate(180deg);transform:rotate(180deg);}
@media (min-width:1200px){
  .container{
    max-width:1520px;
  }

  #diagrama3dContainer{
    height:auto;
    aspect-ratio:16 / 9;
  }
}
@media (max-width:768px){.user-menu-container{top:10px;right:10px;}
h1{font-size:24px;margin-top:40px;}
.tramo-modulos-container table,.tramo-modulos-container tbody,.tramo-modulos-container tr,.tramo-modulos-container th{display:block;}
.tramo-modulos-container thead{display:none;}
.tramo-modulos-container tr{display:flex;flex-wrap:wrap;justify-content:space-around;gap:10px;}
.tramo-modulos-container td{flex:1 1 45%;max-width:calc(50% - 10px);border:1px solid var(--app-border-strong);border-radius:4px;padding:10px;background-color:var(--app-surface);display:flex;flex-direction:column;align-items:center;}
.tramo-modulos-container td label{display:block;font-weight:500;margin-bottom:8px;}
.tramo-modulos-container .quantity-btn{display:inline-block;background-color:var(--app-surface-accent);border:1px solid var(--app-border-strong);border-radius:50%;cursor:pointer;font-size:20px;font-weight:bold;width:32px;height:32px;line-height:30px;text-align:center;user-select:none;}
.tramo-modulos-container .quantity-btn:hover{background-color:var(--app-surface-accent-hover);}
.tramo-modulos-container .modulo-input{width:50px;border:none;text-align:center;font-size:16px;}
.tramo-modulos-container input[type="number"]{-moz-appearance:textfield;}
.tramo-modulos-container input[type="number"]::-webkit-outer-spin-button,.tramo-modulos-container input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
#tablaPiezas thead th:first-child,#tablaPiezas tbody td:first-child,#tablaPiezas tfoot td:first-child{display:none;}
#tablaPiezas tfoot td#pesoTotalGlobal{text-align:right;padding-right:10px;}
#tablaPiezas tfoot td#pesoTotalGlobal::before{content:"Total:";font-weight:bold;float:left;padding-left:10px;}
#btn-vr-3d,#btn-ar-3d{min-height:40px;padding:10px 12px;font-size:13px;}
#cargarDisenoModal .modal-content{width:calc(100% - 16px);}
#cargarDisenoModal .modal-header{padding:18px 18px 14px;}
#cargarDisenoModal .modal-body{padding:18px 18px 0;}
#cargarDisenoModal .modal-footer{padding:14px 18px 18px;}
.design-load-summary{flex-direction:column;align-items:flex-start;}
.design-card{grid-template-columns:1fr;}
.design-card-actions{flex-direction:row;width:100%;}
.design-card-action{flex:1 1 0;min-width:0;}
.design-load-state-title{font-size:21px;}
}
@media (min-width:769px){.tramo-row{flex-direction:row;flex-wrap:wrap;align-items:flex-end;gap:15px;}
.tramo-row .input-group{flex:1 1 180px;margin-bottom:0;}
.tramo-row .input-group-checkbox,.tramo-row .tramo-paso-peaton-container{flex:1;padding-top:20px;margin-bottom:0;align-self:center;}
.tramo-row .tramo-paso-peaton-container{display:flex;flex-direction:column;gap:5px;}
}
.tramo-label{color:#fff;background-color:rgba(30,76,80,0.8);padding:4px 8px;border-radius:4px;font-size:16px;font-weight:bold;border:1px solid rgba(255,255,255,0.5);pointer-events:none;text-shadow:1px 1px 2px rgba(0,0,0,0.3);}
.corner-label{font-size:20px;font-weight:bold;color:var(--app-primary-hover);background-color:rgba(255,255,255,0.7);border:1px solid var(--app-primary-hover);border-radius:50%;width:30px;height:30px;display:flex;justify-content:center;align-items:center;pointer-events:none;}
.replanteo-label{color:#fff;background:rgba(17,17,17,0.88);padding:3px 8px;border-radius:999px;font-size:13px;font-weight:600;border:1px solid rgba(255,255,255,0.25);pointer-events:none;white-space:nowrap;box-shadow:0 2px 6px rgba(0,0,0,0.18);}

/* Selección de etiquetas (clic 1 a 1) */
.tramo-label.label-selected,.corner-label.label-selected{box-shadow:0 0 0 3px rgba(255,235,59,0.95);}

/* --- Login / Registro / Recuperar contraseña --- */
.login-body{
  background:var(--app-page-bg);
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:100vh;
  padding:0;              /* anula el padding global del body */
}

.login-container{
  width:100%;
  max-width:420px;
  margin:0 auto;
  background:var(--app-surface);
  padding:28px;
  border-radius:10px;
  box-shadow:0 2px 12px rgba(0,0,0,0.10);
}

.login-logo,
.login-container .logo{
  display:block;
  margin:0 auto 16px;
  max-width:180px;
  height:auto;
}

.login-container h1{
  text-align:center;
  margin:0 0 18px;
  color:var(--app-primary);
}

.login-form{width:100%;}

.login-container .input-group{margin-bottom:16px;}

.login-container .btn-calcular{
  width:100%;
  font-size:18px;
}

.login-error{
  color:var(--app-danger);
  background:#ffebee;
  border:1px solid var(--app-danger);
  padding:10px;
  border-radius:6px;
  margin-bottom:14px;
  text-align:center;
}

.login-success{
  color:var(--app-success-hover);
  background:#e8f5e9;
  border:1px solid var(--app-success);
  padding:10px;
  border-radius:6px;
  margin-bottom:14px;  /* estaba mal escrito (margin-body) */
  text-align:center;
}

.login-subtext{
  text-align:center;
  margin-top:14px;
  color:var(--app-text-muted);
}

.login-subtext a{
  color:var(--app-primary);
  font-weight:500;
  text-decoration:none;
}

.login-subtext a:hover{text-decoration:underline;}

.logout-link{
  float:right;
  margin-top:5px;
  color:var(--app-primary);
  text-decoration:none;
  font-size:14px;
}

.logout-link:hover{text-decoration:underline;}

/* --- Panel de uso (admin) --- */
.usage-view-body{
  background:linear-gradient(180deg,var(--app-page-bg) 0%,var(--app-surface-soft) 100%);
  min-height:100vh;
  padding:16px;
}

.usage-panel{
  width:min(1280px,100%);
  margin:0 auto;
  background:var(--app-surface);
  border:1px solid var(--app-border);
  border-radius:14px;
  box-shadow:0 12px 32px rgba(11,51,53,0.09);
  padding:22px;
}

.usage-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.usage-header h1{
  margin:0;
  text-align:left;
  color:var(--app-primary-hover);
}

.usage-subtitle{
  margin-top:6px;
  color:var(--app-text-muted);
  font-size:14px;
}

.usage-back-link{
  color:var(--app-primary);
  text-decoration:none;
  font-weight:600;
  background:var(--app-surface-soft);
  border:1px solid var(--app-border);
  border-radius:999px;
  padding:8px 14px;
  line-height:1;
}

.usage-back-link:hover{
  background:var(--app-surface-accent-hover);
}

.usage-filter-form{
  display:grid;
  grid-template-columns:repeat(3,minmax(170px,1fr));
  gap:12px;
  align-items:end;
  background:var(--app-surface-soft);
  border:1px solid var(--app-border);
  border-radius:12px;
  padding:14px;
  margin-bottom:16px;
}

.usage-filter-form .usage-input-group{
  margin:0;
}

.usage-filter-form .usage-input-group label{
  color:var(--app-primary);
}

.usage-apply-btn{
  margin-top:0;
  height:auto;
  min-height:42px;
  width:100%;
}

.usage-kpis{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  margin-bottom:16px;
}

.usage-kpi-card{
  background:linear-gradient(180deg,var(--app-surface) 0%,var(--app-surface-soft) 100%);
  border:1px solid var(--app-border);
  border-radius:12px;
  padding:12px 14px;
}

.usage-kpi-label{
  margin:0 0 8px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.04em;
  color:var(--app-text-muted);
}

.usage-kpi-value{
  margin:0;
  color:var(--app-primary-hover);
  font-weight:600;
  font-size:22px;
  line-height:1.2;
}

.usage-kpi-value-small{
  font-size:14px;
  font-weight:500;
}

.usage-summary-section{
  margin-bottom:16px;
}

.usage-section-title{
  margin:0 0 10px;
  color:#12373a;
  font-size:18px;
}

.usage-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:12px;
}

.usage-summary-card{
  background:linear-gradient(180deg,#ffffff 0%,#f7fbfb 100%);
  border:1px solid #dbe8e8;
  border-radius:12px;
  padding:14px;
}

.usage-summary-title{
  margin:0 0 12px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.04em;
  color:#607d80;
}

.usage-metric-list{
  margin:0;
  display:grid;
  gap:8px;
}

.usage-metric-list div{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}

.usage-metric-list dt{
  color:#455a64;
}

.usage-metric-list dd{
  margin:0;
  color:#12373a;
  font-weight:600;
  font-variant-numeric:tabular-nums;
}

.usage-summary-note{
  margin:12px 0 0;
  color:#607d80;
  font-size:13px;
}

.usage-summary-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.usage-summary-list li{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  color:#455a64;
}

.usage-summary-list span{
  min-width:0;
  word-break:break-word;
}

.usage-summary-list strong{
  color:#12373a;
  font-weight:600;
  white-space:nowrap;
}

.usage-table-shell{
  border:1px solid #d9e3e4;
  border-radius:12px;
  overflow:auto;
  background:#fff;
}

.usage-table{
  width:100%;
  min-width:1540px;
  border-collapse:collapse;
}

.usage-table thead th{
  background:#12373a;
  color:#fff;
  text-align:left;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.03em;
  white-space:nowrap;
  padding:11px 10px;
}

.usage-table tbody td{
  border-bottom:1px solid #e6edee;
  padding:10px;
  vertical-align:top;
  font-size:14px;
}

.usage-table tbody tr:nth-child(even){
  background:#f8fcfc;
}

.usage-table td.num{
  text-align:right;
  font-variant-numeric:tabular-nums;
}

.usage-table td.hosts{
  min-width:220px;
  word-break:break-word;
  color:#455a64;
}

.usage-table td.usage-apps{
  min-width:210px;
  word-break:break-word;
  color:#455a64;
}

.usage-table td.last-seen{
  white-space:nowrap;
  color:#37474f;
}

.usage-empty-row td{
  text-align:center !important;
  font-weight:500;
  color:#607d80;
  padding:18px 12px;
}

.usage-note{
  margin-top:14px;
  color:#607d80;
  font-size:13px;
}

@media (min-width:1366px) and (min-aspect-ratio:16/9){
  .usage-view-body{
    padding:12px;
  }

  .usage-panel{
    width:min(1720px,calc(100vw - 24px));
    min-height:calc(100vh - 24px);
    padding:18px 20px;
    display:grid;
    grid-template-rows:auto auto auto auto minmax(0,1fr) auto;
    gap:14px;
  }

  .usage-header,
  .usage-filter-form,
  .usage-kpis,
  .usage-summary-section,
  .usage-note{
    margin:0;
  }

  .usage-header{
    align-items:center;
  }

  .usage-filter-form{
    grid-template-columns:minmax(180px,220px) minmax(180px,220px) minmax(220px,1fr);
    gap:10px;
    padding:12px;
  }

  .usage-kpis{
    gap:10px;
  }

  .usage-kpi-card{
    min-height:92px;
    padding:10px 12px;
  }

  .usage-summary-grid{
    gap:10px;
  }

  .usage-summary-card{
    padding:12px;
  }

  .usage-table-shell{
    min-height:0;
    max-height:none;
    overflow:auto;
  }

  .usage-table thead th{
    position:sticky;
    top:0;
    z-index:1;
  }

  .usage-table td.hosts{
    min-width:180px;
  }
}

@media (max-width:900px){
  .usage-view-body{
    padding:8px;
  }

  .usage-panel{
    padding:14px;
    border-radius:10px;
  }

  .usage-filter-form{
    grid-template-columns:1fr;
    padding:12px;
  }

  .usage-kpis{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .usage-summary-grid{
    grid-template-columns:1fr;
  }

  .usage-table-shell{
    border:none;
    overflow:visible;
    background:transparent;
  }

  .usage-table{
    min-width:0;
    border-collapse:separate;
    border-spacing:0;
  }

  .usage-table thead{
    display:none;
  }

  .usage-table tbody{
    display:block;
  }

  .usage-table tbody tr{
    display:block;
    margin-bottom:10px;
    border:1px solid #dbe8e8;
    border-radius:10px;
    padding:10px 12px;
    background:#fff;
    box-shadow:0 4px 14px rgba(17,56,58,0.06);
  }

  .usage-table tbody td{
    display:grid;
    grid-template-columns:minmax(105px,42%) 1fr;
    gap:8px;
    padding:8px 0;
    border-bottom:1px dashed #e3ecec;
    text-align:left;
  }

  .usage-table tbody td::before{
    content:attr(data-label);
    color:#1E4C50;
    font-weight:600;
  }

  .usage-table tbody td.usage-user{
    display:block;
    padding:0 0 8px;
    margin-bottom:4px;
    border-bottom:1px solid #e3ecec;
    color:#12373a;
    font-size:16px;
    font-weight:600;
  }

  .usage-table tbody td.usage-user::before{
    display:none;
  }

  .usage-table tbody td.num{
    text-align:left;
  }

  .usage-empty-row td{
    display:block;
    border-bottom:none;
    text-align:center !important;
    padding:12px 0 4px;
  }

  .usage-empty-row td::before{
    display:none;
  }
}

@media (max-width:560px){
  .usage-kpis{
    grid-template-columns:1fr;
  }
}
