/**
 * Calculadora de Levadura - Encervezate.com
 * CSS con aislamiento total para WordPress
 * v1.8 - Solución Final
 */

/* ============================================
   RESET Y AISLAMIENTO TOTAL
   ============================================ */

.ecl-calculator-wrapper {
    all: initial !important;
    display: block !important;
    width: 100% !important;
	max-width:100% !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    color: #424242 !important;
    
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

.ecl-calculator-wrapper *,
.ecl-calculator-wrapper *::before,
.ecl-calculator-wrapper *::after {
    box-sizing: border-box !important;
    font-family: inherit !important;
}

.ecl-calculator-wrapper button,
.ecl-calculator-wrapper input,
.ecl-calculator-wrapper select,
.ecl-calculator-wrapper textarea {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: inherit !important;
    line-height: inherit !important;
}

.ecl-calculator-wrapper #manualCellsGroup[style*="display: none"],
.ecl-calculator-wrapper #manualCellsGroup[style*="display:none"] {
    display: none !important;
}
/* ============================================
   VARIABLES CSS
   ============================================ */

.ecl-calculator-wrapper {
    --ecl-primary: #1a1a1a;
    --ecl-primary-light: #333333;
    --ecl-secondary: #d4a03d;
    --ecl-secondary-light: #e8c068;
    --ecl-secondary-dark: #b8862f;
    --ecl-white: #ffffff;
    --ecl-gray-50: #fafafa;
    --ecl-gray-100: #f5f5f5;
    --ecl-gray-200: #eeeeee;
    --ecl-gray-300: #e0e0e0;
    --ecl-gray-400: #bdbdbd;
    --ecl-gray-500: #9e9e9e;
    --ecl-gray-600: #757575;
    --ecl-gray-700: #616161;
    --ecl-gray-800: #424242;
    --ecl-gray-900: #212121;
    --ecl-success: #4caf50;
    --ecl-success-light: #e8f5e9;
    --ecl-warning: #ff9800;
    --ecl-warning-light: #fff3e0;
    --ecl-danger: #f44336;
    --ecl-danger-light: #ffebee;
    --ecl-info: #000000;
    --ecl-info-light: #e3f2fd;
    --ecl-radius-sm: 4px;
    --ecl-radius-md: 8px;
    --ecl-radius-lg: 12px;
    --ecl-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
    --ecl-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.06);
    --ecl-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.08);
}
/* ============================================
   FIX PARA FONT AWESOME
   ============================================ */

.ecl-calculator-wrapper i[class*="fa-"],
.ecl-calculator-wrapper .fas,
.ecl-calculator-wrapper .far,
.ecl-calculator-wrapper .fab,
.ecl-calculator-wrapper .fa {
    font-family: "Font Awesome 6 Free", "Font Awesome 6 Brands", FontAwesome !important;
    font-style: normal !important;
    font-variant: normal !important;
    text-rendering: auto !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    display: inline-block !important;
}

.ecl-calculator-wrapper .fas,
.ecl-calculator-wrapper .fa-solid {
    font-weight: 900 !important;
}

.ecl-calculator-wrapper .far,
.ecl-calculator-wrapper .fa-regular {
    font-weight: 400 !important;
}

.ecl-calculator-wrapper .fab,
.ecl-calculator-wrapper .fa-brands {
    font-weight: 400 !important;
}

/* ============================================
   LAYOUT PRINCIPAL
   ============================================ */

.ecl-calculator-wrapper .container {
    max-width: 940px !important;
    margin: 0 auto !important;
    padding: 0 1.5rem !important;
}

.ecl-calculator-wrapper .main-content {
    padding-bottom: 3rem !important;
}

/* ============================================
   PRESETS RÁPIDOS
   ============================================ */

.ecl-calculator-wrapper .presets-section {
    margin-bottom: 2rem !important;
}

.ecl-calculator-wrapper .presets-wrapper {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
    padding: 1rem 1.5rem !important;
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-lg) !important;
}

.ecl-calculator-wrapper .presets-label {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
}

.ecl-calculator-wrapper .presets-label i {
    color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .presets-buttons {
    display: flex !important;
    gap: 0.5rem !important;
    flex-wrap: wrap !important;
    flex: 1 !important;
}

.ecl-calculator-wrapper .preset-btn {
    padding: 0.5rem 1rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-700) !important;
    background: var(--ecl-gray-100) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .preset-btn:hover {
    background: var(--ecl-gray-200) !important;
    border-color: var(--ecl-gray-300) !important;
}

.ecl-calculator-wrapper .advanced-toggle {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    background: transparent !important;
    border: 1px solid var(--ecl-gray-300) !important;
    border-radius: var(--ecl-radius-md) !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
    margin-left: auto !important;
}

.ecl-calculator-wrapper .advanced-toggle:hover {
    border-color: var(--ecl-secondary) !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .advanced-toggle.active {
    background: var(--ecl-secondary) !important;
    border-color: var(--ecl-secondary) !important;
    color: var(--ecl-white) !important;
}

/* ============================================
   SECCIONES DE LA CALCULADORA
   ============================================ */

.ecl-calculator-wrapper .calculator-section {
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-lg) !important;
    margin-bottom: 1.5rem !important;
    overflow: hidden !important;
}

.ecl-calculator-wrapper .calculator-section.hidden {
    display: none !important;
}

.ecl-calculator-wrapper .section-header {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1.5rem !important;
    border-bottom: 1px solid var(--ecl-gray-100) !important;
    margin: 0 !important;
}

.ecl-calculator-wrapper .section-icon {
    font-size: 1.25rem !important;
    color: var(--ecl-secondary) !important;
    flex-shrink: 0 !important;
}

.ecl-calculator-wrapper .section-header h2 {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--ecl-primary) !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

.ecl-calculator-wrapper .section-content {
    padding: 1.5rem !important;
}

/* ============================================
   GRID DE INPUTS
   ============================================ */

.ecl-calculator-wrapper .input-grid {
    display: grid !important;
    gap: 1.5rem !important;
}

.ecl-calculator-wrapper .input-grid.two-columns {
    grid-template-columns: repeat(2, 1fr) !important;
    padding-top: 20px !important;
}

.ecl-calculator-wrapper .input-grid.three-columns {
    grid-template-columns: repeat(3, 1fr) !important;
}

.ecl-calculator-wrapper .input-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
}

.ecl-calculator-wrapper .input-group.full-width {
    grid-column: 1 / -1 !important;
}

.ecl-calculator-wrapper .input-group label {
    /*display: flex !important;*/
    align-items: center !important;
    gap: 0.5rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-700) !important;
    margin: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .input-group label i {
    color: var(--ecl-gray-400) !important;
    font-size: 0.875rem !important;
}

.ecl-calculator-wrapper .input-hint {
    display: block !important;
    font-size: 0.75rem !important;
    color: #9e9e9e !important;
    margin-top: 4px !important;
    font-style: italic !important;
}

/* ============================================
   INPUTS Y CONTROLES
   ============================================ */

.ecl-calculator-wrapper input[type="number"],
.ecl-calculator-wrapper input[type="text"],
.ecl-calculator-wrapper input[type="date"],
.ecl-calculator-wrapper select {
    width: 100% !important;
    padding: 0.5rem 1rem !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 0.9375rem !important;
    color: var(--ecl-gray-800) !important;
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-300) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

.ecl-calculator-wrapper input[type="number"]:focus,
.ecl-calculator-wrapper input[type="text"]:focus,
.ecl-calculator-wrapper input[type="date"]:focus,
.ecl-calculator-wrapper select:focus {
    outline: none !important;
    border-color: var(--ecl-secondary) !important;
    box-shadow: 0 0 0 3px rgba(212, 160, 61, 0.1) !important;
}

.ecl-calculator-wrapper input[type="number"]:hover,
.ecl-calculator-wrapper input[type="text"]:hover,
.ecl-calculator-wrapper input[type="date"]:hover,
.ecl-calculator-wrapper select:hover {
    border-color: var(--ecl-gray-400) !important;
}

.ecl-calculator-wrapper select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23757575' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 1rem center !important;
    padding-right: 2.5rem !important;
}

/* Input con unidad */
.ecl-calculator-wrapper .input-with-unit {
    display: flex !important;
    align-items: stretch !important;
    max-width: 420px !important;
}

.ecl-calculator-wrapper .input-with-unit input {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-right: none !important;
    flex: 1 !important;
}

.ecl-calculator-wrapper .input-with-unit .unit {
    display: flex !important;
    align-items: center !important;
    padding: 0 1rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-500) !important;
    background: var(--ecl-gray-100) !important;
    border: 1px solid var(--ecl-gray-300) !important;
    border-left: none !important;
    border-radius: 0 var(--ecl-radius-md) var(--ecl-radius-md) 0 !important;
    white-space: nowrap !important;
}

/* ============================================
   SLIDER
   ============================================ */

.ecl-calculator-wrapper .slider-below {
    width: 100% !important;
    margin-top: 0.5rem !important;
    height: 4px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    background: var(--ecl-gray-200) !important;
    border-radius: 2px !important;
    cursor: pointer !important;
    border: none !important;
    outline: none !important;
}

.ecl-calculator-wrapper .slider-below::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    width: 14px !important;
    height: 14px !important;
    background: var(--ecl-secondary) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    border: none !important;
}

.ecl-calculator-wrapper .slider-below::-moz-range-thumb {
    width: 14px !important;
    height: 14px !important;
    background: var(--ecl-secondary) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    border: none !important;
}

/* ============================================
   TOGGLE SWITCH (SG/Plato)
   ============================================ */

.ecl-calculator-wrapper .toggle-switch {
    display: inline-flex !important;
    background: var(--ecl-gray-100) !important;
    border-radius: var(--ecl-radius-md) !important;
    padding: 2px !important;
    align-self: flex-start !important;
    margin-bottom: 0.5rem !important;
}

.ecl-calculator-wrapper .toggle-switch input[type="radio"] {
    display: none !important;
}

.ecl-calculator-wrapper .toggle-switch label {
    padding: 0.25rem 1rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    cursor: pointer !important;
    border-radius: var(--ecl-radius-sm) !important;
    transition: all 150ms ease !important;
    margin: 0 !important;
}

.ecl-calculator-wrapper .toggle-switch input[type="radio"]:checked + label {
    background: var(--ecl-white) !important;
    color: var(--ecl-primary) !important;
    box-shadow: var(--ecl-shadow-sm) !important;
}

/* ============================================
   OPCIONES DE FERMENTACIÓN
   ============================================ */

.ecl-calculator-wrapper .fermentation-options {
    display: flex !important;
    gap: 0.5rem !important;
    margin-top: 0.5rem !important;
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
}

.ecl-calculator-wrapper .fermentation-option {
    cursor: pointer !important;
}

.ecl-calculator-wrapper .fermentation-option input {
    display: none !important;
}

.ecl-calculator-wrapper .fermentation-option .option-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    padding: 0.5rem 1rem !important;
    min-width: 80px !important;
    background: var(--ecl-gray-50) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
    text-align: center !important;
}

.ecl-calculator-wrapper .fermentation-option .option-content i {
    font-size: 1rem !important;
    color: var(--ecl-gray-400) !important;
}

.ecl-calculator-wrapper .fermentation-option .option-content strong {
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .fermentation-option .option-content small {
    font-size: 0.625rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .fermentation-option input:checked + .option-content {
    background: var(--ecl-white) !important;
    border-color: var(--ecl-secondary) !important;
    box-shadow: 0 0 0 3px rgba(212, 160, 61, 0.1) !important;
}

.ecl-calculator-wrapper .fermentation-option input:checked + .option-content i {
    color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .fermentation-option:hover .option-content {
    border-color: var(--ecl-gray-300) !important;
}

/* ============================================
   PANEL DE RESULTADOS
   ============================================ */

.ecl-calculator-wrapper .results-panel {
    display: flex !important;
    align-items: center !important;
    gap: 2rem !important;
    padding: 1.5rem !important;
    margin-top: 1.5rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    flex-wrap: wrap !important;
}

.ecl-calculator-wrapper .result-item {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
}

.ecl-calculator-wrapper .result-label {
    font-size: 0.6875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.ecl-calculator-wrapper .result-value {
    font-size: 1.125rem !important;
    font-weight: 600 !important;
    color: var(--ecl-primary) !important;
}

.ecl-calculator-wrapper .result-value.large {
    font-size: 1.5rem !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .result-item.highlight {
    padding-left: 1.5rem !important;
    border-left: 2px solid var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .result-item.hint {
    display: flex !important;
    align-items: center !important;
    flex: 1 !important;
    justify-content: center !important;
}

.ecl-calculator-wrapper .results-hint {
    font-size: 0.80rem !important;
    color: var(--ecl-gray-500) !important;
    font-style: italic !important;
}

/* ============================================
   TABS DE LEVADURA
   ============================================ */

.ecl-calculator-wrapper .yeast-tabs {
    display: flex !important;
    gap: 0.25rem !important;
    padding: 0.5rem !important;
    background: var(--ecl-gray-100) !important;
    border-radius: var(--ecl-radius-md) !important;
    margin-bottom: 1.5rem !important;
}

.ecl-calculator-wrapper .yeast-tab {
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--ecl-radius-sm) !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .yeast-tab i {
    font-size: 0.875rem !important;
}

.ecl-calculator-wrapper .yeast-tab span {
    display: none !important;
}

.ecl-calculator-wrapper .yeast-tab:hover {
    color: var(--ecl-gray-800) !important;
    background: var(--ecl-gray-200) !important;
}

.ecl-calculator-wrapper .yeast-tab.active {
    color: var(--ecl-primary) !important;
    background: var(--ecl-white) !important;
    box-shadow: var(--ecl-shadow-sm) !important;
}

.ecl-calculator-wrapper .yeast-tab-content {
    display: none !important;
}

.ecl-calculator-wrapper .yeast-tab-content.active {
    display: block !important;
}

/* ============================================
   STATE TOGGLE (Sellada/Abierta)
   ============================================ */

.ecl-calculator-wrapper .state-toggle {
    display: flex !important;
    gap: 0.5rem !important;
}

.ecl-calculator-wrapper .state-option {
    flex: 1 !important;
    cursor: pointer !important;
}

.ecl-calculator-wrapper .state-option input {
    display: none !important;
}

.ecl-calculator-wrapper .state-option span {
    display: block !important;
    padding: 0.5rem 1rem !important;
    text-align: center !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    background: var(--ecl-gray-50) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .state-option input:checked + span {
    background: var(--ecl-white) !important;
    border-color: var(--ecl-secondary) !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .state-option:hover span {
    border-color: var(--ecl-gray-300) !important;
}

/* ============================================
   OPCIONES LEVADURA SELLADA/ABIERTA
   ============================================ */

.ecl-calculator-wrapper .sealed-options,
.ecl-calculator-wrapper .opened-options {
    margin-top: 1.5rem !important;
    padding: 1.5rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    border: 1px dashed var(--ecl-gray-300) !important;
}

/* ============================================
   TOGGLE DE TEMPERATURA
   ============================================ */

.ecl-calculator-wrapper .temp-toggle {
    display: flex !important;
    gap: 2px !important;
    background: var(--ecl-gray-100) !important;
    padding: 3px !important;
    border-radius: var(--ecl-radius-md) !important;
}

.ecl-calculator-wrapper .temp-option {
    flex: 1 !important;
    cursor: pointer !important;
    text-align: center !important;
    padding: 0.5rem !important;
    border-radius: var(--ecl-radius-sm) !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .temp-option input {
    display: none !important;
}

.ecl-calculator-wrapper .temp-option .temp-icon {
    display: block !important;
    font-size: 1.25rem !important;
    line-height: 1 !important;
}

.ecl-calculator-wrapper .temp-option small {
    display: block !important;
    font-size: 0.625rem !important;
    color: var(--ecl-gray-500) !important;
    margin-top: 2px !important;
}

.ecl-calculator-wrapper .temp-option:has(input:checked) {
    background: var(--ecl-white) !important;
    box-shadow: var(--ecl-shadow-sm) !important;
}

.ecl-calculator-wrapper .temp-option:has(input:checked) small {
    color: var(--ecl-gray-700) !important;
}

/* ============================================
   EXTRACT TOGGLE (DME/LME)
   ============================================ */

.ecl-calculator-wrapper .extract-toggle {
    display: flex !important;
    gap: 0.5rem !important;
}

.ecl-calculator-wrapper .extract-option {
    flex: 1 !important;
    cursor: pointer !important;
}

.ecl-calculator-wrapper .extract-option input {
    display: none !important;
}

.ecl-calculator-wrapper .extract-option span {
    display: block !important;
    padding: 0.5rem 1rem !important;
    text-align: center !important;
    font-size: 0.8rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    background: var(--ecl-gray-50) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .extract-option input:checked + span {
    background: var(--ecl-white) !important;
    border-color: var(--ecl-secondary) !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .extract-option:hover span {
    border-color: var(--ecl-gray-300) !important;
}

/* ============================================
   BARRA DE VIABILIDAD
   ============================================ */

.ecl-calculator-wrapper .viability-display {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem !important;
    margin-top: 1.5rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    flex-wrap: wrap !important;
}

.ecl-calculator-wrapper .viability-bar {
    flex: 1 !important;
    min-width: 100px !important;
    height: 6px !important;
    background: var(--ecl-gray-200) !important;
    border-radius: 3px !important;
    overflow: hidden !important;
}

.ecl-calculator-wrapper .viability-fill {
    height: 100% !important;
    background: var(--ecl-success) !important;
    border-radius: 3px !important;
    transition: width 250ms ease, background-color 250ms ease !important;
}

.ecl-calculator-wrapper .viability-text {
    font-size: 0.875rem !important;
    color: var(--ecl-gray-600) !important;
    white-space: nowrap !important;
}

.ecl-calculator-wrapper .viability-text strong {
    color: var(--ecl-primary) !important;
}

.ecl-calculator-wrapper .viability-display small {
    font-size: 0.75rem !important;
    color: var(--ecl-gray-500) !important;
}

/* ============================================
   INFO BOX
   ============================================ */

.ecl-calculator-wrapper .info-box {
    display: flex !important;
    gap: 1rem !important;
    padding: 1rem !important;
    margin-top: 1.5rem !important;
    background: var(--ecl-info-light) !important;
    border-radius: var(--ecl-radius-md) !important;
}

.ecl-calculator-wrapper .info-box i {
    color: var(--ecl-info) !important;
    font-size: 1rem !important;
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}

.ecl-calculator-wrapper .info-box p {
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-700) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .info-box.warning {
    background: var(--ecl-warning-light) !important;
}

.ecl-calculator-wrapper .info-box.warning i {
    color: var(--ecl-warning) !important;
}

/* ============================================
   RESULTADOS SECCIÓN 2 (LEVADURA)
   ============================================ */

.ecl-calculator-wrapper .yeast-results {
    justify-content: flex-start !important;
    gap: 2rem !important;
}

/* ============================================
   BARRA DE COBERTURA VISUAL
   ============================================ */

.ecl-calculator-wrapper .coverage-bar-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
    margin-top: 1.5rem !important;
    padding: 1rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
}

.ecl-calculator-wrapper .coverage-bar-container {
    flex: 1 !important;
}

.ecl-calculator-wrapper .coverage-bar-bg {
    height: 12px !important;
    background: var(--ecl-gray-200) !important;
    border-radius: 6px !important;
    overflow: hidden !important;
}

.ecl-calculator-wrapper .coverage-bar-fill {
    height: 100% !important;
    background: linear-gradient(90deg, var(--ecl-danger) 0%, var(--ecl-warning) 60%, var(--ecl-success) 100%) !important;
    border-radius: 6px !important;
    transition: width 250ms ease !important;
}

.ecl-calculator-wrapper .coverage-bar-labels {
    display: flex !important;
    justify-content: space-between !important;
    margin-top: 0.25rem !important;
    font-size: 0.6875rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .coverage-percent {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: var(--ecl-primary) !important;
    min-width: 70px !important;
    text-align: right !important;
}

/* ============================================
   INDICADOR DE COBERTURA
   ============================================ */

.ecl-calculator-wrapper .coverage-indicator {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1rem !important;
    padding: 1rem !important;
    border-radius: var(--ecl-radius-md) !important;
    margin-top: 1rem !important;
}

.ecl-calculator-wrapper .indicator-content {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
}

.ecl-calculator-wrapper .indicator-needed {
    display: flex !important;
    align-items: center !important;
    gap: 0.25rem !important;
    font-size: 0.875rem !important;
}

.ecl-calculator-wrapper .needed-label {
    opacity: 0.8 !important;
}

.ecl-calculator-wrapper .needed-value {
    font-weight: 700 !important;
    font-size: 1rem !important;
}

.ecl-calculator-wrapper .coverage-indicator.sufficient {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.ecl-calculator-wrapper .coverage-indicator.sufficient .indicator-needed {
    display: none !important;
}

.ecl-calculator-wrapper .coverage-indicator.marginal {
    background: var(--ecl-warning-light) !important;
    color: #e65100 !important;
}

.ecl-calculator-wrapper .coverage-indicator.insufficient {
    background: var(--ecl-danger-light) !important;
    color: var(--ecl-danger) !important;
}

/* ============================================
   INDICADOR DE VIABILIDAD FINAL
   ============================================ */

.ecl-calculator-wrapper .final-viability-indicator {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem 1.5rem !important;
    margin-bottom: 1.5rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    border: 1px solid var(--ecl-gray-200) !important;
}

.ecl-calculator-wrapper .viability-circle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

.ecl-calculator-wrapper .viability-circle.sufficient {
    background: var(--ecl-success) !important;
    color: var(--ecl-white) !important;
}

.ecl-calculator-wrapper .viability-circle.marginal {
    background: var(--ecl-warning) !important;
    color: var(--ecl-white) !important;
}

.ecl-calculator-wrapper .viability-circle.insufficient {
    background: var(--ecl-danger) !important;
    color: var(--ecl-white) !important;
}

.ecl-calculator-wrapper .viability-circle i {
    font-size: 0.875rem !important;
}

.ecl-calculator-wrapper .viability-info {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.ecl-calculator-wrapper .viability-status {
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .viability-percent {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--ecl-success) !important;
}

.ecl-calculator-wrapper .final-viability-indicator:has(.viability-circle.marginal) .viability-percent {
    color: var(--ecl-warning) !important;
}

.ecl-calculator-wrapper .final-viability-indicator:has(.viability-circle.insufficient) .viability-percent {
    color: var(--ecl-danger) !important;
}

/* ============================================
   RESULTADO DE MOSTO COMPACTO (Sección 3)
   ============================================ */

.ecl-calculator-wrapper .mosto-result-compact {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem 1.5rem !important;
    margin-top: 1.5rem !important;
    background: var(--ecl-gray-100) !important;
    border-radius: var(--ecl-radius-md) !important;
   }

.ecl-calculator-wrapper .mosto-result-compact .mosto-result-label {
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
}

.ecl-calculator-wrapper .mosto-result-compact .mosto-result-value {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .mosto-result-compact .mosto-result-note {
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-500) !important;
    margin-left: auto !important;
}

/* ============================================
   METHOD OPTIONS (Propagación)
   ============================================ */

.ecl-calculator-wrapper .method-options {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
}

.ecl-calculator-wrapper .method-option {
    cursor: pointer !important;
}

.ecl-calculator-wrapper .method-option input {
    display: none !important;
}

.ecl-calculator-wrapper .method-option > span {
    display: flex !important;
    flex-direction: column !important;
    padding: 0.5rem 1rem !important;
    background: var(--ecl-gray-50) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .method-option span strong {
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .method-option span small {
    font-size: 0.6875rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .method-option input:checked + span {
    background: var(--ecl-white) !important;
    border-color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .method-option:hover > span {
    border-color: var(--ecl-gray-300) !important;
}

/* ============================================
   TABLA DE PASOS STARTER
   ============================================ */

.ecl-calculator-wrapper .starter-steps-table {
    margin-top: 1.5rem !important;
}

.ecl-calculator-wrapper .starter-steps-table h4 {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: var(--ecl-gray-700) !important;
    margin-bottom: 1rem !important;
    margin-top: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .starter-steps-table h4 i {
    color: var(--ecl-gray-400) !important;
}

.ecl-calculator-wrapper .table-responsive {
    overflow-x: auto !important;
}

.ecl-calculator-wrapper #starterStepsTable,
.ecl-calculator-wrapper #manualStepsTable {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.8125rem !important;
}

.ecl-calculator-wrapper #starterStepsTable th,
.ecl-calculator-wrapper #starterStepsTable td,
.ecl-calculator-wrapper #manualStepsTable th,
.ecl-calculator-wrapper #manualStepsTable td {
    padding: 0.5rem 1rem !important;
    text-align: center !important;
    border-bottom: 1px solid var(--ecl-gray-200) !important;
    white-space: nowrap !important;
}

.ecl-calculator-wrapper #starterStepsTable th,
.ecl-calculator-wrapper #manualStepsTable th {
    font-weight: 600 !important;
    color: var(--ecl-gray-600) !important;
    background: var(--ecl-gray-50) !important;
    font-size: 0.6875rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.ecl-calculator-wrapper #starterStepsTable td,
.ecl-calculator-wrapper #manualStepsTable td {
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper #starterStepsTable .step-number,
.ecl-calculator-wrapper #manualStepsTable .step-number {
    font-weight: 600 !important;
    color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper #starterStepsTable tr.step-cold,
.ecl-calculator-wrapper #manualStepsTable tr.step-cold {
    background: var(--ecl-info-light) !important;
}

.ecl-calculator-wrapper #starterStepsTable tr.step-cold td,
.ecl-calculator-wrapper #manualStepsTable tr.step-cold td {
    color: var(--ecl-info) !important;
    font-style: italic !important;
}

.ecl-calculator-wrapper .coverage-good {
    color: var(--ecl-success) !important;
    font-weight: 600 !important;
}

.ecl-calculator-wrapper .coverage-ok {
    color: var(--ecl-warning) !important;
}

.ecl-calculator-wrapper .coverage-low {
    color: var(--ecl-danger) !important;
}

.ecl-calculator-wrapper .no-starter-row {
    text-align: center !important;
    padding: 2rem !important;
    color: var(--ecl-success) !important;
}

.ecl-calculator-wrapper .no-starter-row i {
    font-size: 1.5rem !important;
    display: block !important;
    margin-bottom: 0.5rem !important;
}

/* ============================================
   TABLA MANUAL - INPUTS
   ============================================ */

.ecl-calculator-wrapper #manualStepsTable .manual-input {
    width: 65px !important;
    padding: 6px 4px !important;
    border: 1px solid var(--ecl-gray-300) !important;
    border-radius: var(--ecl-radius-sm) !important;
    font-size: 0.875rem !important;
    text-align: center !important;
    background: white !important;
    font-family: inherit !important;
}

.ecl-calculator-wrapper #manualStepsTable .manual-input:focus {
    outline: none !important;
    border-color: var(--ecl-secondary) !important;
    box-shadow: 0 0 0 2px rgba(212, 160, 61, 0.2) !important;
}

.ecl-calculator-wrapper #manualStepsTable .manual-input-density {
    width: 70px !important;
}

.ecl-calculator-wrapper #manualStepsTable .remove-step-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    background: none !important;
    border: none !important;
    color: var(--ecl-gray-400) !important;
    cursor: pointer !important;
    border-radius: var(--ecl-radius-sm) !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper #manualStepsTable .remove-step-btn:hover {
    color: var(--ecl-danger) !important;
    background: var(--ecl-danger-light) !important;
}

.ecl-calculator-wrapper .add-step-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-top: 1rem !important;
    padding: 8px 14px !important;
    background: white !important;
    color: var(--ecl-secondary-dark) !important;
    border: 1px dashed var(--ecl-secondary) !important;
    border-radius: var(--ecl-radius-md) !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .add-step-btn:hover {
    background: rgba(212, 160, 61, 0.1) !important;
    border-style: solid !important;
}

.ecl-calculator-wrapper .no-steps-row {
    text-align: center !important;
    padding: 2rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .no-steps-row i {
    margin-right: 8px !important;
    color: var(--ecl-gray-400) !important;
}

/* ============================================
   GUÍA DE PROCEDIMIENTO
   ============================================ */

.ecl-calculator-wrapper .procedure-guide {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.ecl-calculator-wrapper .procedure-step {
    display: flex !important;
    gap: 1rem !important;
    padding: 1rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    border-left: 3px solid var(--ecl-gray-300) !important;
}

.ecl-calculator-wrapper .procedure-step.highlight-step {
    background: rgba(212, 160, 61, 0.08) !important;
    border-left-color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .procedure-step.cold-step {
    background: var(--ecl-info-light) !important;
    border-left-color: var(--ecl-info) !important;
}

.ecl-calculator-wrapper .procedure-step-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    background: var(--ecl-white) !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

.ecl-calculator-wrapper .procedure-step-icon i {
    font-size: 0.875rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .highlight-step .procedure-step-icon i {
    color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .cold-step .procedure-step-icon i {
    color: var(--ecl-info) !important;
}

.ecl-calculator-wrapper .procedure-step-number {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    height: 24px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    color: var(--ecl-gray-600) !important;
    background: var(--ecl-white) !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

.ecl-calculator-wrapper .procedure-step-content h4 {
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: var(--ecl-primary) !important;
    margin-bottom: 0.25rem !important;
    margin-top: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .procedure-step-content p {
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-600) !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .procedure-step-content strong {
    color: var(--ecl-gray-800) !important;
}

/* Mensaje cuando NO necesita starter */
.ecl-calculator-wrapper .no-starter-message {
    text-align: center !important;
    padding: 2rem !important;
    background: transparent !important;
    border: none !important;
}

.ecl-calculator-wrapper .no-starter-message .no-starter-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
    background: none !important;
}

.ecl-calculator-wrapper .no-starter-message .no-starter-content > i,
.ecl-calculator-wrapper .no-starter-message .no-starter-content > .fa-check-circle {
    font-size: 3rem !important;
    color: #4caf50 !important;
    width: 60px !important;
    height: 60px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 0.5rem !important;
}

.ecl-calculator-wrapper .no-starter-message .no-starter-text {
    text-align: center !important;
}

.ecl-calculator-wrapper .no-starter-message .no-starter-text strong {
    display: block !important;
    font-size: 1.125rem !important;
    color: #4caf50 !important;
    margin-bottom: 0.25rem !important;
}

.ecl-calculator-wrapper .no-starter-message .no-starter-text p {
    font-size: 0.875rem !important;
    color: #757575 !important;
    margin: 0 !important;
}


/* ============================================
   TOGGLE MODO DE CÁLCULO
   ============================================ */

.ecl-calculator-wrapper .calc-mode-wrapper {
    margin: 1.5rem 0 !important;
    padding: 1rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
}

.ecl-calculator-wrapper .calc-mode-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
}

.ecl-calculator-wrapper .calc-mode-header label {
    font-weight: 500 !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .calc-mode-toggle {
    display: flex !important;
    background: var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    padding: 3px !important;
}

.ecl-calculator-wrapper .calc-mode-btn {
    padding: 8px 16px !important;
    border: none !important;
    background: transparent !important;
    border-radius: var(--ecl-radius-sm) !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-600) !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
}

.ecl-calculator-wrapper .calc-mode-btn.active {
    background: white !important;
    color: var(--ecl-gray-900) !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
}

.ecl-calculator-wrapper .calc-mode-btn:hover:not(.active) {
    color: var(--ecl-gray-800) !important;
}

.ecl-calculator-wrapper .calc-mode-hint {
    display: block !important;
    margin-top: 0.5rem !important;
    color: var(--ecl-gray-500) !important;
    font-size: 0.75rem !important;
}

/* ============================================
   RESUMEN FINAL
   ============================================ */

.ecl-calculator-wrapper .summary-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)) !important;
    gap: 1rem !important;
    margin-bottom: 1.5rem !important;
}

.ecl-calculator-wrapper .summary-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.25rem !important;
    padding: 1rem !important;
    background: var(--ecl-gray-50) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    text-align: center !important;
}

.ecl-calculator-wrapper .summary-card i {
    font-size: 1rem !important;
    color: var(--ecl-gray-400) !important;
}

.ecl-calculator-wrapper .summary-label {
    font-size: 0.5625rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.ecl-calculator-wrapper .summary-value {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--ecl-primary) !important;
}

.ecl-calculator-wrapper .summary-card.highlight {
    background: var(--ecl-secondary) !important;
    border-color: var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .summary-card.highlight i,
.ecl-calculator-wrapper .summary-card.highlight .summary-label {
    color: rgba(255, 255, 255, 0.8) !important;
}

.ecl-calculator-wrapper .summary-card.highlight .summary-value {
    color: var(--ecl-white) !important;
}

.ecl-calculator-wrapper .summary-value.coverage-good {
    color: var(--ecl-success) !important;
}

.ecl-calculator-wrapper .summary-value.coverage-ok {
    color: var(--ecl-warning) !important;
}

.ecl-calculator-wrapper .summary-value.coverage-low {
    color: var(--ecl-danger) !important;
}

/* ============================================
   AVISOS INTELIGENTES
   ============================================ */

.ecl-calculator-wrapper .smart-warnings {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
    margin-bottom: 1.5rem !important;
}

.ecl-calculator-wrapper .smart-warnings:empty {
    display: none !important;
}

.ecl-calculator-wrapper .warning-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 1rem !important;
    padding: 1rem !important;
    border-radius: var(--ecl-radius-md) !important;
    font-size: 0.8125rem !important;
    line-height: 1.5 !important;
}

.ecl-calculator-wrapper .warning-item i {
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}

.ecl-calculator-wrapper .warning-danger {
    background: var(--ecl-danger-light) !important;
    color: var(--ecl-danger) !important;
}

.ecl-calculator-wrapper .warning-warning {
    background: var(--ecl-warning-light) !important;
    color: #e65100 !important;
}

.ecl-calculator-wrapper .warning-tip {
    background: var(--ecl-info-light) !important;
    color: var(--ecl-info) !important;
}

.ecl-calculator-wrapper .warning-success {
    background: var(--ecl-success-light) !important;
    color: var(--ecl-success) !important;
}

/* ============================================
   TOGGLE DE REHIDRATACIÓN
   ============================================ */

.ecl-calculator-wrapper .rehydration-compact {
    padding-top: 16px !important;
}

.ecl-calculator-wrapper .rehydration-toggle {
    display: flex !important;
    gap: 1rem !important;
    flex-wrap: wrap !important;
}

.ecl-calculator-wrapper .rehydration-option {
    flex: 1 !important;
    min-width: 200px !important;
    cursor: pointer !important;
}

.ecl-calculator-wrapper .rehydration-option input {
    display: none !important;
}

.ecl-calculator-wrapper .rehydration-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 8px !important;
    border: 2px solid var(--ecl-gray-300) !important;
    border-radius: var(--ecl-radius-md) !important;
    transition: all 150ms ease !important;
    text-align: center !important;
}

.ecl-calculator-wrapper .rehydration-content strong {
    font-size: 0.9rem !important;
}

.ecl-calculator-wrapper .rehydration-content small {
    font-size: 0.75rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .rehydration-option input:checked + .rehydration-content {
    border-color: var(--ecl-primary) !important;
    background: rgba(212, 160, 61, 0.1) !important;
}

.ecl-calculator-wrapper .rehydration-note {
    display: block !important;
    margin-top: 0.5rem !important;
    font-size: 0.75rem !important;
    color: var(--ecl-gray-500) !important;
}

.ecl-calculator-wrapper .rehydration-note i {
    margin-right: 0.25rem !important;
}

/* ============================================
   BOTONES DE ACCIÓN
   ============================================ */

.ecl-calculator-wrapper .action-buttons {
    display: flex !important;
    gap: 1rem !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
}

.ecl-calculator-wrapper .action-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem 1.5rem !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    border-radius: var(--ecl-radius-md) !important;
    cursor: pointer !important;
    transition: all 150ms ease !important;
    text-decoration: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.ecl-calculator-wrapper .action-btn.primary {
    color: var(--ecl-white) !important;
    background: var(--ecl-secondary) !important;
    border: 1px solid var(--ecl-secondary) !important;
}

.ecl-calculator-wrapper .action-btn.primary:hover {
    background: var(--ecl-secondary-dark) !important;
    border-color: var(--ecl-secondary-dark) !important;
}

.ecl-calculator-wrapper .action-btn.secondary {
    color: var(--ecl-gray-700) !important;
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-300) !important;
}

.ecl-calculator-wrapper .action-btn.secondary:hover {
    background: var(--ecl-gray-50) !important;
    border-color: var(--ecl-gray-400) !important;
}

/* ============================================
   SECCIÓN MÉTODOS ENTRE PASOS
   ============================================ */

.ecl-calculator-wrapper .method-explanation-card {
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    padding: 1.5rem !important;
    margin-bottom: 1rem !important;
}

.ecl-calculator-wrapper .method-explanation-header {
    margin-bottom: 0.5rem !important;
}

.ecl-calculator-wrapper .method-explanation-header strong {
    font-size: 0.9375rem !important;
    color: var(--ecl-gray-800) !important;
}

.ecl-calculator-wrapper .method-explanation-card p {
    font-size: 0.875rem !important;
    color: var(--ecl-gray-600) !important;
    line-height: 1.6 !important;
    margin-bottom: 0.5rem !important;
    margin-top: 0 !important;
    padding: 0 !important;
}

.ecl-calculator-wrapper .method-explanation-card p:last-child {
    margin-bottom: 0 !important;
}

.ecl-calculator-wrapper .method-note {
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .method-note.warning {
    color: #b45309 !important;
}

/* Subtabla de decantado */
.ecl-calculator-wrapper .decant-example {
    margin-top: 1rem !important;
    padding: 1rem !important;
    background: var(--ecl-gray-50) !important;
    border-radius: var(--ecl-radius-md) !important;
    border: 1px solid var(--ecl-gray-200) !important;
}

.ecl-calculator-wrapper .decant-example-title {
    font-size: 0.8125rem !important;
    font-weight: 600 !important;
    color: var(--ecl-gray-700) !important;
    margin-bottom: 0.5rem !important;
}

.ecl-calculator-wrapper .decant-subtable {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.8125rem !important;
}

.ecl-calculator-wrapper .decant-subtable th {
    padding: 0.5rem 1rem !important;
    background: var(--ecl-gray-700) !important;
    color: var(--ecl-white) !important;
    font-weight: 500 !important;
    border: 1px solid var(--ecl-gray-600) !important;
    font-size: 0.75rem !important;
}

.ecl-calculator-wrapper .decant-subtable td {
    padding: 0.5rem 1rem !important;
    border: 1px solid var(--ecl-gray-200) !important;
    text-align: center !important;
    background: var(--ecl-white) !important;
    color: var(--ecl-gray-700) !important;
}

.ecl-calculator-wrapper .decant-action-row td {
    background: var(--ecl-info-light) !important;
    border: 1px solid #b3d4fc !important;
    color: #1565c0 !important;
    font-weight: 500 !important;
    font-style: normal !important;
}

.ecl-calculator-wrapper .decant-action {
    font-size: 0.8125rem !important;
}

/* ============================================
   FAQ
   ============================================ */

.ecl-calculator-wrapper .faq-item {
    background: var(--ecl-white) !important;
    border: 1px solid var(--ecl-gray-200) !important;
    border-radius: var(--ecl-radius-md) !important;
    margin-bottom: 0.5rem !important;
    transition: box-shadow 150ms ease !important;
}

.ecl-calculator-wrapper .faq-item:hover {
    box-shadow: var(--ecl-shadow-md) !important;
}

.ecl-calculator-wrapper .faq-item summary {
    padding: 1rem 1.5rem !important;
    cursor: pointer !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--ecl-gray-800) !important;
    list-style: none !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.ecl-calculator-wrapper .faq-item summary::-webkit-details-marker {
    display: none !important;
}

.ecl-calculator-wrapper .faq-item summary::after {
    content: '+' !important;
    font-size: 1.25rem !important;
    color: var(--ecl-secondary) !important;
    font-weight: 400 !important;
}

.ecl-calculator-wrapper .faq-item[open] summary::after {
    content: '−' !important;
}

.ecl-calculator-wrapper .faq-item[open] summary {
    border-bottom: 1px solid var(--ecl-gray-100) !important;
    background: var(--ecl-gray-50) !important;
}

.ecl-calculator-wrapper .faq-item p {
    padding: 1rem 1.5rem !important;
    font-size: 0.8125rem !important;
    color: var(--ecl-gray-600) !important;
    line-height: 1.7 !important;
    margin: 0 !important;
}

/* ============================================
   FOOTER DEL PLUGIN
   ============================================ */

.ecl-calculator-wrapper + .ecl-footer,
.ecl-footer {
    padding: 2rem 0 !important;
    text-align: center !important;
    border-top: 1px solid #eeeeee !important;
    background: #ffffff !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

.ecl-footer p {
    font-size: 0.8125rem !important;
    color: #9e9e9e !important;
    margin-bottom: 0.25rem !important;
}

.ecl-footer a {
    color: #b8862f !important;
    text-decoration: none !important;
}

.ecl-footer a:hover {
    text-decoration: underline !important;
}

.ecl-footer .disclaimer-subtle {
    font-size: 0.75rem !important;
    color: #bdbdbd !important;
    text-align: center !important;
    margin-bottom: 0.5rem !important;
    line-height: 1.5 !important;
}

.ecl-footer .footer-credits {
    font-size: 0.8125rem !important;
    color: #9e9e9e !important;
    text-align: center !important;
}

/* ============================================
   TOAST NOTIFICATION
   ============================================ */

.ecl-calculator-wrapper .toast {
    position: fixed !important;
    bottom: 2rem !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(100px) !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 1rem 1.5rem !important;
    background: #212121 !important;
    color: #ffffff !important;
    border-radius: var(--ecl-radius-md) !important;
    font-size: 0.875rem !important;
    box-shadow: var(--ecl-shadow-lg) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 250ms ease !important;
    z-index: 10000 !important;
}

.ecl-calculator-wrapper .toast.show {
    transform: translateX(-50%) translateY(0) !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.ecl-calculator-wrapper .toast i {
    color: var(--ecl-success) !important;
}

/* ============================================
   UTILIDADES
   ============================================ */

.ecl-calculator-wrapper .hidden {
    display: none !important;
}

.ecl-calculator-wrapper .advanced-only {
    display: none !important;
    padding-top: 20px;
    padding-bottom: 10px;
}

.ecl-calculator-wrapper .advanced-only.visible {
    display: block !important;
}

/* ============================================
   NO STARTER MESSAGE
   ============================================ */

.ecl-calculator-wrapper .no-starter-message {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--success);
}

.ecl-calculator-wrapper .no-starter-content {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem !important;
    background: var(--ecl-success-light) !important;
    border-radius: var(--ecl-radius-md) !important;
}

.ecl-calculator-wrapper .no-starter-content i {
    font-size: 1.5rem !important;
    color: var(--ecl-success) !important;
}

.ecl-calculator-wrapper .no-starter-text strong {
    display: block !important;
    color: var(--ecl-success) !important;
    margin-bottom: 0.25rem !important;
}

.ecl-calculator-wrapper .no-starter-text p {
    font-size: 0.875rem !important;
    color: var(--ecl-gray-600) !important;
    margin: 0 !important;
}

/* ============================================
   MODAL LOGIN REQUERIDO
   ============================================ */
.ecl-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.5) !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 99999 !important;
}

.ecl-modal-overlay.show {
    display: flex !important;
}

.ecl-modal-content {
    background: #ffffff !important;
    border-radius: 12px !important;
    padding: 2rem !important;
    max-width: 400px !important;
    width: 90% !important;
    text-align: center !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2) !important;
    animation: modalSlideIn 0.3s ease !important;
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ecl-modal-icon {
    width: 60px !important;
    height: 60px !important;
    background: #fff3e0 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 1rem !important;
}

.ecl-modal-icon i {
    font-size: 1.5rem !important;
    color: #f57c00 !important;
}

.ecl-modal-content h3 {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    margin-bottom: 0.5rem !important;
}

.ecl-modal-content p {
    font-size: 0.9rem !important;
    color: #757575 !important;
    margin-bottom: 1.5rem !important;
    line-height: 1.5 !important;
}

.ecl-modal-buttons {
    display: flex !important;
    gap: 0.75rem !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
}

.ecl-modal-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.625rem 1.25rem !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    border: none !important;
}

.ecl-modal-btn.primary {
    background: #d4a03d !important;
    color: #ffffff !important;
}

.ecl-modal-btn.primary:hover {
    background: #b8862f !important;
}

.ecl-modal-btn.secondary {
    background: #f5f5f5 !important;
    color: #616161 !important;
}

.ecl-modal-btn.secondary:hover {
    background: #eeeeee !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (min-width: 640px) {
    .ecl-calculator-wrapper .yeast-tab span {
        display: inline !important;
    }
}

@media (max-width: 768px) {
    /* Contenedor más ancho - menos márgenes */
    .ecl-calculator-wrapper .container {
        padding: 0 12px !important;
        max-width: 100% !important;
    }
    
    .ecl-calculator-wrapper .main-content {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .ecl-calculator-wrapper .calculator-section {
        border-radius: 8px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    
    .ecl-calculator-wrapper .section-content {
        padding: 12px !important;
    }
    
   .ecl-calculator-wrapper .presets-wrapper {
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 10px 12px !important;
    position: relative !important;
}
    
    .ecl-calculator-wrapper .presets-wrapper .presets-buttons {
    justify-content: center !important;
}
	.ecl-calculator-wrapper .procedure-step.highlight-step {
		border-left-color:none !important;
	}

    .ecl-calculator-wrapper .presets-wrapper .advanced-toggle {
    position: absolute !important;
    top: 10px !important;
    right: 12px !important;
    z-index: 10 !important;
    margin: 0 !important;
}

   .ecl-calculator-wrapper .presets-wrapper .presets-label {
    text-align: center !important;
    margin-bottom: 8px !important;
    padding-right: 100px !important; /* Espacio para el botón */
}
    
    .ecl-calculator-wrapper .input-grid.two-columns,
    .ecl-calculator-wrapper .input-grid.three-columns {
        grid-template-columns: 1fr !important;
    }
    
    .ecl-calculator-wrapper .fermentation-options {
        flex-wrap: wrap !important;
    }
    
    .ecl-calculator-wrapper .fermentation-option {
        flex: 1 1 45% !important;
        min-width: 120px !important;
    }
    
    .ecl-calculator-wrapper .results-panel {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 1rem !important;
    }
    
    .ecl-calculator-wrapper .result-item.highlight {
        padding-left: 0 !important;
        padding-top: 1rem !important;
        border-left: none !important;
        border-top: 2px solid var(--ecl-secondary) !important;
        width: 100% !important;
    }
    
    .ecl-calculator-wrapper .yeast-results {
        flex-direction: column !important;
        align-items: stretch !important;
    }
    
    .ecl-calculator-wrapper .coverage-bar-wrapper {
        flex-direction: column !important;
        align-items: stretch !important;
    }
    
    .ecl-calculator-wrapper .coverage-percent {
        text-align: center !important;
        font-size: 2rem !important;
    }
    
    .ecl-calculator-wrapper .coverage-indicator {
        flex-direction: column !important;
        text-align: center !important;
    }
    
    .ecl-calculator-wrapper .mosto-result-compact {
        flex-direction: column !important;
        text-align: center !important;
    }
    
    .ecl-calculator-wrapper .mosto-result-compact .mosto-result-note {
        margin-left: 0 !important;
    }
    
    .ecl-calculator-wrapper .summary-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
    .ecl-calculator-wrapper .action-buttons {
        flex-direction: column !important;
    }
    
    .ecl-calculator-wrapper .action-btn {
        justify-content: center !important;
    }
    
    .ecl-calculator-wrapper .decant-subtable {
        font-size: 0.75rem !important;
    }
    
    .ecl-calculator-wrapper .decant-subtable th,
    .ecl-calculator-wrapper .decant-subtable td {
        padding: 0.25rem 0.5rem !important;
    }
    
    .ecl-calculator-wrapper .method-explanation-card {
        padding: 1rem !important;
    }
    
    .ecl-calculator-wrapper .faq-item summary {
        font-size: 0.8125rem !important;
        padding: 0.5rem 1rem !important;
    }
    
    .ecl-calculator-wrapper .faq-item p {
        padding: 0.5rem 1rem !important;
    }
    
    /* ============================================
       TABLA DE PASOS STARTER - CONVERTIR A CARDS
       ============================================ */
    
    /* Ocultar cabecera de tabla */
    .ecl-calculator-wrapper #starterStepsTable thead {
        display: none !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable,
    .ecl-calculator-wrapper #starterStepsTable tbody,
    .ecl-calculator-wrapper #starterStepsTable tr,
    .ecl-calculator-wrapper #starterStepsTable td {
        display: block !important;
        width: 100% !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr {
        background: #fafafa !important;
        border: 1px solid #e0e0e0 !important;
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        padding: 0 !important;
        overflow: hidden !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr.step-cold {
        background: #e3f2fd !important;
        border-color: #90caf9 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 10px 12px !important;
        border: none !important;
        border-bottom: 1px solid #eeeeee !important;
        text-align: right !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td:last-child {
        border-bottom: none !important;
    }
    
    /* Etiquetas antes de cada celda */
    .ecl-calculator-wrapper #starterStepsTable td::before {
        content: attr(data-label);
        font-weight: 600 !important;
        font-size: 0.75rem !important;
        color: #757575 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        text-align: left !important;
    }
    
    /* Número de paso destacado */
    .ecl-calculator-wrapper #starterStepsTable td:first-child {
        background: #d4a03d !important;
        color: white !important;
        padding: 12px !important;
        justify-content: center !important;
        font-weight: 700 !important;
        font-size: 0.875rem !important;
        border-bottom: none !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td:first-child::before {
        content: "PASO " !important;
        color: white !important;
        margin-right: 4px !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr.step-cold td:first-child {
        background: #2196f3 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr.step-cold td:first-child::before {
        content: "" !important;
    }
    
    /* Cobertura destacada */
    .ecl-calculator-wrapper #starterStepsTable td.coverage-good {
        color: #4caf50 !important;
        font-weight: 700 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td.coverage-ok {
        color: #ff9800 !important;
        font-weight: 700 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td.coverage-low {
        color: #f44336 !important;
        font-weight: 700 !important;
    }
    
    /* ============================================
   TABLA MANUAL - FIX RESPONSIVE ALINEACIÓN
   ============================================ */

@media (max-width: 768px) {
    /* Ocultar fila de cabecera */
    .ecl-calculator-wrapper #manualStepsTable thead {
        display: none !important;
    }

    .ecl-calculator-wrapper #manualStepsTable,
    .ecl-calculator-wrapper #manualStepsTable tbody {
        display: block !important;
        width: 100% !important;
    }

    .ecl-calculator-wrapper #manualStepsTable tbody tr td.step-number {
        background: #d4a03d !important;
        color: white !important;
        padding: 12px !important;
        justify-content: center !important;
        font-weight: 700 !important;
        font-size: 0.9rem !important;
        border-bottom: none !important;
    }
    
    /* Fila fría - fondo azul para el paso */
    .ecl-calculator-wrapper #manualStepsTable tbody tr.step-cold td.step-number {
        background: #2196f3 !important;
        color: white !important;
    }
    
    /* Lo mismo para starterStepsTable */
    .ecl-calculator-wrapper #starterStepsTable tbody tr td.step-number {
        background: #d4a03d !important;
        color: white !important;
        padding: 12px !important;
        justify-content: center !important;
        font-weight: 700 !important;
        font-size: 0.9rem !important;
        border-bottom: none !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tbody tr.step-cold td.step-number {
        background: #2196f3 !important;
        color: white !important;
    }

    .ecl-calculator-wrapper #manualStepsTable tr {
        display: block !important;
        background: #fafafa !important;
        border: 1px solid #e0e0e0 !important;
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        padding: 0 !important;
        overflow: hidden !important;
    }

    .ecl-calculator-wrapper #manualStepsTable tr.step-cold {
        background: #e3f2fd !important;
        border-color: #90caf9 !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        align-items: center !important;
        padding: 12px !important;
        border: none !important;
        border-bottom: 1px solid #eeeeee !important;
        width: 100% !important;
        box-sizing: border-box !important;
        gap: 8px !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:last-child {
        border-bottom: none !important;
    }

    /* Cabecera del paso (número) */
    .ecl-calculator-wrapper #manualStepsTable td:first-child {
        display: flex !important;
        background: #d4a03d !important;
        color: white !important;
        justify-content: center !important;
        font-weight: 700 !important;
        font-size: 0.9rem !important;
        padding: 14px 12px !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:first-child::before {
        content: "PASO " !important;
        color: white !important;
    }

    /* Etiquetas - alineadas a la izquierda */
    .ecl-calculator-wrapper #manualStepsTable td::before {
        font-weight: 600 !important;
        font-size: 0.7rem !important;
        color: #757575 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        text-align: left !important;
        justify-self: start !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(2)::before {
        content: "VOLUMEN" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(3)::before {
        content: "DENSIDAD" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(4)::before {
        content: "TEMP." !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(5)::before {
        content: "INICIO" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(6)::before {
        content: "FINAL" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(7)::before {
        content: "COBERTURA" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(8)::before {
        content: "TIEMPO" !important;
    }

    .ecl-calculator-wrapper #manualStepsTable td:nth-child(9)::before {
        content: "" !important;
    }

    /* Contenido de las celdas - alineado a la derecha */
    .ecl-calculator-wrapper #manualStepsTable td > * {
        justify-self: end !important;
    }

    /* Wrapper para inputs con unidad */
    .ecl-calculator-wrapper #manualStepsTable .input-wrapper {
        display: flex !important;
        align-items: center !important;
        gap: 4px !important;
        justify-content: flex-end !important;
    }

    /* Inputs dentro de la tabla - ancho fijo para alineación */
    .ecl-calculator-wrapper #manualStepsTable .manual-input {
        width: 70px !important;
        padding: 8px 6px !important;
        text-align: right !important;
        border: 1px solid #e0e0e0 !important;
        border-radius: 6px !important;
        font-size: 0.9rem !important;
        background: white !important;
    }

    .ecl-calculator-wrapper #manualStepsTable .manual-input:focus {
        border-color: #d4a03d !important;
        outline: none !important;
        box-shadow: 0 0 0 2px rgba(212, 160, 61, 0.2) !important;
    }

    /* Unidades */
    .ecl-calculator-wrapper #manualStepsTable .unit {
        font-size: 0.8rem !important;
        color: #757575 !important;
        min-width: 20px !important;
    }

    /* Valores de solo lectura (Inicio, Final, Cobertura, Tiempo) */
    .ecl-calculator-wrapper #manualStepsTable td:nth-child(5),
    .ecl-calculator-wrapper #manualStepsTable td:nth-child(6),
    .ecl-calculator-wrapper #manualStepsTable td:nth-child(7),
    .ecl-calculator-wrapper #manualStepsTable td:nth-child(8) {
        font-weight: 500 !important;
        font-size: 0.9rem !important;
    }

    /* Botón eliminar - centrado */
    .ecl-calculator-wrapper #manualStepsTable td:last-child {
        display: flex !important;
        justify-content: center !important;
        padding: 10px !important;
        background: #f5f5f5 !important;
    }

    .ecl-calculator-wrapper #manualStepsTable .remove-step-btn {
        width: 40px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: #ffebee !important;
        border: 1px solid #ffcdd2 !important;
        border-radius: 8px !important;
        color: #f44336 !important;
        cursor: pointer !important;
        transition: all 150ms ease !important;
    }

    .ecl-calculator-wrapper #manualStepsTable .remove-step-btn:hover {
        background: #ffcdd2 !important;
    }

    /* Colores de cobertura */
    .ecl-calculator-wrapper #manualStepsTable .coverage-good {
        color: #4caf50 !important;
        font-weight: 700 !important;
    }

    .ecl-calculator-wrapper #manualStepsTable .coverage-ok {
        color: #ff9800 !important;
        font-weight: 700 !important;
    }

    .ecl-calculator-wrapper #manualStepsTable .coverage-low {
        color: #f44336 !important;
        font-weight: 700 !important;
    }
}

}

@media (max-width: 480px) {
    /* Márgenes aún más reducidos en móviles pequeños */
    .ecl-calculator-wrapper .container {
        padding: 0 8px !important;
    }
    
    .ecl-calculator-wrapper .section-content {
        padding: 10px !important;
    }
    
    /* Grid 2x2 para fermentación (NO vertical) */
    .ecl-calculator-wrapper .fermentation-options {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .ecl-calculator-wrapper .fermentation-option {
        flex: 1 1 45% !important;
        min-width: 0 !important;
    }
    
    .ecl-calculator-wrapper .fermentation-option .option-content {
        padding: 0.5rem !important;
    }
    
    .ecl-calculator-wrapper .fermentation-option .option-content strong {
        font-size: 0.75rem !important;
    }
    
    .ecl-calculator-wrapper .fermentation-option .option-content small {
        font-size: 0.625rem !important;
    }
    
    .ecl-calculator-wrapper .summary-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
    .ecl-calculator-wrapper .preset-btn {
        flex: 1 !important;
        justify-content: center !important;
        text-align: center !important;
        font-size: 0.75rem !important;
        padding: 0.5rem !important;
    }
    
    .ecl-calculator-wrapper .state-toggle {
        flex-direction: column !important;
    }
    
    .ecl-calculator-wrapper .extract-toggle {
        flex-direction: column !important;
    }
    
    .ecl-calculator-wrapper .rehydration-toggle {
        flex-direction: column !important;
    }
    
    .ecl-calculator-wrapper .rehydration-option {
        min-width: 100% !important;
    }
    
    /* Tabla de pasos - ajustes extra */
    .ecl-calculator-wrapper #starterStepsTable td,
    .ecl-calculator-wrapper #manualStepsTable td {
        padding: 8px 10px !important;
        font-size: 0.875rem !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td:first-child,
    .ecl-calculator-wrapper #manualStepsTable td:first-child {
        padding: 10px !important;
    }
}


/* ============================================
   RESPONSIVE - TABLA DE PASOS STARTER
   ============================================ */

@media (max-width: 768px) {
    /* Ocultar tabla tradicional en móvil */
    .ecl-calculator-wrapper #starterStepsTable thead {
        display: none !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable,
    .ecl-calculator-wrapper #starterStepsTable tbody,
    .ecl-calculator-wrapper #starterStepsTable tr,
    .ecl-calculator-wrapper #starterStepsTable td {
        display: block !important;
        width: 100% !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr {
        background: #fafafa !important;
        border: 1px solid #e0e0e0 !important;
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        padding: 12px !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr.step-cold {
        background: #e3f2fd !important;
        border-color: #90caf9 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 8px 0 !important;
        border: none !important;
        border-bottom: 1px solid #eeeeee !important;
        text-align: right !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td:last-child {
        border-bottom: none !important;
    }
    
    /* Añadir etiquetas antes de cada celda */
    .ecl-calculator-wrapper #starterStepsTable td::before {
        content: attr(data-label);
        font-weight: 600 !important;
        font-size: 0.75rem !important;
        color: #757575 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        text-align: left !important;
    }
    
    /* Estilo para el número de paso */
    .ecl-calculator-wrapper #starterStepsTable td:first-child {
        background: #d4a03d !important;
        color: white !important;
        border-radius: 6px !important;
        padding: 8px 12px !important;
        margin-bottom: 8px !important;
        justify-content: center !important;
        font-weight: 700 !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable td:first-child::before {
        content: "Paso " !important;
        color: white !important;
    }
    
    .ecl-calculator-wrapper #starterStepsTable tr.step-cold td:first-child {
        background: #2196f3 !important;
        color: white !important;
    }
    
    /* Cobertura destacada */
    .ecl-calculator-wrapper #starterStepsTable td.coverage-good,
    .ecl-calculator-wrapper #starterStepsTable td.coverage-ok,
    .ecl-calculator-wrapper #starterStepsTable td.coverage-low {
        font-weight: 700 !important;
        font-size: 1rem !important;
    }
    
    /* Tabla manual también */
    .ecl-calculator-wrapper #manualStepsTable thead {
        display: none !important;
    }
    
    .ecl-calculator-wrapper #manualStepsTable,
    .ecl-calculator-wrapper #manualStepsTable tbody,
    .ecl-calculator-wrapper #manualStepsTable tr,
    .ecl-calculator-wrapper #manualStepsTable td {
        display: block !important;
        width: 100% !important;
    }
    
    .ecl-calculator-wrapper #manualStepsTable tr {
        background: #fafafa !important;
        border: 1px solid #e0e0e0 !important;
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        padding: 12px !important;
    }
    
    .ecl-calculator-wrapper #manualStepsTable td {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 8px 0 !important;
        border-bottom: 1px solid #eeeeee !important;
    }
    
    .ecl-calculator-wrapper #manualStepsTable td::before {
        content: attr(data-label);
        font-weight: 600 !important;
        font-size: 0.75rem !important;
        color: #757575 !important;
    }
    
    .ecl-calculator-wrapper #manualStepsTable .manual-input {
        width: 80px !important;
        text-align: center !important;
    }
}
