:root{--color-primary:#1e3a8a;--color-primary-light:#3b82f6;--color-primary-dark:#1e40af;--color-secondary:#0ea5e9;--color-secondary-light:#38bdf8;--color-neutral-lightest:#f8fafc;--color-neutral-light:#e2e8f0;--color-neutral:#64748b;--color-neutral-dark:#334155;--color-accent:#10b981;--text-primary:#1e293b;--text-secondary:#64748b;--text-light:#94a3b8;--background-primary:#fff;--background-secondary:#f8fafc;--background-tertiary:#f1f5f9;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem}
.header{background-color:var(--background-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);z-index:1000;padding:var(--spacing-md)0;position:sticky;top:0}.header-container{max-width:1200px;padding:0 var(--spacing-lg);justify-content:center;align-items:center;margin:0 auto;display:flex}.header-logo{align-items:center;gap:var(--spacing-sm);text-decoration:none;display:flex}.logo-image{border-radius:var(--radius-md);width:40px;height:40px}.logo-text{color:var(--color-primary);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:700}
.footer{background-color:var(--color-neutral-dark);color:var(--color-neutral-light);padding:var(--spacing-lg)0;margin-top:auto}.footer-bottom-container{max-width:1200px;padding:0 var(--spacing-lg);justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin:0 auto;display:flex}.footer-copyright{color:var(--color-neutral-light);margin:0;font-size:.9rem}.footer-creators{align-items:center;gap:var(--spacing-sm);font-size:.9rem;display:flex}.creators-label{color:var(--color-neutral-light);font-weight:500}.creator-link{color:var(--color-secondary-light);font-weight:600;text-decoration:none;transition:color .2s}.creator-link:hover{color:var(--color-secondary);text-decoration:underline}.separator{color:var(--color-neutral-light);margin:0 var(--spacing-xs)}@media (max-width:768px){.footer-bottom-container{gap:var(--spacing-md);text-align:center;flex-direction:column}.footer-creators{flex-wrap:wrap;justify-content:center}}
.hero{background:linear-gradient(135deg,var(--color-primary)0%,var(--color-primary-dark)100%);color:#fff;padding:var(--spacing-2xl)0;margin-bottom:var(--spacing-2xl)}.hero-container{gap:var(--spacing-2xl);grid-template-columns:1fr 1fr;align-items:center;max-width:1200px;margin:0 auto;display:grid}.hero-content{gap:var(--spacing-lg);flex-direction:column;display:flex}.hero-title{margin:0;font-size:3rem;font-weight:800;line-height:1.2}.highlight{color:var(--color-secondary-light)}.hero-subtitle{color:var(--color-neutral-light);margin:0;font-size:1.25rem;line-height:1.6}.hero-features{gap:var(--spacing-md);margin-top:var(--spacing-lg);flex-direction:column;display:flex}.feature-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;transition:all .3s;display:flex}.feature-item:hover{background:#ffffff26;transform:translate(8px);box-shadow:0 4px 12px #00000026}.feature-icon{filter:drop-shadow(0 2px 4px #0000001a);flex-shrink:0;font-size:1.8rem}.feature-text{color:#fff;font-size:1.1rem;font-weight:500;line-height:1.4}.hero-buttons{gap:var(--spacing-md);margin-top:var(--spacing-md);display:flex}.btn-hero-primary,.btn-hero-secondary{padding:var(--spacing-md)var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;border:none;font-size:1.1rem;font-weight:600;transition:all .2s}.btn-hero-primary{background-color:var(--color-secondary);color:#fff}.btn-hero-primary:hover{background-color:var(--color-secondary-light);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-hero-secondary{color:#fff;background-color:#0000;border:2px solid #fff}.btn-hero-secondary:hover{background-color:#ffffff1a}.hero-image{justify-content:center;align-items:center;display:flex}.placeholder-image{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#ffffff1a;justify-content:center;align-items:center;width:300px;height:300px;font-size:6rem;display:flex}@media (max-width:768px){.hero-container{text-align:center;grid-template-columns:1fr}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-features{margin-top:var(--spacing-md)}.feature-item{padding:var(--spacing-sm)var(--spacing-md)}.feature-item:hover{transform:translateY(-4px)}.feature-icon{font-size:1.5rem}.feature-text{font-size:.95rem}.hero-buttons{flex-direction:column;justify-content:center}.placeholder-image{width:200px;height:200px;font-size:4rem}}@media (max-width:1024px) and (min-width:769px){.hero-title{font-size:2.5rem}}
.input-component{width:100%;max-width:900px;margin:0 auto}.input-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.input-title{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:700}.btn-add-block{padding:var(--spacing-sm)var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #1e3a8a33}.btn-add-block:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn-add-block:hover:before{left:100%}.btn-add-block:hover{transform:translateY(-2px);box-shadow:0 4px 16px #1e3a8a4d}.btn-add-block:active{transform:translateY(0);box-shadow:0 2px 8px #1e3a8a33}.empty-state{text-align:center;padding:var(--spacing-2xl);background-color:var(--background-secondary);border-radius:var(--radius-lg);color:var(--text-secondary)}.bloques-list{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-direction:column;display:flex}@keyframes slideInFromRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.bloque-card{background-color:var(--background-primary);border:2px solid var(--border-color);border-radius:var(--radius-lg);transition:all .3s cubic-bezier(.4,0,.2,1);animation:.3s ease-out forwards slideInFromRight;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000d}.bloque-card:before{content:"";background:linear-gradient(90deg,var(--color-primary),var(--color-accent));opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.bloque-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.bloque-card:hover:before{opacity:1}.bloque-card.has-errors{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.bloque-header{padding:var(--spacing-md)var(--spacing-lg);background-color:var(--background-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;transition:background-color .2s;display:flex}.bloque-header:hover{background-color:var(--background-tertiary)}.bloque-header-left{align-items:center;gap:var(--spacing-md);flex:1;min-width:0;display:flex}.color-indicator{cursor:pointer;border:3px solid #fff;border-radius:50%;flex-shrink:0;width:24px;height:24px;transition:all .2s;box-shadow:0 2px 4px #0000001a}.color-indicator:hover{transform:scale(1.2);box-shadow:0 0 0 3px #1e3a8a33,0 4px 8px #00000026}.bloque-number{background-color:var(--color-primary);color:#fff;letter-spacing:.5px;white-space:nowrap;border-radius:14px;flex-shrink:0;padding:4px 12px;font-size:.85rem;font-weight:700}.bloque-summary{gap:var(--spacing-xs);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;flex:1;align-items:center;min-width:0;padding:2px 0;display:flex;overflow:auto hidden}.bloque-summary::-webkit-scrollbar{display:none}.summary-chip{white-space:nowrap;border-radius:12px;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 1px 3px #00000014}.summary-chip-info{color:#1e40af;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd}.summary-chip-success{color:#065f46;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #6ee7b7}.summary-chip:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.chip-icon{font-size:.9rem;line-height:1}.chip-label{line-height:1}.bloque-summary-empty{color:var(--text-secondary);opacity:.7;font-size:.85rem;font-style:italic}.bloque-header-right{align-items:center;gap:var(--spacing-md);display:flex}.btn-icon{cursor:pointer;padding:var(--spacing-xs);background:0 0;border:none;font-size:1.2rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.1)}.btn-delete:hover{filter:brightness(.8)}.expand-icon{color:var(--text-secondary);font-size:.8rem;transition:transform .2s}.expand-icon.expanded{transform:rotate(180deg)}.bloque-content{padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.validation-errors{border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background-color:#fef2f2;border:1px solid #fecaca}.error-message{color:#dc2626;margin-bottom:var(--spacing-xs);font-size:.9rem}.error-message:last-child{margin-bottom:0}.form-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-group{gap:var(--spacing-xs);flex-direction:column;display:flex}.form-group label{color:var(--text-primary);font-size:.95rem;font-weight:500}.form-input{padding:var(--spacing-sm)var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background-primary);font-size:1rem;transition:all .2s}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #1e3a8a1a}.form-hint{color:var(--text-secondary);font-size:.85rem}.costes-section{background-color:var(--background-secondary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-top:var(--spacing-lg)}.costes-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.costes-header h4{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:600}.btn-toggle-custom{padding:var(--spacing-xs)var(--spacing-md);background-color:var(--background-primary);color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.btn-toggle-custom:hover,.btn-toggle-custom.active{background-color:var(--color-primary);color:#fff}.costes-default{padding:var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-md)}.costes-info{color:var(--text-secondary);margin:0;font-family:Courier New,monospace;font-size:.95rem}.costes-custom{padding:var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-md)}.consejos-section{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--background-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary)}.consejo-item{color:var(--text-secondary);margin:var(--spacing-xs)0;font-size:.9rem;line-height:1.5}.consejo-item:first-child{margin-top:0}.consejo-item:last-child{margin-bottom:0}.costes-actions{margin-bottom:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.bulk-cost-input{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--background-secondary);border-radius:var(--radius-sm);border:2px solid var(--color-primary);display:flex}.bulk-cost-input label{color:var(--text-primary);white-space:nowrap;font-size:.9rem;font-weight:500}.bulk-input{padding:var(--spacing-xs)var(--spacing-sm);border:2px solid var(--border-color);border-radius:var(--radius-sm);width:100px;font-size:.9rem;transition:all .2s}.bulk-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #1e3a8a1a}.btn-apply-bulk{padding:var(--spacing-xs)var(--spacing-md);background-color:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;font-size:.85rem;font-weight:600;transition:all .2s}.btn-apply-bulk:hover{background-color:var(--color-primary-dark);transform:translateY(-1px)}.btn-reset-costs{padding:var(--spacing-xs)var(--spacing-md);background-color:var(--color-neutral-light);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;border:none;align-self:flex-start;font-size:.85rem;font-weight:500;transition:all .2s}.btn-reset-costs:hover{background-color:var(--color-neutral);color:#fff}.costes-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.cost-input-group{gap:var(--spacing-xs);flex-direction:column;display:flex}.cost-input-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.cost-input{padding:var(--spacing-xs)var(--spacing-sm);border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;transition:all .2s}.cost-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #1e3a8a1a}.output-section{margin-top:var(--spacing-2xl);padding:var(--spacing-lg);background-color:var(--background-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.output-section h4{color:var(--text-primary);margin:0 0 var(--spacing-md)0;font-size:1rem;font-weight:600}.json-output{background-color:var(--color-neutral-dark);color:#10b981;padding:var(--spacing-md);border-radius:var(--radius-md);margin:0;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;overflow-x:auto}.analyze-section{margin-top:var(--spacing-xl);padding:var(--spacing-lg)0;justify-content:center;display:flex}.btn-analyze{padding:var(--spacing-md)var(--spacing-2xl);background:linear-gradient(135deg,var(--color-accent),#059669);color:#fff;border-radius:var(--radius-lg);cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;min-width:200px;font-size:1.1rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 12px #10b9814d}.btn-analyze:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.btn-analyze:hover:not(:disabled):before{left:100%}.btn-analyze:hover:not(:disabled){transform:translateY(-3px)scale(1.02);box-shadow:0 8px 24px #10b98166}.btn-analyze:active:not(:disabled){transform:translateY(-1px)scale(1)}.btn-analyze:disabled{background:linear-gradient(135deg,var(--color-neutral),var(--color-neutral-dark));cursor:not-allowed;opacity:.6;box-shadow:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.btn-analyze:disabled{animation:1.5s ease-in-out infinite pulse}.button-click-error{margin-top:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);background-color:#fffbeb;border:1px solid #fcd34d;animation:.3s fadeIn}.error-hint{color:#92400e;text-align:center;margin:0;font-size:.9rem;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.analysis-error{margin-top:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-lg);background-color:#fef2f2;border:2px solid #fecaca}.error-text{color:#dc2626;text-align:center;margin:0;font-size:1rem;font-weight:500}.analysis-result{margin-top:var(--spacing-xl);padding:var(--spacing-lg);border-radius:var(--radius-lg);background-color:#f0fdf4;border:2px solid #86efac}.analysis-result h4{color:var(--text-primary);margin:0 0 var(--spacing-md)0;text-align:center;font-size:1.1rem;font-weight:600}.result-output{background-color:var(--background-primary);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border-color);margin:0;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;overflow-x:auto}@media (max-width:768px){.input-component{max-width:100%;padding:0}.input-header{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-left:var(--spacing-sm);padding-right:var(--spacing-sm);flex-direction:column;align-items:stretch}.input-title{text-align:center;font-size:1.3rem}.btn-add-block{width:100%;padding:var(--spacing-md);font-size:1rem}.bloques-list{padding:0 var(--spacing-sm)}.bloque-card{border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014}.bloque-card:active{transform:scale(.98)}.bloque-content{padding:var(--spacing-sm)}.bloque-header{padding:var(--spacing-sm);gap:var(--spacing-xs);flex-direction:column;align-items:stretch}.bloque-header-left{gap:var(--spacing-xs);flex-flow:wrap;align-items:flex-start}.color-indicator{flex-shrink:0;width:18px;height:18px;margin-top:2px}.bloque-number{flex-shrink:0;padding:3px 8px;font-size:.7rem}.bloque-summary{gap:var(--spacing-xs);flex-basis:100%;grid-template-columns:1fr 1fr;width:100%;padding:0;overflow:visible;display:grid!important}.summary-chip{border-radius:8px;justify-content:center;gap:3px;padding:4px 6px;font-size:.7rem}.chip-icon{font-size:.8rem}.chip-label{white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.bloque-header-right{justify-content:flex-end;gap:var(--spacing-sm);flex-direction:row}.btn-icon{padding:var(--spacing-xs);font-size:1.1rem}.expand-icon{font-size:.9rem}.form-grid{gap:var(--spacing-md);grid-template-columns:1fr}.form-group label{font-size:.9rem}.form-input{padding:var(--spacing-md);font-size:1rem}.costes-section{padding:var(--spacing-sm)}.costes-header{align-items:stretch;gap:var(--spacing-sm);flex-direction:column}.costes-header h5{font-size:.9rem;line-height:1.4}.btn-toggle-custom{width:100%;padding:var(--spacing-sm)var(--spacing-md)}.consejos-section{padding:var(--spacing-sm)}.consejo-item{font-size:.85rem}.bulk-cost-input{gap:var(--spacing-xs);flex-wrap:wrap}.bulk-cost-input label{width:100%;font-size:.85rem}.bulk-input{flex:1;min-width:80px}.btn-apply-bulk{padding:var(--spacing-xs)var(--spacing-md)}.costes-grid{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.cost-input-group label{font-size:.75rem}.cost-input{padding:var(--spacing-xs);font-size:.85rem}.analyze-section{padding-left:var(--spacing-sm);padding-right:var(--spacing-sm)}.btn-analyze{width:100%;padding:var(--spacing-lg);font-size:1.1rem}.button-click-error{margin-left:var(--spacing-sm);margin-right:var(--spacing-sm)}.error-hint{font-size:.85rem}.analysis-error{margin-left:var(--spacing-sm);margin-right:var(--spacing-sm)}.validation-errors{padding:var(--spacing-sm);margin-bottom:var(--spacing-md)}.error-message{font-size:.85rem}}
.output-component{width:100%;max-width:900px;margin:var(--spacing-2xl)auto;padding:var(--spacing-xl);background-color:var(--background-primary);border:2px solid var(--color-accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.output-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.output-title{color:var(--text-primary);text-align:center;flex:1;margin:0;font-size:1.5rem;font-weight:700}.download-pdf-button{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm)var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 12px #00000026}.download-pdf-button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.download-pdf-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #00000026}.download-pdf-button:disabled{opacity:.6;cursor:not-allowed;background:linear-gradient(135deg,#999,#777)}.empty-message{text-align:center;padding:var(--spacing-2xl);background-color:var(--background-secondary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:1.1rem;line-height:1.6}.empty-message p{margin:0}.plan-selector{background-color:var(--background-secondary);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.selector-title{color:var(--text-primary);margin:0 0 var(--spacing-md)0;text-align:center;font-size:1.1rem;font-weight:600}.plan-options{gap:var(--spacing-md);flex-wrap:wrap;justify-content:center;display:flex}.plan-option{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;border:2px solid #ccc;transition:all .3s;display:flex}.plan-option:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.plan-option.selected{background-color:var(--background-secondary);box-shadow:var(--shadow-sm)}.plan-option.plan-optimo{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);font-weight:600;box-shadow:0 2px 8px #2e7d3233;border-color:#2e7d32!important}.plan-option.plan-optimo:hover{transform:none;box-shadow:0 2px 8px #2e7d3233}.plan-option input[type=checkbox]{cursor:pointer}.plan-option input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.plan-color-indicator{border:2px solid var(--border-color);border-radius:50%;flex-shrink:0;width:16px;height:16px}.plan-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.chart-container{background-color:var(--background-secondary);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);overflow:visible}.chart-title-container{justify-content:center;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.chart-main-title{color:var(--text-primary);text-align:center;margin:0;font-size:1.1rem;font-weight:600}.info-tooltip{cursor:help;-webkit-tap-highlight-color:transparent;align-items:center;display:inline-flex;position:relative}.info-icon{-webkit-user-select:none;user-select:none;font-size:1.2rem;transition:transform .2s}.info-tooltip:hover .info-icon,.info-tooltip.active .info-icon{transform:scale(1.2)}.tooltip-content{margin-top:var(--spacing-xs);padding:var(--spacing-md);background-color:var(--color-neutral-dark);color:#fff;border-radius:var(--radius-md);width:300px;max-width:90vw;box-shadow:var(--shadow-lg);z-index:1000;opacity:0;visibility:hidden;pointer-events:none;font-size:.9rem;line-height:1.4;transition:opacity .2s,visibility .2s;position:absolute;top:100%;left:50%;transform:translate(-50%)}.info-tooltip:hover .tooltip-content,.info-tooltip.active .tooltip-content{opacity:1;visibility:visible}.tooltip-content:before{content:"";border:8px solid #0000;border-bottom-color:var(--color-neutral-dark);position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.chart-legend{justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color);flex-wrap:wrap;transition:all .3s;display:flex}.legend-item{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs)var(--spacing-sm);background-color:var(--background-secondary);border-radius:var(--radius-sm);cursor:default;-webkit-user-select:none;user-select:none;transition:all .2s;display:flex}.legend-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.legend-color-box{border:2px solid var(--border-color);border-radius:3px;flex-shrink:0;width:16px;height:16px;transition:all .2s}.legend-item:hover .legend-color-box{transform:scale(1.1)}.legend-label{color:var(--text-primary);white-space:nowrap;font-size:.9rem;font-weight:500}.chart-svg{touch-action:manipulation;width:100%;height:auto;margin:0 auto;display:block}.chart-title{fill:var(--text-primary);font-size:16px;font-weight:600}.grid-line{stroke:var(--border-color);stroke-width:1px;opacity:.5}.axis-line{stroke:var(--text-primary);stroke-width:2px}.axis-label{fill:var(--text-secondary);font-size:12px}.axis-title{fill:var(--text-primary);font-size:14px;font-weight:600}.x-axis-label-container{justify-content:center;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding-top:var(--spacing-xs);display:flex}.x-axis-label{color:var(--text-primary);font-size:14px;font-weight:600}.axis-info-tooltip{align-items:center;display:inline-flex;position:relative}.axis-info-tooltip .tooltip-content{margin-top:0;margin-bottom:var(--spacing-xs);width:220px;top:auto;bottom:100%}.axis-info-tooltip .tooltip-content:before{content:"";border:8px solid #0000;border-top-color:var(--color-neutral-dark);border-bottom:none;position:absolute;top:100%;bottom:auto;left:50%;transform:translate(-50%)}.chart-line{stroke:var(--color-primary);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;fill:none}.chart-point{fill:var(--color-accent);stroke:var(--background-primary);stroke-width:2px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s}.chart-point:hover,.chart-point.active{stroke-width:3px;filter:brightness(1.2)}@media (max-width:768px){.chart-point{stroke-width:2.5px}}.point-tooltip{pointer-events:none}.tooltip-rect{fill:var(--color-neutral-dark);stroke:var(--color-primary);stroke-width:2px;opacity:.95;filter:drop-shadow(0 4px 6px #0000004d)}.tooltip-text-title{fill:#fff;font-size:13px;font-weight:700}.tooltip-text{fill:#fff;font-size:12px;font-weight:500}.probability-section{background-color:var(--background-secondary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl)}.probability-section h4{color:var(--text-primary);margin:0 0 var(--spacing-lg)0;font-size:1.1rem;font-weight:600}.stats-container{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.stat-card{background:linear-gradient(135deg,var(--background-primary),var(--background-secondary));padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;border:2px solid var(--border-color);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000d}.stat-card:before{content:"";background:linear-gradient(90deg,var(--color-primary),var(--color-accent));height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--color-primary);transform:translateY(-4px)scale(1.02);box-shadow:0 8px 20px #0000001f}.stat-label{color:var(--text-secondary);margin-bottom:var(--spacing-xs);font-size:.9rem;font-weight:500}.stat-value{color:var(--color-primary);font-size:2rem;font-weight:700}.threshold-card{flex-direction:column;justify-content:space-between;min-height:180px;display:flex}.threshold-card .stat-label{margin-bottom:var(--spacing-md);color:var(--text-primary);font-size:.95rem;line-height:1.5}.threshold-values{gap:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:center;align-items:center;display:flex}.threshold-item{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);flex-direction:column;flex:1;display:flex}.threshold-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:600}.threshold-number{color:var(--color-accent);text-shadow:0 2px 4px #0000001a;font-size:2rem;font-weight:800;line-height:1}.plan-details{background-color:var(--background-secondary);padding:var(--spacing-lg);border-radius:var(--radius-md)}.plan-details h4{color:var(--text-primary);margin:0 0 var(--spacing-md)0;font-size:1.1rem;font-weight:600}.plan-list{gap:var(--spacing-sm);flex-direction:column;display:flex}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.plan-step{opacity:0;animation:.3s ease-out forwards slideInFromLeft}.plan-step:first-child{animation-delay:50ms}.plan-step:nth-child(2){animation-delay:.1s}.plan-step:nth-child(3){animation-delay:.15s}.plan-step:nth-child(4){animation-delay:.2s}.plan-step:nth-child(5){animation-delay:.25s}.plan-step:nth-child(6){animation-delay:.3s}.plan-step:nth-child(7){animation-delay:.35s}.plan-step:nth-child(8){animation-delay:.4s}.plan-step:nth-child(9){animation-delay:.45s}.plan-step:nth-child(10),.plan-step:nth-child(n+11){animation-delay:.5s}.plan-step{gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--background-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);border-left-width:4px;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000d}.plan-step:before{content:"";background:linear-gradient(90deg,var(--color-primary),var(--color-accent));opacity:0;height:2px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.plan-step:hover{border-color:var(--color-primary);transform:translate(8px)translateY(-2px);box-shadow:0 4px 12px #0000001a}.plan-step:hover:before{opacity:1}.step-header{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.step-number{color:#fff;background-color:var(--color-primary);letter-spacing:.5px;border-radius:12px;padding:2px 8px;font-size:.8rem;font-weight:700}.step-block-theme{color:var(--text-primary);align-items:center;gap:var(--spacing-xs);font-size:.9rem;font-weight:600;display:flex}.step-details{gap:var(--spacing-md);padding-top:var(--spacing-xs);border-top:1px solid var(--border-color);flex-wrap:wrap;display:flex}.step-detail-item{color:var(--text-secondary);background-color:var(--background-secondary);border-radius:var(--radius-sm);align-items:center;gap:4px;padding:4px 8px;font-size:.85rem;display:flex}.step-detail-item strong{color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;font-size:.75rem;font-weight:600}.step-content{color:var(--text-secondary);word-break:break-word;font-family:Courier New,monospace;font-size:.9rem}@media (max-width:768px){.output-component{max-width:100%;padding:var(--spacing-sm);margin:var(--spacing-md)0}.output-header{text-align:center;flex-direction:column}.output-title{text-align:center;font-size:1.3rem}.download-pdf-button{width:100%;padding:var(--spacing-md);justify-content:center;font-size:.9rem}.plan-selector{padding:var(--spacing-md)}.selector-title{font-size:1rem}.plan-options{gap:var(--spacing-sm)}.plan-option{padding:var(--spacing-xs)var(--spacing-sm);font-size:.85rem}.plan-name{font-size:.85rem}.chart-container{padding:var(--spacing-sm);overflow:visible}.chart-title-container{gap:var(--spacing-xs);flex-direction:column}.chart-main-title{text-align:center;font-size:1rem}.chart-legend{justify-content:flex-start;gap:var(--spacing-xs);padding:var(--spacing-sm)var(--spacing-xs);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-primary)var(--background-secondary);flex-wrap:nowrap;position:relative;overflow:auto hidden}.chart-legend:after{content:"";background:linear-gradient(to right,transparent,var(--background-primary));pointer-events:none;border-radius:var(--radius-sm);width:30px;position:absolute;top:0;bottom:0;right:0}.chart-legend::-webkit-scrollbar{height:4px}.chart-legend::-webkit-scrollbar-track{background:var(--background-secondary);border-radius:2px}.chart-legend::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:2px}.chart-legend::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dark)}.legend-item{background:linear-gradient(135deg,var(--background-secondary),var(--background-primary));border:1px solid var(--border-color);border-radius:16px;flex-shrink:0;padding:6px 10px;font-size:.8rem;box-shadow:0 2px 4px #0000001a}.legend-item:hover{transform:translateY(0)scale(1.05)}.legend-color-box{border-width:1.5px;border-radius:50%;width:12px;height:12px}.legend-label{font-size:.8rem;font-weight:600}.axis-label{font-size:10px}.axis-title{font-size:12px}.x-axis-label{font-size:13px}.stats-container{gap:var(--spacing-md);grid-template-columns:1fr}.stat-card{padding:var(--spacing-lg);border-radius:var(--radius-xl);min-height:auto;box-shadow:0 4px 12px #00000014}.stat-card:active{transform:scale(.98)}.threshold-card{min-height:160px}.threshold-card .stat-label{font-size:.9rem;line-height:1.4}.threshold-number{font-size:1.8rem}.threshold-values{gap:var(--spacing-sm);padding:var(--spacing-sm);flex-direction:row}.threshold-item{padding:var(--spacing-xs)}.threshold-label{font-size:.7rem}.plan-details{padding:var(--spacing-sm)}.plan-details h4{font-size:1rem}.plan-step{padding:var(--spacing-sm);border-radius:var(--radius-md);border-left-width:3px;box-shadow:0 2px 8px #00000014}.plan-step:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.step-header{gap:var(--spacing-sm);flex-direction:row;align-items:center}.step-number{white-space:nowrap;border-radius:14px;padding:4px 10px;font-size:.75rem}.step-block-theme{flex:1;font-size:.85rem}.step-details{gap:var(--spacing-xs);padding-top:var(--spacing-sm);margin-top:var(--spacing-xs)}.step-detail-item{background:linear-gradient(135deg,var(--background-secondary),var(--background-primary));border:1px solid var(--border-color);border-radius:8px;padding:4px 8px;font-size:.75rem}.step-detail-item strong{font-size:.7rem}.probability-section{padding:var(--spacing-sm)}.probability-section h4{font-size:1rem}.tooltip-content{width:250px;padding:var(--spacing-sm);font-size:.85rem}.info-icon{font-size:1.1rem}}
.simular-examen-component{flex-direction:column;align-items:center;width:100%;margin-top:20px;padding:16px 0;display:flex}.btn-simular-examen{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;min-width:200px;padding:16px 48px;font-size:1.1rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 12px #667eea4d}.btn-simular-examen:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.btn-simular-examen:hover:not(:disabled):before{left:100%}.btn-simular-examen:hover:not(:disabled){transform:translateY(-3px)scale(1.02);box-shadow:0 8px 24px #667eea66}.btn-simular-examen:active:not(:disabled){transform:translateY(-1px)scale(1)}.btn-simular-examen:disabled{cursor:not-allowed;opacity:.6;box-shadow:none;background:linear-gradient(135deg,#9ca3af,#6b7280)}.simulation-result{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:12px;width:100%;max-width:900px;margin-top:30px;padding:20px}.simulation-title{color:#333;text-align:center;margin-bottom:8px;font-size:20px;font-weight:700}.simulation-subtitle{color:#666;text-align:center;margin-bottom:20px;font-size:14px;font-style:italic}.bloques-simulation{flex-direction:column;gap:16px;display:flex}.bloque-simulation-card{background:#fff;border-left:4px solid;border-radius:8px;padding:16px;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #0000000d}.bloque-simulation-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.bloque-simulation-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.bloque-simulation-number{color:#333;font-size:16px;font-weight:700}.bloque-simulation-count{color:#666;font-size:14px;font-weight:500}.temas-seleccionados{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.tema-badge{color:#000;border-radius:16px;justify-content:center;align-items:center;min-width:40px;height:32px;padding:0 12px;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 2px 4px #0000001a}.bloque-simulation-info{color:#666;text-align:center;border-top:1px solid #e0e0e0;margin-top:8px;padding-top:8px;font-size:13px}@media (max-width:768px){.simular-examen-component{padding:16px 8px}.btn-simular-examen{width:100%;padding:16px;font-size:1.1rem}.simulation-result{padding:16px}.simulation-title{font-size:18px}.simulation-subtitle{font-size:13px}.bloque-simulation-card{padding:12px}.bloque-simulation-number{font-size:14px}.bloque-simulation-count{font-size:12px}.tema-badge{min-width:36px;height:28px;padding:0 10px;font-size:13px}.bloque-simulation-info{font-size:12px}}
