:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-hover: #eff6ff;--text-primary: #1e293b;--text-secondary: #475569;--text-tertiary: #64748b;--border-color: #e2e8f0;--border-color-hover: #cbd5e1;--color-primary: #2563eb;--color-primary-dark: #1e40af;--bg-success: #f0fdf4;--border-success: #86efac;--text-success: #15803d;color-scheme:light;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dark-mode{color-scheme:dark;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-hover: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--border-color: #334155;--border-color-hover: #475569;--color-primary: #3b82f6;--color-primary-dark: #60a5fa;--bg-success: #064e3b;--border-success: #065f46;--text-success: #6ee7b7}body{margin:0;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}.file-drop-zone{border:2px dashed #cbd5e1;border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#f8fafc}.file-drop-zone:hover:not(.disabled){border-color:#3b82f6;background:#eff6ff}.file-drop-zone.disabled{opacity:.5;cursor:not-allowed}.drop-zone-content svg{color:#64748b;margin:0 auto 1rem}.drop-zone-title{font-size:1.125rem;font-weight:500;color:#1e293b;margin:0 0 .5rem}.drop-zone-subtitle{font-size:.875rem;color:#64748b;margin:0}.drop-zone-divider{display:flex;align-items:center;width:100%;margin:1.5rem 0 1rem}.drop-zone-divider:before,.drop-zone-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.drop-zone-divider span{padding:0 1rem;color:#94a3b8;font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.try-examples-button{padding:.75rem 1.5rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;margin:0 auto}.try-examples-button:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 8px #0000000d}.try-examples-button:disabled{opacity:.5;cursor:not-allowed}.example-hint{font-size:.75rem;color:#94a3b8;margin:.75rem 0 0;font-style:italic}.summary-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:2rem 0}.summary-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;text-align:center}.no-border{border:none}.no-background{background:transparent}.summary-card.highlight{background:#eff6ff;border-color:#3b82f6}.summary-value{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.summary-value-small{font-size:1.5rem}.summary-value-xsmall{font-size:1.25rem}.summary-card.highlight .summary-value{color:#3b82f6}.summary-card.positive{border-color:#86efac}.summary-card.positive .summary-value{color:#16a34a}.summary-card.negative{border-color:#fca5a5}.summary-card.negative .summary-value{color:#dc2626}.summary-label{font-size:.875rem;color:#64748b;font-weight:500}@media(max-width:768px){.summary-container{grid-template-columns:repeat(2,1fr);gap:.75rem;margin:1.5rem 0}.summary-card{padding:1rem .75rem;border-radius:6px}.summary-value{font-size:1.5rem;margin-bottom:.375rem}.summary-value-small{font-size:1.125rem}.summary-value-xsmall{font-size:.9375rem}.summary-label{font-size:.75rem;line-height:1.3}}@media(max-width:400px){.summary-container{gap:.5rem}.summary-card{padding:.75rem .5rem}.summary-value{font-size:1.25rem;margin-bottom:.25rem}.summary-value-small{font-size:1rem}.summary-value-xsmall{font-size:.875rem}.summary-label{font-size:.6875rem}}.rules-info{background:#f0f7fd;border:1px solid #86d3ef;border-radius:8px;padding:1.5rem;margin:2rem 0}.rules-info h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#1e40af}.rules-info ul{margin:0;padding-left:1.5rem;color:#1e40af}.rules-info li{margin:.5rem 0}.settings-link{background:none;border:none;color:#3b82f6;font-weight:600;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;transition:color .2s}.settings-link:hover{color:#2563eb;text-decoration-style:solid}.preview-container{margin:2rem 0}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.preview-controls{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.page-size-selector{display:flex;align-items:center;gap:.5rem}.page-size-selector label{font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.page-size-selector select{padding:.375rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s}.page-size-selector select:hover{border-color:var(--border-color-hover)}.page-size-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.preview-title{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0}.preview-pagination{display:flex;align-items:center;gap:.5rem}.pagination-button{padding:.375rem .75rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;color:#475569;cursor:pointer;transition:all .15s ease;min-width:2rem}.pagination-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.pagination-button:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:.875rem;color:#64748b;padding:0 .5rem;white-space:nowrap}.preview-table-wrapper{overflow-x:auto;border:1px solid #e2e8f0;border-radius:8px;background:#fff}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.preview-table th{text-align:left;padding:.75rem 1rem;font-weight:600;color:#475569;white-space:nowrap}.preview-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s,color .2s}.preview-table th.sortable:hover{background:#f1f5f9;color:#1e293b}.preview-table th.sortable.active{background:#e0e7ff;color:#3b82f6}.preview-table tbody tr{border-bottom:1px solid #f1f5f9}.preview-table tbody tr:last-child{border-bottom:none}.preview-table tbody tr:hover{background:#f8fafc}.preview-table td{padding:.75rem 1rem;color:#334155}.date-column{white-space:nowrap;font-variant-numeric:tabular-nums}.account-column{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.description-column{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.amount-column{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.amount-column.positive{color:#16a34a;font-weight:500}.amount-column.negative{color:#dc2626;font-weight:500}@media(max-width:768px){.preview-header{flex-direction:column;align-items:flex-start}.preview-pagination{width:100%;justify-content:center}.preview-table{font-size:.75rem}.preview-table th,.preview-table td{padding:.5rem}.account-column{max-width:120px}.description-column{max-width:150px}.pagination-button{padding:.25rem .5rem;font-size:.875rem;min-width:1.75rem}.pagination-info{font-size:.75rem}}.chart-container{margin:2rem 0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;position:relative}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-header h3{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0}.chart-note{margin:.75rem 0 1.5rem;padding:.75rem 1rem;background:#f0f9ff;border-left:3px solid #3b82f6;border-radius:4px;font-size:.875rem;color:#1e40af;line-height:1.5}.chart-note strong{font-weight:600}.chart-final-balance{font-size:1rem;font-weight:600;padding:.5rem 1rem;border-radius:6px}.chart-final-balance.positive{background:#dcfce7;color:#16a34a}.chart-final-balance.negative{background:#fee2e2;color:#dc2626}.chart-svg{width:100%;height:auto;display:block}.chart-tooltip{position:absolute;transform:translate(-50%,-120%);background:#1e293b;color:#fff;padding:.75rem;border-radius:6px;font-size:.875rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;pointer-events:none;z-index:10;min-width:180px}.chart-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #1e293b}.tooltip-date{font-size:.75rem;color:#94a3b8;margin-bottom:.5rem}.tooltip-balance{margin-bottom:.25rem}.tooltip-change{margin-bottom:0}.tooltip-change.positive{color:#86efac}.tooltip-change.negative{color:#fca5a5}.tooltip-balance strong,.tooltip-change strong{font-weight:600}@media(max-width:768px){.chart-header{flex-direction:column;align-items:flex-start;gap:.5rem}.chart-final-balance{font-size:.875rem;padding:.375rem .75rem}}.about-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;overflow-y:auto;transition:opacity .2s ease-out,visibility .2s ease-out}.about-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.about-overlay.visible{opacity:1;visibility:visible;pointer-events:auto}.about-modal{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;padding:2.5rem;position:relative;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(0);transition:transform .3s ease-out}.about-overlay.hidden .about-modal{transform:translateY(-20px)}.about-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;line-height:1;color:#64748b;cursor:pointer;padding:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.about-close:hover{background-color:#f1f5f9;color:#334155}.about-modal h1{font-size:2rem;color:#1e293b;margin:0 0 2rem;padding-right:3rem}.about-modal h2{font-size:1.5rem;color:#334155;margin:2rem 0 1rem}.about-modal section{margin-bottom:2rem}.about-modal section:first-of-type h2{margin-top:0}.about-modal p{line-height:1.7;color:#475569;margin:1rem 0}.about-modal ul,.about-modal ol{margin:1rem 0;padding-left:1.5rem}.about-modal li{margin:.5rem 0;line-height:1.6;color:#475569}.about-modal strong{color:#334155;font-weight:600}.support-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;padding:1.5rem;margin-top:2.5rem!important;text-align:center}.support-section h2{margin-top:0;color:#92400e}.support-section p{color:#78350f}.coffee-button{display:inline-block;background-color:#fd0;color:#000;padding:.875rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.125rem;margin:1rem 0;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a}.coffee-button:hover{background-color:gold;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.support-note{font-size:.875rem;color:#92400e;margin-top:1rem;font-style:italic}.about-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #e2e8f0;text-align:center}.about-footer p{color:#94a3b8;font-size:.875rem;margin:0}@media(max-width:768px){.about-modal{padding:2rem 1.5rem;max-height:95vh}.about-modal h1{font-size:1.75rem;margin-bottom:1.5rem}.about-modal h2{font-size:1.25rem}.coffee-button{font-size:1rem;padding:.75rem 1.5rem}}.about-modal{scroll-behavior:smooth}.about-modal::-webkit-scrollbar{width:8px}.about-modal::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.about-modal::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.about-modal::-webkit-scrollbar-thumb:hover{background:#94a3b8}.tip-box{background-color:#dbeafe;border-left:4px solid #3b82f6;padding:1rem 1.25rem;border-radius:4px;margin:1.5rem 0;font-size:.9375rem}.tip-box strong{color:#1e40af}.example-files{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.example-download{display:inline-flex;align-items:center;justify-content:center;background-color:#f8fafc;border:2px solid #e2e8f0;color:#334155;padding:1rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;font-size:1rem;transition:all .2s}.example-download:hover{background-color:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.example-note{background-color:#f8fafc;border:1px solid #e2e8f0;padding:.875rem 1.25rem;border-radius:6px;font-size:.875rem;color:#64748b;margin-top:1rem}@media(min-width:640px){.example-files{flex-direction:row}}.currency-selector{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;border-radius:8px}.currency-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0}.currency-options{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.currency-button{padding:.5rem 1rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:6px;font-size:1rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s;min-width:3rem}.currency-button:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--bg-hover)}.currency-button.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.currency-input{padding:.5rem .75rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:6px;font-size:1rem;font-weight:600;color:var(--text-primary);cursor:text;transition:all .2s;min-width:4.5rem;max-width:5rem;text-align:center;outline:none}.currency-input::placeholder{color:var(--text-tertiary);font-weight:500}.currency-input:hover{border-color:var(--color-primary)}.currency-input:focus{border-color:var(--color-primary);background:var(--bg-hover);box-shadow:0 0 0 3px #3b82f61a}.currency-input.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.currency-input.active::placeholder{color:#ffffffb3}@media(max-width:768px){.currency-selector{padding:.875rem}.currency-button{padding:.4rem .875rem;font-size:.95rem;min-width:2.75rem}.currency-input{padding:.4rem .75rem;font-size:.95rem;min-width:4rem;max-width:4.5rem}}.error-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.error-modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.error-modal-header h2{margin:0;font-size:1.5rem;color:#dc2626;display:flex;align-items:center;gap:.5rem}.error-modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#64748b;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.error-modal-close:hover{background:#f1f5f9;color:#1e293b}.error-modal-body{padding:1.5rem}.error-modal-body p{margin:0 0 1rem;color:#475569}.error-list{list-style:none;padding:0;margin:0}.error-list li{background:#fef2f2;border-left:3px solid #dc2626;padding:.75rem 1rem;margin-bottom:.75rem;border-radius:4px;color:#7f1d1d;font-size:.875rem;line-height:1.5}.error-list li:last-child{margin-bottom:0}.error-modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}@media(max-width:768px){.error-modal-content{max-height:95vh}.error-modal-header h2{font-size:1.25rem}}.removed-items-container{margin:2rem 0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem}.removed-items-container h3{margin:0 0 .5rem;font-size:1.25rem;color:#1e293b}.removed-items-description{margin:0 0 1.5rem;color:#64748b;font-size:.875rem}.removed-section{margin-bottom:1rem}.removed-section:last-child{margin-bottom:0}.removed-section-toggle{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;color:#475569;text-align:left;transition:all .2s}.removed-section-toggle:hover{background:#f1f5f9;border-color:#cbd5e1}.toggle-icon{color:#94a3b8;font-size:.75rem}.toggle-label{flex:1}.removed-content{margin-top:.75rem;padding:1rem;background:#fafafa;border-radius:6px}.removed-table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff;border-radius:4px;overflow:hidden}.removed-table thead{background:#f8fafc}.removed-table th{padding:.75rem;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.removed-table td{padding:.75rem;border-bottom:1px solid #f1f5f9;color:#1e293b}.removed-table tbody tr:last-child td{border-bottom:none}.removed-table tbody tr:hover{background:#f8fafc}.amount-column.positive{color:#16a34a;font-weight:600}.amount-column.negative{color:#dc2626;font-weight:600}.account-column{font-size:.8125rem;color:#64748b}.transfers-list{display:flex;flex-direction:column;gap:1.5rem}.transfer-pair{background:#fff;border-radius:6px;padding:1rem;border:1px solid #e2e8f0}.transfer-label{font-size:.8125rem;font-weight:600;color:#64748b;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.transfer-direction{font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.transfer-direction.out{color:#dc2626}.transfer-direction.in{color:#16a34a}@media(max-width:768px){.removed-items-container{padding:1rem}.removed-table{font-size:.75rem;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.removed-table thead,.removed-table tbody,.removed-table tr{display:block}.removed-table thead{display:none}.removed-table tr{margin-bottom:1rem;border:1px solid #e2e8f0;border-radius:6px;padding:.75rem}.removed-table tr:last-child{margin-bottom:0}.removed-table td{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.removed-table td:last-child{border-bottom:none}.removed-table td:before{content:attr(data-label);font-weight:600;color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;margin-right:1rem}.transfer-pair{padding:.75rem}.transfer-label{font-size:.75rem;margin-bottom:.5rem}.transfer-pair .removed-table{background:transparent}.transfer-pair .removed-table tr{background:#f8fafc;margin-bottom:.75rem;padding:.5rem .75rem}}.dark-mode-toggle{position:fixed;bottom:2rem;right:2rem;width:3.5rem;height:3.5rem;border-radius:50%;border:none;background:#fff;box-shadow:0 4px 12px #00000026;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:999}.dark-mode-toggle:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003}.dark-mode-toggle:active{transform:scale(.95)}.dark-mode .dark-mode-toggle{background:#1e293b;box-shadow:0 4px 12px #0000004d}@media(max-width:768px){.dark-mode-toggle{bottom:1rem;right:1rem;width:3rem;height:3rem;font-size:1.25rem}}.navigation-bar{background:var(--bg-primary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.nav-container{max-width:800px;width:100%;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center}.nav-brand{display:flex;flex-direction:column;gap:.25rem;background:none;border:none;padding:0;text-align:left;transition:opacity .2s}.nav-brand:not(:disabled){cursor:pointer}.nav-brand:not(:disabled):hover{opacity:.8}.nav-brand:not(:disabled):active{opacity:.6}.nav-brand h1{margin:0;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#6f00ff,#00aeff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-tagline{margin:0;font-size:.875rem;color:var(--text-tertiary);font-weight:500}.nav-menu{display:flex;align-items:center;gap:1rem}.nav-link{background:none;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;padding:.5rem 1rem;border-radius:6px;transition:all .2s;white-space:nowrap}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.mobile{width:100%;text-align:left;padding:.875rem 1.5rem;border-radius:0}.nav-link.mobile:hover{background:var(--bg-secondary)}.mobile-menu-button{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center}.hamburger{width:24px;height:20px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger span{display:block;width:100%;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}.mobile-menu{border-top:1px solid var(--border-color);background:var(--bg-primary);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.desktop-only{display:flex}.mobile-only{display:none}@media(max-width:768px){.desktop-only{display:none}.mobile-only{display:flex}.nav-brand h1{font-size:1.25rem}.nav-tagline{font-size:.7rem}.nav-container{padding:.875rem 1rem}}.loading-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.dark-mode .loading-overlay{background:#0f172acc}.loading-content{background:var(--bg-primary);border-radius:12px;padding:2rem 3rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;align-items:center;gap:1.5rem;min-width:300px;animation:slideUp .3s ease-out}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-text{text-align:center}.loading-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.loading-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.loading-progress{font-size:.875rem;font-weight:600;color:var(--color-primary);margin:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.loading-content{padding:1.5rem 2rem;min-width:280px;margin:0 1rem}.loading-spinner{width:40px;height:40px}.loading-title{font-size:1rem}.loading-subtitle{font-size:.8125rem}}*{box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:2rem 1rem}.privacy-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--bg-success);border:1px solid var(--border-success);border-radius:8px;padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-success);font-weight:500;box-shadow:0 1px 3px #0000000d}.privacy-notice svg{flex-shrink:0;color:#22c55e}.app-main{flex:1;max-width:800px;width:100%;margin:0 auto;padding:2rem 1rem}.processing-message{text-align:center;padding:1rem;color:#64748b;font-style:italic}.errors-notice{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:1.5rem;margin:2rem 0}.errors-notice h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#991b1b}.errors-notice ul{margin:0;padding-left:1.5rem;color:#b91c1c}.errors-notice li{margin:.5rem 0}.action-buttons{display:flex;gap:1rem;justify-content:center;margin:2rem 0}.button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.button-primary{background:#3b82f6;color:#fff}.button-primary:hover{background:#2563eb}.button-secondary{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.button-secondary:hover{background:#e2e8f0}.export-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.export-label{font-size:.875rem;font-weight:600;color:#475569}.export-format-select{padding:.625rem 1rem;font-size:.875rem;font-weight:500;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;cursor:pointer;transition:all .2s}.export-format-select:hover{border-color:#94a3b8}.export-format-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.app-footer{text-align:center;padding:2rem 1rem;border-top:1px solid #e2e8f0;background:#f8fafc;color:#64748b;font-size:.875rem}.footer-contact{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0;line-height:1.6}.footer-contact a{color:#0a66c2;font-weight:600;text-decoration:none;transition:color .2s}.footer-contact a:hover{color:#004182;text-decoration:underline}.footer-coffee{margin-top:.75rem}.footer-coffee a{display:inline-flex;align-items:center;gap:.375rem;color:#92400e;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:0 1px 3px #0000001a}.footer-coffee a:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a;text-decoration:none}.app-footer a{color:#3b82f6;text-decoration:none}.footer-coffee a{color:#004182;text-decoration:none}.app-footer a:hover{text-decoration:underline}.footer-coffee a:hover{text-decoration:none}@media(max-width:768px){.app-header h1{font-size:2rem}.about-link{margin-top:0;position:absolute;right:1rem;top:1rem}.action-buttons{flex-direction:column}.button{width:100%}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(to bottom,#fff,#f8fafc)}.error-boundary-content{max-width:600px;text-align:center;background:#fff;padding:3rem 2rem;border-radius:12px;box-shadow:0 10px 25px #0000001a}.error-boundary-content h1{font-size:2rem;color:#1e293b;margin:0 0 1rem}.error-boundary-content>p{font-size:1.125rem;color:#64748b;margin:0 0 2rem}.error-details{text-align:left;margin:2rem 0;padding:1rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.error-details summary{cursor:pointer;font-weight:600;color:#475569;-webkit-user-select:none;user-select:none}.error-details pre{margin:1rem 0 0;padding:1rem;background:#fff;border-radius:4px;overflow-x:auto;font-size:.875rem;color:#dc2626;font-family:Courier New,monospace}.error-actions{margin:2rem 0}.error-help{font-size:.875rem;color:#94a3b8;margin:2rem 0 0}.error-help a{color:#3b82f6;text-decoration:none}.error-help a:hover{text-decoration:underline}@media(max-width:768px){.error-boundary-content{padding:2rem 1.5rem}.error-boundary-content h1{font-size:1.5rem}}
