*{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);}
body:not([data-es-admin="1"]) #btn-vista-perspectiva,
body:not([data-es-admin="1"]) #btn-vista-planta{display:none !important;}
.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);}
.app-footer{
  width:100%;
  max-width:1200px;
  margin:12px auto 0;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  color:var(--app-text-muted);
  font-size:13px;
}

.app-legal-links{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:12px;
}

.app-legal-links a{
  color:var(--app-primary);
  font-weight:600;
  text-decoration:none;
}

.app-legal-links a:hover{
  text-decoration:underline;
}
.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-export-group{padding:8px 10px 9px;border-top:1px solid var(--app-border);border-bottom:1px solid var(--app-border);}
.user-menu-export-title{padding:0 4px 7px;color:var(--app-text-muted);font-size:12px;font-weight:500;letter-spacing:0;}
.user-menu-export-options{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.user-menu-dropdown .user-menu-export-options a{display:flex;align-items:center;justify-content:center;padding:7px 8px;border:1px solid var(--app-border);border-radius:4px;background:var(--app-surface-soft);font-size:13px;font-weight:500;line-height:1;}
.user-menu-dropdown .user-menu-export-options a:hover{background-color:var(--app-surface-accent-hover);border-color:var(--app-border-strong);color:var(--app-primary);}
.user-menu-language-group{padding:8px 10px 9px;border-top:1px solid var(--app-border);}
.user-menu-language-title{padding:0 4px 7px;color:var(--app-text-muted);font-size:12px;font-weight:500;letter-spacing:0;}
.user-menu-language-options{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.user-menu-dropdown .user-menu-language-options a{display:flex;align-items:center;justify-content:center;padding:7px 8px;border:1px solid var(--app-border);border-radius:4px;background:var(--app-surface-soft);font-size:12px;font-weight:500;line-height:1;text-align:center;}
.user-menu-dropdown .user-menu-language-options a:hover{background-color:var(--app-surface-accent-hover);border-color:var(--app-border-strong);color:var(--app-primary);}
.user-menu-dropdown .user-menu-language-options a.language-option-active{background-color:var(--app-primary);color:#fff;border-color:var(--app-primary);font-weight:600;}
.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-pricing-warning{margin:12px 0;padding:12px 14px;border:1px solid #f2cc8f;border-radius:12px;background:#fff4de;color:#8a4b12;font-size:13px;line-height:1.4;}
.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-history{background:#eef7f6;color:#1E4C50;border-color:#c7dddd;}
.design-card-action-history:hover{background:#e0f0ef;border-color:#abcaca;}
.design-card-action-delete{background:#fff3f1;color:#a23d32;border-color:#efc3bc;}
.design-card-action-delete:hover{background:#ffe7e2;border-color:#e5a69b;color:#8c2d25;}
.design-revision-modal{max-width:760px;width:min(92vw,760px);}
.design-revision-help{margin:0 0 14px;color:#546e7a;line-height:1.5;}
.design-revision-list{display:grid;gap:10px;}
.design-revision-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px;border:1px solid #dbe8e8;border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,#fbfdfd 100%);}
.design-revision-main{display:grid;gap:6px;min-width:0;}
.design-revision-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#12373a;}
.design-revision-title-row span{display:inline-flex;padding:4px 8px;border-radius:999px;background:#e4f0f0;color:#1E4C50;font-size:12px;font-weight:700;}
.design-revision-main p{margin:0;color:#546e7a;font-size:13px;}
.design-revision-main code{width:max-content;max-width:100%;padding:3px 6px;border-radius:6px;background:#f1f5f5;color:#607d80;font-size:12px;}
.design-revision-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.design-revision-action{padding:9px 12px;border:1px solid #c7dddd;border-radius:10px;background:#fff;color:#1E4C50;font:inherit;font-size:13px;font-weight:700;cursor:pointer;}
.design-revision-action:hover{background:#eef7f6;}
.design-revision-action-restore{background:var(--app-primary);border-color:var(--app-primary);color:#fff;}
.design-revision-action-restore:hover{background:var(--app-primary-hover);}
.design-revision-state{padding:16px;border:1px dashed #c5d6d6;border-radius:14px;color:#546e7a;background:#fbfcfc;}
.design-revision-state-error{border-style:solid;border-color:#e9c6bf;background:#fff8f6;color:#a23d32;}
.design-revision-status.is-error{color:#a23d32;}
.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:flex-start;}
.editor3d-selection-actions{display:flex;flex-direction:column;gap:8px;align-items:stretch;}
.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-rotar-3d{padding:8px 16px;font-size:14px;background-color:var(--app-secondary);color:white;border:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease,opacity 0.2s ease;}
.btn-rotar-3d:hover{background-color:var(--app-secondary-hover);}
.btn-rotar-3d:disabled{opacity:0.7;cursor:not-allowed;}
.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,.btn-lateral{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; background-color: var(--app-primary); margin-bottom: 5px;}
.btn-lateral.btn-lateral-icon{width:auto;flex:1 1 0;min-width:0;padding:8px;margin-bottom:0;}
.btn-lateral.btn-lateral-icon svg{width:20px;height:20px;fill:currentColor;display:block;}
.btn-lateral.btn-lateral-icon.active{background-color:var(--app-secondary);box-shadow:inset 0 0 0 2px rgba(255,255,255,0.55);}
.btn-lateral.btn-lateral-icon:focus-visible{outline:2px solid #fff;outline-offset:2px;}
#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,.btn-lateral{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-revision-card{grid-template-columns:1fr;}
.design-revision-actions{justify-content:stretch;}
.design-revision-action{flex:1 1 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);}
.plan-dim-label{color:#c0392b;background:rgba(255,255,255,0.92);padding:0 4px;font-family:"Courier New",Consolas,monospace;font-size:13px;font-weight:600;letter-spacing:0.02em;pointer-events:none;white-space:nowrap;}
.plan-angle-label{color:#c0392b;background:rgba(255,255,255,0.92);padding:0 4px;font-family:"Courier New",Consolas,monospace;font-size:12px;font-weight:600;pointer-events:none;white-space:nowrap;}
.plan-module-label{color:#101820;background:rgba(255,255,255,0.92);padding:0 4px;font-family:Arial,Helvetica,sans-serif;font-size:18px;font-weight:700;pointer-events:none;white-space:nowrap;}
.plan-total-label{color:#1f6feb;background:rgba(255,255,255,0.92);padding:0 5px;font-family:Arial,Helvetica,sans-serif;font-size:14px;font-weight:700;pointer-events:none;white-space:nowrap;}

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

.login-container{
  width:100%;
  max-width:460px;
  margin:0 auto;
  background:var(--app-surface);
  padding:30px;
  border-radius:8px;
  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 8px;
  color:var(--app-primary);
}

.login-intro{
  margin:0 0 20px;
  color:var(--app-text-muted);
  font-size:15px;
  line-height:1.45;
  text-align:center;
}

.login-form{width:100%;}

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

.login-container .input-group label{
  color:var(--app-text);
}

.input-help{
  margin-top:6px;
  color:var(--app-text-muted);
  font-size:13px;
  line-height:1.35;
}

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

.login-inline-link{
  display:inline-flex;
  margin-top:12px;
  color:var(--app-primary);
  font-size:14px;
  font-weight:600;
  line-height:1.35;
  text-decoration:none;
}

.login-inline-link:hover{
  text-decoration:underline;
}

.login-forgot-link{
  width:100%;
  justify-content:center;
}

.register-callout{
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid rgba(20,58,62,0.16);
  text-align:center;
}

.register-callout h2{
  margin:0 0 8px;
  color:var(--app-primary-hover);
  font-size:20px;
  line-height:1.25;
}

.register-callout p{
  margin:0 0 16px;
  color:var(--app-text-muted);
  font-size:15px;
  line-height:1.45;
}

.register-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:42px;
  padding:10px 16px;
  border:1px solid var(--app-primary);
  border-radius:4px;
  background:var(--app-surface);
  color:var(--app-primary);
  font-size:16px;
  font-weight:700;
  line-height:1.25;
  text-decoration:none;
  transition:background-color 0.2s ease,color 0.2s ease,transform 0.2s ease;
}

.register-cta:hover{
  background:var(--app-primary);
  color:#ffffff;
  transform:translateY(-1px);
}

.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-return-text{
  margin-top:20px;
}

.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;}

/* --- Landing publica --- */
.landing-body{
  background:#f6f8f7;
  color:#17383b;
  min-height:100vh;
  padding:0;
}

.landing-nav{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:24px;
  padding:14px clamp(18px,4vw,64px);
  background:#ffffff;
  border-bottom:1px solid #dfe8e6;
}

.landing-nav-links{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:18px;
  font-size:15px;
}

.landing-nav-links a{
  color:#35585b;
  text-decoration:none;
  font-weight:500;
}

.landing-nav-links a:hover{
  color:#1E4C50;
}

.landing-nav-links .landing-nav-login{
  color:#ffffff;
  background:#1E4C50;
  border-radius:4px;
  padding:10px 14px;
}

.landing-nav-links .landing-nav-login:hover{
  color:#ffffff;
  background:#143336;
}

.landing-hero{
  min-height:min(720px,82vh);
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 74% 42%,rgba(67,160,71,0.20) 0%,rgba(67,160,71,0) 36%),
    linear-gradient(120deg,#102f32 0%,#173f42 46%,#245b54 100%);
  color:#ffffff;
}

.landing-hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(15,42,45,0.96) 0%,rgba(15,42,45,0.88) 38%,rgba(15,42,45,0.32) 68%,rgba(15,42,45,0.16) 100%),
    linear-gradient(180deg,rgba(9,27,29,0.15) 0%,rgba(9,27,29,0.42) 100%);
  pointer-events:none;
}

.landing-hero-scene{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
}

.landing-hero-scene canvas{
  display:block;
  width:100%;
  height:100%;
}

.landing-hero-inner{
  width:min(1180px,100%);
  margin:0 auto;
  padding:72px clamp(18px,4vw,64px);
  position:relative;
  z-index:2;
}

.landing-eyebrow,
.landing-kicker{
  margin:0 0 12px;
  color:#e7bd4c;
  font-size:14px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0;
}

.landing-hero h1{
  max-width:680px;
  margin:0 0 18px;
  color:#ffffff;
  text-align:left;
  font-size:52px;
  line-height:1.04;
  text-shadow:0 3px 14px rgba(0,0,0,0.28);
}

.landing-hero-copy{
  max-width:620px;
  margin:0;
  font-size:20px;
  line-height:1.55;
  color:#edf5f3;
  text-shadow:0 2px 10px rgba(0,0,0,0.24);
}

.landing-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}

.landing-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:12px 18px;
  border-radius:4px;
  font-weight:700;
  text-decoration:none;
  border:1px solid transparent;
}

.landing-button-primary{
  color:#17383b;
  background:#f0c24f;
}

.landing-button-primary:hover{
  background:#e4b33e;
}

.landing-button-secondary{
  color:#ffffff;
  border-color:rgba(255,255,255,0.75);
}

.landing-button-secondary:hover{
  background:rgba(255,255,255,0.12);
}

.landing-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  background:#dfe8e6;
  border-top:1px solid #dfe8e6;
  border-bottom:1px solid #dfe8e6;
}

.landing-strip-item{
  background:#ffffff;
  padding:22px clamp(18px,3vw,36px);
}

.landing-strip-item strong{
  display:block;
  color:#1E4C50;
  font-size:18px;
  margin-bottom:6px;
}

.landing-strip-item span{
  color:#5c6f70;
  line-height:1.45;
}

.landing-section{
  padding:72px clamp(18px,4vw,64px);
  background:#f6f8f7;
}

.landing-section-light{
  background:#ffffff;
}

.landing-section-muted{
  background:#ecf2f0;
}

.landing-section-preview{
  background:#eef4f2;
}

.landing-section-inner{
  width:min(1180px,100%);
  margin:0 auto;
}

.landing-section-heading{
  max-width:760px;
  margin-bottom:30px;
}

.landing-section h2{
  margin:0 0 12px;
  color:#17383b;
  font-size:34px;
  line-height:1.18;
}

.landing-section-heading p,
.landing-audience p,
.landing-card p,
.landing-flow p,
.landing-faq p{
  color:#526a6b;
  line-height:1.62;
}

.landing-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.landing-preview-layout{
  display:grid;
  grid-template-columns:minmax(0,0.78fr) minmax(0,1.22fr);
  gap:36px;
  align-items:center;
}

.landing-app-preview{
  margin:0;
  border:1px solid #d3dfdd;
  border-radius:8px;
  background:#ffffff;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(15,42,45,0.12);
}

.landing-app-preview img{
  display:block;
  width:100%;
  height:auto;
}

.landing-card,
.landing-audience-grid article{
  border:1px solid #d9e4e2;
  border-radius:8px;
  background:#ffffff;
  padding:22px;
}

.landing-card h3,
.landing-audience-grid h3{
  margin:0 0 10px;
  color:#1E4C50;
  font-size:20px;
}

.landing-specs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
  margin:0;
  padding:0;
}
.landing-spec{
  border:1px solid #d9e4e2;
  border-radius:8px;
  background:#ffffff;
  padding:18px 22px;
}
.landing-spec dt{
  margin:0 0 6px;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:#1E4C50;
}
.landing-spec dd{
  margin:0;
  font-size:15px;
  line-height:1.5;
  color:#333333;
}

.landing-flow-layout{
  display:grid;
  grid-template-columns:minmax(0,0.85fr) minmax(0,1.15fr);
  gap:44px;
  align-items:start;
}

.landing-flow{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:18px;
}

.landing-flow li{
  display:grid;
  grid-template-columns:minmax(150px,190px) minmax(0,1fr);
  gap:18px;
  align-items:stretch;
  min-height:156px;
  padding:14px;
  background:#ffffff;
  border:1px solid #d9e4e2;
  border-radius:8px;
  overflow:hidden;
}

.landing-flow-media{
  position:relative;
  margin:0;
  min-height:128px;
  border:1px solid #c9d8d5;
  border-radius:6px;
  background:#143336;
  overflow:hidden;
  isolation:isolate;
}

.landing-flow-media::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(180deg,rgba(10,34,36,0.02) 0%,rgba(10,34,36,0.18) 100%);
  pointer-events:none;
}

.landing-flow-media img{
  display:block;
  width:100%;
  height:100%;
  min-height:128px;
  object-fit:cover;
  transform:scale(1.06);
  filter:saturate(1.04) contrast(0.98);
}

.landing-flow-media-form img{
  object-position:center 18%;
}

.landing-flow-media-model img{
  object-position:center center;
  animation:landingFlowDrift 7s ease-in-out infinite alternate;
}

.landing-flow-media-table img{
  object-position:center 48%;
}

.landing-flow-media-export img{
  object-position:center 34%;
  opacity:0.58;
}

.landing-flow-copy{
  display:grid;
  grid-template-columns:48px minmax(0,1fr);
  column-gap:14px;
  align-content:center;
  padding:6px 4px 6px 0;
}

.landing-flow-number{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:50%;
  background:#1E4C50;
  color:#ffffff;
  font-weight:700;
  grid-row:1 / span 2;
}

.landing-flow-copy strong{
  display:block;
  margin-bottom:5px;
  color:#17383b;
  font-size:18px;
}

.landing-flow-copy p{
  margin:0;
}

.landing-flow-scan{
  position:absolute;
  z-index:3;
  left:9%;
  right:9%;
  top:18%;
  height:2px;
  background:#f0c24f;
  box-shadow:0 0 14px rgba(240,194,79,0.55);
  animation:landingFlowScan 3.8s ease-in-out infinite;
}

.landing-flow-ring{
  position:absolute;
  z-index:3;
  left:50%;
  top:50%;
  width:74px;
  height:34px;
  border:2px solid rgba(240,194,79,0.72);
  border-radius:50%;
  transform:translate(-50%,-50%) rotate(-8deg);
  animation:landingFlowRing 3.6s ease-in-out infinite;
}

.landing-flow-highlight{
  position:absolute;
  z-index:3;
  left:11%;
  right:11%;
  bottom:22%;
  height:20px;
  border:1px solid rgba(240,194,79,0.86);
  background:rgba(240,194,79,0.18);
  animation:landingFlowHighlight 3.4s ease-in-out infinite;
}

.landing-flow-export-sheet{
  position:absolute;
  z-index:3;
  width:58px;
  height:74px;
  right:20px;
  bottom:18px;
  border:1px solid rgba(255,255,255,0.86);
  border-radius:5px;
  background:rgba(255,255,255,0.86);
  box-shadow:0 10px 20px rgba(12,38,41,0.22);
}

.landing-flow-export-sheet::before,
.landing-flow-export-sheet::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  height:4px;
  border-radius:999px;
  background:#1E4C50;
}

.landing-flow-export-sheet::before{
  top:18px;
}

.landing-flow-export-sheet::after{
  top:31px;
  right:18px;
  opacity:0.45;
}

.landing-flow-export-sheet-a{
  transform:rotate(-7deg) translateX(-28px);
  animation:landingFlowSheetA 4.2s ease-in-out infinite;
}

.landing-flow-export-sheet-b{
  transform:rotate(5deg);
  animation:landingFlowSheetB 4.2s ease-in-out infinite;
}

@keyframes landingFlowScan{
  0%,100%{top:18%;opacity:0.35;}
  45%,55%{top:72%;opacity:1;}
}

@keyframes landingFlowDrift{
  from{transform:scale(1.08) translateX(-3px);}
  to{transform:scale(1.12) translateX(5px);}
}

@keyframes landingFlowRing{
  0%,100%{opacity:0.25;transform:translate(-50%,-50%) rotate(-8deg) scale(0.82);}
  50%{opacity:1;transform:translate(-50%,-50%) rotate(-8deg) scale(1.08);}
}

@keyframes landingFlowHighlight{
  0%,100%{opacity:0.28;transform:translateY(0);}
  50%{opacity:1;transform:translateY(-18px);}
}

@keyframes landingFlowSheetA{
  0%,100%{transform:rotate(-7deg) translateX(-28px) translateY(3px);}
  50%{transform:rotate(-4deg) translateX(-36px) translateY(-5px);}
}

@keyframes landingFlowSheetB{
  0%,100%{transform:rotate(5deg) translateY(0);}
  50%{transform:rotate(2deg) translateY(-8px);}
}

.landing-audience{
  display:grid;
  grid-template-columns:minmax(0,0.8fr) minmax(0,1.2fr);
  gap:36px;
  align-items:start;
}

.landing-audience-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}

.landing-faq{
  display:grid;
  gap:12px;
}

.landing-faq details{
  background:#ffffff;
  border:1px solid #d9e4e2;
  border-radius:8px;
  padding:18px 20px;
}

.landing-faq summary{
  cursor:pointer;
  color:#17383b;
  font-weight:700;
}

.landing-faq p{
  margin:12px 0 0;
}

.landing-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:24px clamp(18px,4vw,64px);
  background:#17383b;
  color:#ffffff;
}

.landing-footer-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:18px;
}

.landing-legal-links,
.auth-legal-links,
.legal-page-links,
.legal-page-footer-links{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:12px;
}

.landing-footer a{
  color:#f0c24f;
  font-weight:700;
  text-decoration:none;
}

.auth-legal-links{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(20,58,62,0.14);
}

.auth-legal-links a{
  color:#1E4C50;
  font-size:13px;
  font-weight:600;
  text-decoration:none;
}

.legal-page-body{
  min-height:100vh;
  margin:0;
  background:#f3f7f6;
  color:#20393b;
  font-family:'Roboto',Arial,sans-serif;
}

.legal-page-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:18px clamp(18px,4vw,64px);
  background:#17383b;
  color:#fff;
}

.legal-page-brand,
.legal-page-links a,
.legal-page-footer-links a{
  color:#f0c24f;
  font-weight:700;
  text-decoration:none;
}

.legal-page-main{
  width:min(1080px,calc(100% - 32px));
  margin:0 auto;
  padding:42px 0 56px;
}

.legal-page-hero{
  margin-bottom:30px;
}

.legal-page-hero h1{
  margin:8px 0 12px;
  color:#17383b;
  font-size:clamp(32px,5vw,54px);
  line-height:1.05;
}

.legal-page-hero p{
  max-width:760px;
  color:#4c6669;
  font-size:18px;
  line-height:1.65;
}

.legal-page-content{
  display:grid;
  gap:18px;
}

.legal-page-content h2{
  margin:28px 0 0;
  color:#17383b;
  font-size:24px;
}

.legal-page-content p,
.legal-page-content li,
.legal-data-list dd,
.legal-data-list dt{
  line-height:1.7;
}

.legal-page-content p,
.legal-page-content ul{
  margin:0;
}

.legal-page-content ul{
  padding-left:22px;
}

.legal-note{
  padding:12px 14px;
  border-left:4px solid #d69f25;
  background:#fff8e5;
  color:#604719;
}

.legal-data-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  margin:4px 0 8px;
  border:1px solid #d8e3e2;
  background:#fff;
}

.legal-data-list div{
  display:grid;
  grid-template-columns:minmax(130px,32%) 1fr;
  gap:12px;
  padding:12px 14px;
  border-bottom:1px solid #e2ebea;
}

.legal-data-list div:nth-child(odd){
  border-right:1px solid #e2ebea;
}

.legal-data-list div:nth-last-child(-n+2){
  border-bottom:none;
}

.legal-data-list dt{
  color:#17383b;
  font-weight:700;
}

.legal-data-list dd{
  margin:0;
  color:#405a5d;
  overflow-wrap:anywhere;
}

.legal-table-shell{
  overflow:auto;
  border:1px solid #d8e3e2;
  background:#fff;
}

.legal-cookie-table{
  width:100%;
  min-width:720px;
  border-collapse:collapse;
}

.legal-cookie-table th,
.legal-cookie-table td{
  padding:12px 14px;
  border-bottom:1px solid #e2ebea;
  text-align:left;
  vertical-align:top;
}

.legal-cookie-table th{
  background:#17383b;
  color:#fff;
}

.legal-page-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:22px clamp(18px,4vw,64px);
  background:#17383b;
  color:#fff;
}

@media (max-width:920px){
  .app-footer{
    align-items:flex-start;
    flex-direction:column;
  }

  .app-legal-links{
    justify-content:flex-start;
  }

  .landing-nav{
    align-items:center;
    justify-content:flex-end;
  }

  .landing-nav-links{
    width:100%;
    justify-content:flex-end;
    flex-wrap:wrap;
    gap:12px;
  }

  .landing-hero{
    min-height:74vh;
  }

  .landing-hero::before{
    background:
      linear-gradient(180deg,rgba(15,42,45,0.97) 0%,rgba(15,42,45,0.86) 50%,rgba(15,42,45,0.55) 100%),
      linear-gradient(90deg,rgba(15,42,45,0.70) 0%,rgba(15,42,45,0.20) 100%);
  }

  .landing-hero-scene{
    opacity:0.74;
  }

  .landing-hero h1{
    font-size:40px;
  }

  .landing-hero-copy{
    font-size:18px;
  }

  .landing-footer,
  .legal-page-header,
  .legal-page-footer{
    align-items:flex-start;
    flex-direction:column;
  }

  .landing-footer-actions,
  .legal-page-links,
  .legal-page-footer-links{
    justify-content:flex-start;
  }

  .legal-data-list{
    grid-template-columns:1fr;
  }

  .legal-data-list div,
  .legal-data-list div:nth-child(odd){
    border-right:none;
  }

  .legal-data-list div:nth-last-child(-n+2){
    border-bottom:1px solid #e2ebea;
  }

  .legal-data-list div:last-child{
    border-bottom:none;
  }

  .landing-strip,
  .landing-feature-grid,
  .landing-preview-layout,
  .landing-flow-layout,
  .landing-audience,
  .landing-audience-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:560px){
  .landing-nav-links a:not(.landing-nav-login){
    display:none;
  }

  .landing-hero-inner{
    padding-top:54px;
    padding-bottom:54px;
  }

  .landing-hero h1{
    font-size:34px;
  }

  .landing-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .landing-section{
    padding-top:52px;
    padding-bottom:52px;
  }

  .landing-section h2{
    font-size:28px;
  }

  .landing-flow li{
    grid-template-columns:1fr;
    padding:16px;
  }

  .landing-flow-media{
    min-height:150px;
  }

  .landing-flow-copy{
    grid-template-columns:40px minmax(0,1fr);
    padding:0;
  }
}

@media (prefers-reduced-motion:reduce){
  .landing-flow-media-model img,
  .landing-flow-scan,
  .landing-flow-ring,
  .landing-flow-highlight,
  .landing-flow-export-sheet-a,
  .landing-flow-export-sheet-b{
    animation:none;
  }
}

/* --- 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-tabs{
  display:flex;
  gap:4px;
  border-bottom:2px solid var(--app-border);
  margin:0 0 18px;
}

.usage-tab{
  display:inline-flex;
  align-items:center;
  padding:9px 16px 11px;
  background:transparent;
  color:var(--app-text-muted);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  border-bottom:2px solid transparent;
  margin-bottom:-2px;
  border-radius:6px 6px 0 0;
  line-height:1;
}

.usage-tab:hover{
  background:var(--app-surface-soft);
  color:var(--app-primary);
}

.usage-tab.usage-tab-active{
  color:var(--app-primary);
  border-bottom-color:var(--app-primary);
  background:var(--app-surface-soft);
}

.usage-tab-panel[hidden]{display:none;}

.usage-indicators{margin-top:4px;}

.usage-indicators-note{
  margin:0 0 14px;
  color:var(--app-text-muted);
  font-size:13px;
}

.usage-charts-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  gap:16px;
}

.usage-chart-card{
  background:var(--app-surface-soft);
  border:1px solid var(--app-border);
  border-radius:12px;
  padding:14px 16px 8px;
}

.usage-chart-header{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin-bottom:6px;
}

.usage-chart-title{
  margin:0;
  font-size:14px;
  font-weight:600;
  color:var(--app-text);
}

.usage-chart-total{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  line-height:1.1;
}

.usage-chart-total-value{
  font-weight:700;
  font-size:18px;
  color:var(--app-primary);
}

.usage-chart-total-label{
  font-size:11px;
  color:var(--app-text-muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}

.usage-chart-svg{
  display:block;
  width:100%;
  height:180px;
}

.usage-chart-svg rect{transition:opacity .15s ease;}
.usage-chart-svg rect:hover{opacity:1;}

.usage-chart-empty{
  padding:30px 0;
  text-align:center;
  color:var(--app-text-muted);
  font-size:13px;
}

.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;
  }
}
