.header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:none;padding:1rem 2rem;box-shadow:0 2px 8px #0003}.header-content{width:100%;display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.header-left{display:flex;align-items:center;gap:2rem}.header-title{margin:0;font-size:1.5rem;color:#fff;font-weight:600;text-decoration:none}.header-nav{display:flex;gap:1.5rem}.header-nav-link{color:#fff;text-decoration:none;font-weight:500;opacity:.9;transition:opacity .2s}.header-nav-link:hover{opacity:1}.header-right{display:flex;align-items:center;gap:1rem}.header-user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(102,126,234,.3)}.header-user-placeholder{width:40px;height:40px;border-radius:50%;background:#ffffff4d;border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:#fff}.header-user-info{text-align:left}.header-user-name{font-weight:600;font-size:.95rem;color:#fff}.header-user-email{font-size:.8rem;opacity:.9;color:#fff}.header-button{padding:.5rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:.5rem}.header-logout-button{margin-left:.5rem}.header-hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:.5rem}.header-hamburger span{display:block;width:24px;height:3px;background:#fff;border-radius:2px;transition:all .3s}.header-mobile-menu{display:none;flex-direction:column;background:#0003;border-top:1px solid rgba(255,255,255,.1);padding:1rem 2rem}.header-mobile-link{color:#fff;text-decoration:none;padding:.75rem 0;font-weight:500;border-bottom:1px solid rgba(255,255,255,.1)}.header-mobile-link:last-child{border-bottom:none}@media(max-width:768px){.header{padding:.75rem 1rem}.header-left{gap:1rem}.header-title{font-size:1.25rem}.header-nav{display:none}.header-hamburger,.header-mobile-menu{display:flex}.header-nav-link{font-size:.9rem}.header-user-info{display:none}.header-user-avatar,.header-user-placeholder{width:36px;height:36px}.header-button{padding:.5rem .75rem;font-size:.9rem}.header-right{gap:.5rem}}@media(max-width:480px){.header{padding:.5rem .75rem}.header-left{gap:.5rem}.header-title{font-size:1.1rem}.header-user-avatar,.header-user-placeholder{width:32px;height:32px}.header-button{padding:.4rem .6rem;font-size:.85rem}.header-mobile-menu{padding:1rem}}.entry-container{padding:2rem;max-width:600px;margin:0 auto}.entry-title{margin-bottom:1rem;color:#667eea}.entry-description{margin-bottom:2rem;opacity:.8}.entry-card{display:flex;gap:1rem;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.entry-input{flex:1;padding:.75rem;border-radius:6px;border:2px solid #e0e0e0;font-size:1rem;transition:border-color .2s}.entry-input:focus{border-color:#667eea;outline:none}.entry-button{padding:.75rem 2rem;background:#667eea!important;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s;display:flex;align-items:center;gap:.5rem;justify-content:center}.entry-button:disabled{background:#b3c5ff!important;cursor:not-allowed;opacity:.7}.entry-button:not(:disabled):hover{background:#5568d3!important;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.document-page{padding:2rem;max-width:1600px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{color:#667eea;font-size:2rem;margin-bottom:.5rem}.page-header p{color:#666;font-size:1rem}.document-loader{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.loader-form{display:flex;gap:1rem;align-items:flex-end}.form-group{flex:1}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.load-button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.load-button:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.load-button:disabled{background:#ccc;cursor:not-allowed}.document-content{display:flex;flex-direction:column;gap:1.5rem}.common-info{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.common-info h2{color:#667eea;font-size:1.5rem;margin-bottom:1rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-weight:500;color:#666;font-size:.875rem}.info-value{color:#333;font-size:1rem}.document-details{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.line-items-section,.structured-text-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.line-items-section h3,.structured-text-section h3{color:#667eea;font-size:1.25rem;margin-bottom:1rem}.table-container{overflow:auto;max-height:400px;border:1px solid #e0e0e0;border-radius:6px}.line-items-table{width:100%;border-collapse:collapse;font-size:.9rem}.line-items-table thead{position:sticky;top:0;background:#667eea1a;z-index:1}.line-items-table th{padding:.75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.line-items-table td{padding:.75rem;border-bottom:1px solid #f0f0f0;color:#666}.line-items-table tr:hover{background:#667eea0d}.line-items-table tr:last-child td{border-bottom:none}.structured-text-area{width:100%;min-height:400px;padding:1rem;border:1px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;resize:vertical;background:#667eea0d;color:#333}.structured-text-area:focus{outline:none;border-color:#667eea;background:#667eea0d}.download-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:center}.download-button{padding:1rem 3rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.75rem}.download-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.download-button:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:6px;border-left:4px solid #c33;margin-bottom:1rem}.loading-message{background:#eff6ff;color:#1e40af;padding:1rem;border-radius:6px;border-left:4px solid #1e40af;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.loading-spinner{width:20px;height:20px;border:3px solid #bfdbfe;border-top-color:#1e40af;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.document-details{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.document-page{padding:1.5rem}}@media(max-width:768px){.document-page{padding:1rem}.page-header h1{font-size:1.5rem}.common-info,.line-items-section,.structured-text-section{padding:1rem}.common-info h2{font-size:1.25rem}.line-items-section h3,.structured-text-section h3{font-size:1.1rem}.info-grid{grid-template-columns:1fr}.line-items-table{font-size:.8rem}.line-items-table th,.line-items-table td{padding:.5rem}.structured-text-area{font-size:.8rem;min-height:300px}.document-details{grid-template-columns:1fr}}@media(max-width:480px){.document-page{padding:.75rem}.page-header h1{font-size:1.25rem}.common-info,.line-items-section,.structured-text-section{padding:.75rem}.line-items-table th,.line-items-table td{padding:.4rem;font-size:.75rem}}@media(prefers-color-scheme:dark){.common-info,.line-items-section,.structured-text-section{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.common-info h2,.line-items-section h3,.structured-text-section h3{color:#667eea}.info-label{color:#ffffffb3}.info-value,.line-items-table th{color:#ffffffde}.line-items-table td{color:#ffffffb3}.structured-text-area{background:#667eea1a;color:#ffffffde;border-color:#667eea4d}.table-container{border-color:#ffffff1a}.line-items-table th{border-bottom-color:#fff3}.line-items-table td{border-bottom-color:#ffffff1a}.entry-card{background:#ffffff0d;box-shadow:0 2px 8px #0000004d}.entry-input{background:#ffffff0d;border-color:#fff3;color:#ffffffde}.entry-input::placeholder{color:#ffffff80}.entry-input:focus{border-color:#667eea;background:#ffffff14}}@media(max-width:768px){.entry-container{padding:1rem}.entry-card{padding:1.5rem;flex-direction:column}.entry-button{padding:.75rem;width:100%}}@media(max-width:480px){.entry-container{padding:.75rem}.entry-card{padding:1rem}.entry-title{font-size:1.5rem}.entry-description{font-size:.9rem}}.invoice-header-card{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a;width:100%}.invoice-header-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.5rem}.invoice-header-top h2{margin:0;color:#667eea}.invoice-number{font-size:1.1rem;font-weight:600;color:#333}.invoice-header-content{display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap}.invoice-fields{display:flex;gap:3rem;flex:1}.invoice-field{display:flex;flex-direction:column}.invoice-field-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.invoice-field-value{font-weight:600;color:#333;font-size:1.1rem}.invoice-total{text-align:right}.invoice-total-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.invoice-total-value{font-weight:700;font-size:1.75rem;color:#667eea}.invoice-details-grid{display:grid;grid-template-columns:3fr 2fr;gap:2rem;margin-bottom:2rem;width:100%}.invoice-line-items-card{background:#fff;border-radius:12px;padding:2rem;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000001a}.invoice-line-items-card h3{margin-bottom:1rem;color:#667eea}.invoice-full-text-card{background:#fff;border-radius:12px;padding:2rem;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000001a}.invoice-full-text-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.invoice-full-text-header h3{margin:0;color:#667eea}.invoice-download-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.invoice-download-btn:hover{background:#5568d3;transform:translateY(-1px)}.invoice-table-container{overflow-y:auto;max-height:500px;border:1px solid #e0e0e0;border-radius:6px}.invoice-table{width:100%;border-collapse:collapse}.invoice-table th{position:sticky;top:0;background:#f8f9fa;padding:.75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;z-index:1}.invoice-table td{padding:.75rem;border-bottom:1px solid #f0f0f0;color:#666}.invoice-table tr:hover{background:#667eea0d}.invoice-table tr:last-child td{border-bottom:none}.invoice-textarea{width:100%;min-height:400px;padding:1rem;border:1px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;resize:vertical;background:#667eea0d;color:#333}.invoice-textarea:focus{outline:none;border-color:#667eea;background:#667eea0d}@media(prefers-color-scheme:dark){.invoice-header-card,.invoice-line-items-card,.invoice-full-text-card{background:#ffffff0d;box-shadow:0 2px 8px #0000004d}.invoice-number,.invoice-field-value{color:#ffffffde}.invoice-field-label,.invoice-total-label{color:#ffffffb3}.invoice-table th{background:#667eea33;color:#ffffffde;border-bottom-color:#fff3}.invoice-table td{color:#ffffffb3;border-bottom-color:#ffffff1a}.invoice-table tr:hover{background:#667eea1a}.invoice-table-container{border-color:#ffffff1a}.invoice-textarea{background:#667eea1a;color:#ffffffde;border-color:#667eea4d}}@media(max-width:768px){.invoice-details-grid{grid-template-columns:1fr}.invoice-header-card{padding:1.5rem}.invoice-header-content{flex-direction:column;gap:1.5rem}.invoice-fields{flex-direction:column;gap:1rem}.invoice-total{text-align:left}.invoice-line-items-card,.invoice-full-text-card{padding:1.5rem}.invoice-table th,.invoice-table td{padding:.5rem;font-size:.875rem}.invoice-textarea{min-height:300px;font-size:.8rem}}@media(max-width:480px){.invoice-header-card{padding:1rem}.invoice-header-top{flex-direction:column;align-items:flex-start;gap:.5rem}.invoice-header-top h2{font-size:1.25rem}.invoice-number,.invoice-field-value{font-size:1rem}.invoice-total-value{font-size:1.5rem}.invoice-line-items-card,.invoice-full-text-card{padding:1rem}.invoice-table th,.invoice-table td{padding:.4rem;font-size:.75rem}.invoice-textarea{min-height:250px}}:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color-scheme:light dark;color:#ffffffde;background-color:#242424}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.app{flex:1;display:flex;flex-direction:column}.app-main{width:100%;padding:2rem;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;flex:1}.welcome-card{background:#667eea0d;border:1px solid rgba(102,126,234,.2);border-radius:12px;padding:2rem;text-align:center;box-shadow:0 2px 8px #0000001a;margin:2rem 2rem 0}.welcome-card h2{font-size:2rem;margin-bottom:.5rem}.welcome-card p{opacity:.7;font-size:1.1rem}.card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #667eea4d}.card h2{font-size:1.5rem;margin-bottom:1rem}.status-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.status-item:last-child{border-bottom:none}.label{font-weight:600;opacity:.7}.value{color:#667eea;font-weight:500}.loading{color:orange}.error{color:#ff6b6b;font-weight:500}.api-response .message{font-size:1.2rem;margin-bottom:.5rem}.success{color:#51cf66;font-weight:500}.features-list{list-style:none;padding:0}.features-list li{padding:.75rem 0 .75rem 1.5rem;position:relative}.features-list li:before{content:"→";position:absolute;left:0;color:#667eea}.app-footer{text-align:center;opacity:.6;padding:2rem 0;border-top:1px solid rgba(255,255,255,.1);margin-top:2rem}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#f5f5f5}.card{background:#fff;border:1px solid rgba(0,0,0,.1)}}@media(max-width:1024px){.app-main{grid-template-columns:1fr 1fr;padding:1.5rem}.welcome-card{margin:1.5rem}}@media(max-width:768px){.app-main{grid-template-columns:1fr;padding:1rem}.welcome-card{margin:1rem;padding:1.5rem}.welcome-card h2{font-size:1.5rem}.welcome-card p{font-size:1rem}.card h2{font-size:1.25rem}}
