:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}body{color:#213547}a:hover{color:#747bff}button{background-color:#f9f9f9;color:#213547}}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;width:100%}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--error: #ef4444;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;background:#fff;color:var(--gray-900);line-height:1.6}.app{min-height:100vh;width:100%;display:flex;flex-direction:column;overflow-x:hidden}.container{width:100%;max-width:100%;padding:0 3rem}.header{background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;width:100%}.header-content{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 3rem;max-width:100%}.logo{display:flex;align-items:center;gap:.75rem}.logo-text{font-size:1.25rem;font-weight:700;color:var(--gray-900)}.user-section{display:flex;align-items:center;gap:1rem}.credits-badge{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:.625rem 1rem;border-radius:8px;border:2px solid #fbbf24;box-shadow:0 2px 8px #fbbf2433;height:fit-content}.credits-amount{font-weight:700;font-size:1.125rem;color:#b45309}.credits-label{font-size:.875rem;color:#92400e;font-weight:600}.user-badge{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;font-size:.875rem;color:var(--gray-900)}.user-count{font-size:.75rem;color:var(--gray-500)}.btn-logout,.btn-header{padding:.625rem 1.25rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-logout{background:var(--gray-100);color:var(--gray-700)}.btn-logout:hover{background:var(--gray-200)}.btn-header{background:var(--primary);color:#fff}.btn-header:hover{background:var(--primary-dark)}.btn-header-action{padding:.625rem 1rem;border:1px solid var(--gray-200);border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem;background:#fff;color:var(--gray-700);display:flex;align-items:center;gap:.5rem}.btn-header-action:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary)}.warning-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 6px #ef444400}}.hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:4rem 0 6rem;color:#fff;width:100%;overflow:hidden}.hero-wrapper{max-width:100%;margin:0 auto;padding:0}.hero-content{margin-bottom:4rem}.hero-text{max-width:900px;margin:0 auto;text-align:center}.hero-title{font-size:4rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem}.gradient-text{background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.5rem;opacity:.95;margin-bottom:2.5rem;line-height:1.7}.hero-actions{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.btn{padding:.875rem 1.75rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;font-size:1rem}.btn-large{padding:1.25rem 2.5rem;font-size:1.125rem}.btn-primary{background:#fff;color:var(--primary)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #0003}.btn-secondary{background:#ffffff26;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3)}.btn-secondary:hover{background:#ffffff40}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.process-showcase{margin-top:4rem}.showcase-grid{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}.showcase-card{position:relative;width:300px;background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;overflow:hidden;border:2px solid rgba(255,255,255,.2);transition:all .4s cubic-bezier(.4,0,.2,1);animation:slideInUp .8s ease-out;animation-fill-mode:both}.showcase-card.card-1{animation-delay:.1s}.showcase-card.card-2{animation-delay:.3s}.showcase-card.card-3{animation-delay:.5s}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.showcase-card:hover{transform:translateY(-10px) scale(1.02);border-color:#fff6;box-shadow:0 30px 60px #0000004d}.card-number{position:absolute;top:1rem;left:1rem;width:40px;height:40px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.25rem;z-index:10;box-shadow:0 4px 12px #fbbf2480}.card-image-wrapper{position:relative;width:100%;height:200px;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.showcase-card:hover .card-image{transform:scale(1.1)}.card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.4) 100%)}.card-content{padding:1.5rem;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card-content h3{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.card-content p{font-size:.95rem;opacity:.9;line-height:1.5}.showcase-arrow{animation:pulse 2s ease-in-out infinite;opacity:.8}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.camera-section{padding:6rem 0;background:var(--gray-50);width:100%}.camera-container{width:100%;max-width:1200px;margin:0 auto}.camera-feed{width:100%;border-radius:16px;box-shadow:0 20px 50px #00000026}.camera-controls{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem}.btn-capture{width:80px;height:80px;border-radius:50%;background:#fff;border:5px solid var(--primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-capture:hover{transform:scale(1.1)}.capture-inner{width:60px;height:60px;border-radius:50%;background:var(--primary)}.preview-section{padding:6rem 0;background:var(--gray-50);width:100%}.preview-card{background:#fff;border-radius:20px;padding:4rem;box-shadow:0 4px 20px #00000014;width:100%;max-width:1400px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:3rem;color:var(--gray-900)}.preview-content{width:100%;max-width:1000px;margin:0 auto 3rem;border-radius:12px;overflow:hidden;box-shadow:0 8px 30px #0000001f}.preview-image{width:100%;display:block}.pdf-indicator{background:var(--gray-100);padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--gray-600)}.filename{font-weight:600;color:var(--gray-700);font-size:1.125rem}.preview-actions{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.spinner{width:20px;height:20px;border:3px solid rgba(99,102,241,.3);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.result-section{padding:6rem 0;background:var(--gray-50);width:100%}.result-card{background:#fff;border-radius:20px;padding:4rem;box-shadow:0 4px 20px #00000014;width:100%;max-width:1400px;margin:0 auto}.success-header{display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;padding:2rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:12px;margin-bottom:3rem}.success-icon{width:56px;height:56px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.success-title{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:.25rem}.success-subtitle{color:var(--gray-600);font-size:1rem}.btn-download{background:var(--primary);color:#fff;padding:1.125rem 2.5rem}.btn-download:hover{background:var(--primary-dark);transform:translateY(-2px)}.quote-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem;margin-bottom:3rem}.quote-section{background:var(--gray-50);padding:2rem;border-radius:12px}.full-width{grid-column:1 / -1}.section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);margin-bottom:1.5rem}.client-name{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.client-address{color:var(--gray-600);font-size:1.125rem}.items-list{display:flex;flex-direction:column;gap:1rem}.item-row{display:grid;grid-template-columns:2fr auto auto;gap:2rem;padding:1.25rem;background:#fff;border-radius:8px;align-items:center}.item-description{font-weight:500;color:var(--gray-900);font-size:1.125rem}.item-quantity{color:var(--gray-600);font-size:1rem}.item-price{font-weight:700;color:var(--gray-900);font-size:1.125rem}.totals{background:#fff}.total-line{display:flex;justify-content:space-between;padding:1rem 0;color:var(--gray-700);font-size:1.125rem}.total-final{padding-top:1.5rem;border-top:3px solid var(--gray-200);margin-top:1rem;font-size:2rem;font-weight:700;color:var(--gray-900)}.btn-full{width:100%;justify-content:center}.result-actions{padding:2rem 0 0;display:flex;flex-direction:column;gap:1rem;align-items:stretch}.features{padding:8rem 0;background:#fff;width:100%}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4rem;max-width:1400px;margin:0 auto}.feature{text-align:center}.feature-icon{width:90px;height:90px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff}.feature h3{font-size:1.75rem;margin-bottom:1rem;color:var(--gray-900)}.feature p{color:var(--gray-600);line-height:1.7;font-size:1.125rem}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:20px;padding:2.5rem;max-width:480px;width:100%;position:relative;box-shadow:0 20px 50px #0000004d}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-600);transition:all .2s}.modal-close:hover{background:var(--gray-100)}.modal-header{margin-bottom:2rem}.modal-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--gray-900)}.modal-header p{color:var(--gray-600)}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.25rem;background:var(--gray-100);border-radius:12px}.tab{flex:1;padding:.75rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-weight:600;color:var(--gray-600);transition:all .2s}.tab.active{background:#fff;color:var(--gray-900);box-shadow:0 2px 4px #00000014}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.25rem}.auth-form input{padding:1rem;border:2px solid var(--gray-200);border-radius:10px;font-size:1rem;transition:all .2s;color:#111827;background:#fff;font-weight:500}.auth-form input::placeholder{color:#9ca3af;font-weight:400}.auth-form input:focus{outline:none;border-color:var(--primary);background:#fff}.auth-form input.input-error{border-color:var(--error)}.auth-form input.input-error:focus{border-color:var(--error);box-shadow:0 0 0 3px #ef44441a}.error-text{color:var(--error);font-size:.75rem;font-weight:500;padding-left:.25rem}.alert{padding:1rem;border-radius:10px;display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.alert-error{background:#fee2e2;color:#991b1b}@media (max-width: 1200px){.showcase-grid{flex-direction:column}.showcase-arrow{transform:rotate(90deg)}.showcase-card{width:100%;max-width:400px}.features-grid{grid-template-columns:1fr;gap:3rem}}@media (max-width: 968px){.hero-title{font-size:3rem}.hero-subtitle{font-size:1.25rem}.success-header{grid-template-columns:1fr;text-align:center}.success-icon{margin:0 auto}.quote-grid{grid-template-columns:1fr}}@media (max-width: 768px){.container{padding:0 1rem}.header-content{padding:1rem;flex-wrap:wrap;gap:.75rem}.logo-text{font-size:1rem}.user-section{flex-wrap:wrap;gap:.5rem;width:100%;justify-content:space-between}.credits-badge{padding:.375rem .75rem;font-size:.75rem;gap:.375rem}.credits-amount{font-size:.875rem}.credits-label{font-size:.75rem}.btn-header,.btn-logout,.btn-header-action{padding:.5rem .875rem;font-size:.75rem}.btn-icon{width:36px;height:36px}.hero{padding:2rem 0 3rem}.hero-wrapper{padding:0 1rem}.hero-title{font-size:1.75rem;line-height:1.2}.hero-subtitle{font-size:.95rem;margin-bottom:1.5rem}.hero-actions{gap:.75rem}.btn-large{padding:.875rem 1.5rem;font-size:.95rem}.camera-section,.preview-section,.result-section,.features{padding:2.5rem 1rem}.preview-card,.result-card{padding:1.5rem}.section-title{font-size:1.75rem;margin-bottom:2rem}.item-row{grid-template-columns:1fr;gap:.5rem;padding:1rem}.user-badge{display:none}.showcase-card{width:100%}.modal{padding:1.5rem;margin:.5rem}.modal-header h2{font-size:1.5rem}.auth-form input{padding:.875rem;font-size:.95rem}.settings-modal,.settings-modal-large{max-width:calc(100vw - 2rem);margin:1rem}.quote-grid{grid-template-columns:1fr;gap:1.5rem}.success-header{padding:1.5rem;gap:1rem}.success-title{font-size:1.25rem}.btn-download{padding:.875rem 1.5rem;font-size:.95rem}}@media (max-width: 480px){.header-content{padding:.75rem}.logo-text{font-size:.875rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.875rem}.hero-actions{flex-direction:column;width:100%}.btn-large{width:100%;justify-content:center}.modal{padding:1rem;border-radius:12px}.preview-card,.result-card{padding:1rem}.section-title{font-size:1.5rem}.showcase-card{max-width:100%}.card-content{padding:1rem}.card-content h3{font-size:1.25rem}}.settings-modal{max-width:700px;max-height:90vh;overflow-y:auto;color:var(--gray-900)}.settings-content{padding:2rem}.settings-section{margin-top:2.5rem}.settings-section h3{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:#111827}.info-grid{display:grid;gap:1rem;background:#f9fafb;padding:1.5rem;border-radius:12px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.info-item:last-child{border-bottom:none}.info-label{font-weight:500;color:#6b7280;font-size:.875rem}.info-item strong{color:#111827;font-weight:600}.btn-icon{background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#6b7280}.btn-icon:hover{background:#f9fafb;border-color:#6366f1;color:#6366f1;transform:translateY(-2px)}.user-section{display:flex;align-items:center;gap:.75rem}.settings-modal-large{max-width:900px;width:100%;padding:0;max-height:90vh;overflow:hidden;color:var(--gray-900)}.template-preview-full{width:100%;max-width:800px;margin:0 auto;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.preview-header-full{padding:2rem;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.preview-logo-full{width:100px;height:60px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.875rem}.preview-company-info{text-align:right}.preview-company-info h2{margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.preview-company-info p{margin:.25rem 0;font-size:.875rem}.preview-content-full{padding:2rem;display:flex;flex-direction:column;gap:2rem}.preview-title-section h1{margin:0 0 .5rem;font-size:2rem;font-weight:700}.preview-title-section p{margin:.25rem 0;font-size:.875rem}.preview-client-section h3,.preview-items-section h3,.preview-conditions-section h3{margin:0 0 1rem;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.preview-client-section p{margin:.25rem 0;font-size:.875rem}.preview-table-full{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table-full th,.preview-table-full td{padding:.75rem 1rem;text-align:left}.preview-table-full thead th{font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.preview-table-full tbody tr{border-bottom:1px solid #e5e7eb}.preview-table-full tbody tr:last-child{border-bottom:none}.preview-table-full td:last-child,.preview-table-full th:last-child{text-align:right}.preview-totals-section{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.preview-totals-line{display:flex;justify-content:space-between;padding:.75rem 1rem;font-size:.875rem}.preview-total-final{margin-top:.5rem;padding:1rem;border-radius:4px}.preview-conditions-section p{margin:.5rem 0;font-size:.875rem;line-height:1.6}.preview-conditions-section strong{font-weight:600}.preview-signature-section{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem;padding-top:2rem;border-top:1px solid #e5e7eb}.signature-box{display:flex;flex-direction:column;gap:1rem}.signature-box h4{margin:0;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.signature-line{height:80px;border-bottom:2px solid #d1d5db;margin-top:1rem}.stamp-placeholder{width:100px;height:100px;border:2px dashed #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:.5rem}.template-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem}.template-modal{background:#fff;border-radius:20px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.template-modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #e5e7eb}.template-modal-header h2{font-size:1.75rem;margin:0}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#6b7280;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;padding:2rem}.template-card{border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;background:#fff}.template-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #00000026}.template-card.selected{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.template-preview{height:250px;padding:1rem;display:flex;flex-direction:column;gap:.75rem;position:relative;cursor:pointer}.preview-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:opacity .3s;border-radius:4px}.preview-overlay span{color:#fff;font-weight:600;font-size:1rem}.template-preview:hover .preview-overlay{opacity:1}.preview-header{height:40px;border-radius:4px;display:flex;align-items:center;padding:0 1rem}.preview-logo{width:60px;height:20px;background:#ffffff4d;border-radius:2px}.preview-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.preview-line{height:8px;border-radius:2px;width:80%}.preview-line.short{width:50%}.preview-table{flex:1;display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.preview-row{height:20px;background:#f3f4f6;border-radius:2px}.preview-total{text-align:right;font-weight:700;font-size:1.25rem;margin-top:.5rem}.template-info{padding:1.5rem;border-top:1px solid #e5e7eb}.template-info h3{font-size:1.25rem;margin:0 0 .5rem;color:#111827}.template-info p{color:#6b7280;margin:0 0 1rem;font-size:.875rem}.btn-select{padding:.5rem 1rem;border:2px solid #6366f1;border-radius:8px;background:#fff;color:#6366f1;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem;width:100%}.btn-select:hover{background:#6366f1;color:#fff}.btn-select.selected{background:#10b981;border-color:#10b981;color:#fff}.template-preview-container{padding:2rem;max-height:70vh;overflow-y:auto}.btn-back{padding:.75rem 1.5rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;transition:all .2s}.btn-back:hover{background:#f9fafb;border-color:#6366f1;color:#6366f1}.template-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:2rem;border-top:1px solid #e5e7eb}@media (max-width: 768px){.template-modal-overlay{padding:1rem}.template-modal{max-width:100%}.template-modal-header{padding:1.25rem}.template-modal-header h2{font-size:1.375rem}.template-grid{grid-template-columns:1fr;gap:1.5rem;padding:1.25rem}.template-preview{height:200px}.template-info,.template-preview-container{padding:1.25rem}.template-modal-footer{padding:1.25rem;flex-wrap:wrap}.template-modal-footer button{flex:1;min-width:120px}}@media (max-width: 480px){.template-modal-overlay{padding:.5rem}.template-modal-header{padding:1rem}.template-modal-header h2{font-size:1.125rem}.template-grid{padding:1rem;gap:1rem}.template-preview{height:180px;padding:.75rem}.template-info{padding:1rem}.template-info h3{font-size:1.125rem}.template-preview-container{padding:1rem}.template-modal-footer{padding:1rem;flex-direction:column}.template-modal-footer button{width:100%}}.logo-uploader{margin:1.5rem 0}.logo-uploader label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151}.logo-upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.logo-upload-area:hover{border-color:#6366f1;background:#f9fafb}.logo-upload-area svg{margin:0 auto 1rem;color:#9ca3af}.logo-upload-area p{font-weight:600;color:#111827;margin:0 0 .25rem}.logo-upload-area span{font-size:.875rem;color:#6b7280}.logo-preview-container{position:relative;display:inline-block}.logo-preview{max-width:300px;max-height:150px;border-radius:8px;border:1px solid #e5e7eb}.btn-remove-logo{position:absolute;top:-10px;right:-10px;background:#ef4444;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0003;transition:all .2s}.btn-remove-logo:hover{background:#dc2626;transform:scale(1.1)}.uploading-text{margin-top:.5rem;color:#6366f1;font-size:.875rem}.company-settings{padding:2rem;max-height:85vh;overflow-y:auto}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.settings-header h2{font-size:1.75rem;font-weight:700;color:#111827;margin:0 0 .5rem}.settings-header p{color:#6b7280;margin:0;font-size:.875rem}.btn-close-settings{background:#f3f4f6;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#6b7280;flex-shrink:0}.btn-close-settings:hover{background:#e5e7eb;color:#111827;transform:scale(1.1)}.alert{padding:1rem 1.25rem;border-radius:12px;display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.875rem}.alert-success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.settings-form{display:flex;flex-direction:column;gap:2.5rem}.form-section{background:#f9fafb;padding:1.5rem;border-radius:12px;border:1px solid #e5e7eb}.section-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:500;color:#374151;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s;background:#fff;color:#111827;font-family:inherit}.form-group textarea{resize:vertical;min-height:60px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input::placeholder{color:#9ca3af}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-size:.875rem;border:none}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;pointer-events:none}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media (max-width: 768px){.company-settings{padding:1.5rem}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:1}.form-actions{flex-direction:column-reverse}.btn{width:100%;justify-content:center}}.history-modal{max-width:800px;max-height:80vh;width:90%;display:flex;flex-direction:column}.history-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.history-modal .modal-header h2{margin:0;font-size:1.5rem;color:#111827}.btn-close{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.btn-close:hover{background-color:#f3f4f6}.history-modal .modal-content{padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.history-modal .modal-content::-webkit-scrollbar{display:none}.history-modal .modal-content{-ms-overflow-style:none;scrollbar-width:none}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state svg{margin-bottom:1rem;color:#d1d5db}.quotes-list{display:grid;gap:1rem}.quote-card{border:1px solid #e5e7eb;border-radius:8px;background:#fff;overflow:hidden;transition:all .2s}.quote-card:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f126}.quote-card-content{padding:1.25rem;cursor:pointer}.btn-invoice{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;cursor:pointer;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.btn-invoice:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px)}.btn-invoice svg{flex-shrink:0}.quote-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.quote-card-header h3{margin:0;font-size:1.125rem;color:#111827}.quote-template{padding:.25rem .75rem;background:#f3f4f6;border-radius:12px;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:capitalize}.quote-card-body{margin-bottom:.75rem}.quote-card-body p{margin:.25rem 0;font-size:.875rem;color:#4b5563}.quote-card-footer{display:flex;justify-content:flex-end;padding-top:.75rem;border-top:1px solid #f3f4f6}.quote-date{font-size:.75rem;color:#9ca3af}.history-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem 0;border-bottom:2px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.875rem;font-weight:600;color:#6b7280;transition:all .2s;position:relative;top:2px}.tab-btn:hover{color:#6366f1;background:#6366f10d}.tab-btn.active{color:#6366f1;border-bottom-color:#6366f1;background:#fff}.tab-btn svg{flex-shrink:0}.invoice-card{border-left:4px solid #10b981}.invoice-card:hover{border-left-color:#059669}@media (max-width: 768px){.history-modal{max-width:95%;max-height:90vh}.history-modal .modal-header{padding:1rem}.history-modal .modal-header h2{font-size:1.25rem}.history-tabs{padding:.75rem 1rem 0}.tab-btn{padding:.5rem .75rem;font-size:.75rem;gap:.375rem}.tab-btn svg{width:18px;height:18px}.history-modal .modal-content{padding:1rem;max-height:calc(90vh - 120px)}.quote-card-content{padding:1rem}.quote-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.quote-card-header h3{font-size:1rem}.btn-invoice{padding:.625rem .875rem;font-size:.8125rem}}@media (max-width: 480px){.history-modal{width:calc(100vw - 2rem);margin:1rem}.history-modal .modal-header{padding:.75rem}.history-modal .modal-header h2{font-size:1.125rem}.history-tabs{padding:.5rem .75rem 0;gap:.25rem}.tab-btn{padding:.5rem .625rem;font-size:.75rem}.history-modal .modal-content{padding:.75rem}.quote-card-header h3{font-size:.9375rem}.quote-card-body p{font-size:.8125rem}}.credit-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.credit-modal{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.credit-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem;border-bottom:1px solid #e5e7eb}.credit-modal-header h2{margin:0 0 .5rem;color:#111827;font-size:1.5rem}.credit-modal-header p{margin:0;color:#6b7280;font-size:.875rem}.credit-modal-header p strong{color:#f59e0b;font-weight:700}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#9ca3af;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#111827}.credit-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;padding:2rem}.credit-plan{border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:1rem}.credit-plan:hover{border-color:#fbbf24;box-shadow:0 4px 12px #fbbf2433;transform:translateY(-2px)}.credit-plan.selected{border-color:#f59e0b;background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 8px 16px #fbbf244d}.credit-plan.popular{border-color:#6366f1}.credit-plan.popular:hover,.credit-plan.popular.selected{border-color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:0 8px 16px #6366f14d}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.plan-credits{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0}.credits-number{font-size:2rem;font-weight:700;color:#1f2937!important}.credits-text{font-size:.875rem;color:#4b5563!important;font-weight:600}.plan-price{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 0;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.price-amount{font-size:1.75rem;font-weight:700;color:#1f2937!important}.price-detail{font-size:.75rem;color:#6b7280!important}.plan-info{display:flex;flex-direction:column;gap:.5rem}.info-item{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.info-item svg{color:#10b981}.credit-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 16px 16px}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#f9fafb}.btn-primary{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.credit-plans{grid-template-columns:1fr}.credit-modal-footer{flex-direction:column}.btn{width:100%}}.quote-preview-container{width:100%;max-width:900px;margin:0 auto;padding:2rem}.quote-preview-document{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px #00000026}.quote-header{padding:clamp(1rem,3vw,2rem);display:flex;justify-content:space-between;align-items:flex-start;gap:clamp(1rem,3vw,2rem)}.header-logo-section{flex-shrink:0}.quote-logo{max-width:min(250px,30vw);max-height:min(150px,15vh);min-width:120px;width:auto;height:auto;object-fit:contain}.quote-logo-placeholder{width:min(180px,25vw);height:min(100px,12vh);min-width:100px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:clamp(.875rem,2vw,1.25rem)}.header-company-info{text-align:right;flex:1}.header-company-info h2{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:700}.header-company-info p{font-size:clamp(.75rem,1.5vw,.95rem)}.quote-title-section,.quote-client-section,.quote-items-section,.quote-totals-section,.quote-conditions-section,.quote-signatures-section,.quote-notes-section{padding:1.5rem 2rem}.quote-title-section h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.quote-client-section h3,.quote-items-section h3,.quote-conditions-section h3{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}.quote-client-section p{margin:.25rem 0;font-size:.875rem}.quote-table{width:100%;border-collapse:collapse;margin-top:1rem}.quote-table th,.quote-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}.quote-table thead th{font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.quote-table tbody tr:last-child td{border-bottom:none}.quote-totals-section{display:flex;flex-direction:column;gap:.75rem;margin-left:auto;max-width:400px}.totals-line{display:flex;justify-content:space-between;padding:.75rem 1rem;font-size:.875rem}.total-final{margin-top:.5rem;padding:1rem;border-radius:4px}.quote-conditions-section p{margin:.5rem 0;font-size:.875rem;line-height:1.6}.quote-signatures-section{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;border-top:2px solid #e5e7eb;padding-top:2rem}.signature-box h4{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.signature-space{height:80px;border-bottom:2px solid #d1d5db;margin-top:1rem}.quote-stamp{max-width:min(180px,25vw);max-height:min(180px,25vw);min-width:80px;min-height:80px;width:auto;height:auto;object-fit:contain;margin-top:.5rem}.stamp-placeholder{width:min(140px,20vw);height:min(140px,20vw);min-width:80px;min-height:80px;border:2px dashed #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:.5rem;font-size:clamp(.75rem,1.5vw,1rem);font-weight:700}.quote-notes-section{padding-top:1rem;margin-top:1rem}.quote-edit-controls{display:flex;justify-content:flex-end;margin-bottom:1rem;gap:.5rem}.edit-actions{display:flex;gap:.5rem}.btn-edit{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#6366f1;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-save{padding:.625rem 1.25rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover{background:#059669}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{padding:.625rem 1.25rem;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#dc2626}.btn-add-item{padding:.5rem 1rem;background:transparent;border:2px dashed currentColor;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-add-item:hover{background:#6366f11a}.btn-delete-item{padding:.5rem;background:#ef44441a;border:1px solid #ef4444;color:#ef4444;cursor:pointer;transition:all .2s;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.btn-delete-item:hover{background:#ef4444;color:#fff;transform:scale(1.1)}.btn-add-description{padding:.25rem .5rem;background:transparent;border:1px dashed #6366f1;border-radius:4px;color:#6366f1;font-size:.75rem;cursor:pointer;transition:all .2s}.btn-add-description:hover{background:#6366f11a;border-style:solid}.quote-edit-input,.quote-edit-textarea{width:100%;padding:.5rem;border:2px solid #e5e7eb;border-radius:4px;font-size:.875rem;color:#111827;background:#fff;transition:border-color .2s}.quote-edit-input:focus,.quote-edit-textarea:focus{outline:none;border-color:#6366f1}.quote-edit-input-inline{padding:.25rem .5rem;border:1px solid #e5e7eb;border-radius:4px;font-size:.875rem;color:#111827;background:#fff}.quote-edit-input-inline:focus{outline:none;border-color:#6366f1}.draggable-image{position:relative;display:inline-block}.draggable-image.editable{-webkit-user-select:none;user-select:none}.draggable-image.editable:hover{border-color:#6366f1!important}.resize-handle{position:absolute;width:10px;height:10px;background:#6366f1;border:2px solid white;border-radius:50%;cursor:nwse-resize;z-index:10}.resize-handle:hover{background:#4f46e5;transform:scale(1.3)}.corner-tl{top:-5px;left:-5px;cursor:nwse-resize}.corner-tr{top:-5px;right:-5px;cursor:nesw-resize}.corner-bl{bottom:-5px;left:-5px;cursor:nesw-resize}.corner-br{bottom:-5px;right:-5px;cursor:nwse-resize}@media print{.quote-edit-controls,.btn-edit,.btn-save,.btn-cancel,.btn-add-item,.btn-delete-item,.btn-add-description,.resize-handle,.edit-actions{display:none!important}.draggable-image{border:none!important}.quote-preview-document{box-shadow:none!important;border:none!important}.quote-title-section,.quote-client-section,.quote-items-section,.quote-totals-section,.quote-signatures-section{padding:.5rem 1rem!important}.quote-header{padding:.75rem 1rem!important}.quote-header h2{font-size:1rem!important;margin:0!important}.quote-header p{font-size:.7rem!important;margin:.1rem 0!important}.quote-title-section h1{font-size:1.5rem!important;margin-bottom:.25rem!important}.quote-title-section p{font-size:.75rem!important}.quote-client-section h3,.quote-items-section h3{font-size:.75rem!important;margin-bottom:.5rem!important}.quote-client-section p{font-size:.75rem!important;margin:.15rem 0!important}.quote-table th,.quote-table td{padding:.35rem .5rem!important;font-size:.75rem!important}.quote-table th{font-size:.7rem!important}.totals-line{padding:.4rem .75rem!important;font-size:.75rem!important}.total-final{padding:.6rem .75rem!important}.total-final span:first-child{font-size:.9rem!important}.total-final span:last-child{font-size:1.1rem!important}.quote-signatures-section{padding-top:.75rem!important}.signature-box h4{font-size:.7rem!important;margin-bottom:.25rem!important}.signature-box p{font-size:.65rem!important}.signature-space{height:50px!important;margin-top:.5rem!important}.quote-stamp{max-width:100px!important;max-height:100px!important}.quote-footer{font-size:.65rem!important;padding-top:.5rem!important;margin-top:1rem!important}.quote-footer div{margin-bottom:.15rem!important}}@media (max-width: 768px){.quote-preview-container{padding:1rem}.quote-header{flex-direction:column;align-items:center;text-align:center}.header-company-info{text-align:center}.quote-signatures-section{grid-template-columns:1fr}.quote-table{font-size:.75rem}.quote-table th,.quote-table td{padding:.5rem}}.payment-success-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.payment-success-overlay.fade-out{animation:fadeOut .5s ease-out;opacity:0}.payment-success-card{background:#fff;border-radius:24px;padding:3rem 2rem;max-width:400px;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .5s ease-out;position:relative;z-index:10001}.success-icon{margin:0 auto 1.5rem;width:80px;height:80px}.checkmark{width:80px;height:80px;border-radius:50%;display:block;stroke-width:3;stroke:#10b981;stroke-miterlimit:10;box-shadow:inset 0 0 #10b981;animation:fill .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both}.checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:3;stroke-miterlimit:10;stroke:#10b981;fill:none;animation:stroke .6s cubic-bezier(.65,0,.45,1) forwards}.checkmark-check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:stroke .3s cubic-bezier(.65,0,.45,1) .8s forwards}.success-title{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem}.payment-credits-badge{display:inline-flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#fbbf24,#f59e0b);padding:1.5rem 2.5rem;border-radius:16px;margin-bottom:1.5rem;box-shadow:0 10px 25px -5px #fbbf2466;animation:pulse 2s ease-in-out infinite}.payment-credits-number{font-size:3rem;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.1)}.payment-credits-label{font-size:1rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.05em}.success-message{color:#6b7280;font-size:1rem;margin-bottom:2rem}.btn-close-success{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:.875rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #6366f14d}.btn-close-success:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #6366f166}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10000;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;top:-10px;opacity:0;animation:confetti-fall 3s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes stroke{to{stroke-dashoffset:0}}@keyframes scale{0%,to{transform:none}50%{transform:scale3d(1.1,1.1,1)}}@keyframes fill{to{box-shadow:inset 0 0 0 30px #10b981}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.footer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 1rem;margin-top:auto;width:100%}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-section p{margin:0;font-size:.9rem}.footer-links{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.footer-link{background:none;border:none;color:#fff;cursor:pointer;font-size:.9rem;text-decoration:none;transition:opacity .3s ease;padding:.25rem .5rem}.footer-link:hover{opacity:.8;text-decoration:underline}.footer-separator{color:#fff9;font-size:.9rem}@media (min-width: 768px){.footer-content{flex-direction:row;justify-content:space-between}}@media (max-width: 767px){.footer{padding:1.5rem 1rem}.footer-section p{font-size:.85rem;text-align:center}.footer-links{font-size:.85rem}}.legal-modal{max-width:900px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.legal-content{flex:1;overflow-y:auto;padding:2rem;line-height:1.6}.legal-content section{margin-bottom:2rem}.legal-content h3{color:#667eea;margin-bottom:1rem;font-size:1.3rem;font-weight:600}.legal-content p{margin-bottom:1rem;color:#374151}.legal-content ul{margin-left:1.5rem;margin-bottom:1rem}.legal-content li{margin-bottom:.5rem;color:#374151}.legal-content strong{color:#1f2937;font-weight:600}.legal-date{text-align:center;font-size:.9rem;color:#6b7280;margin-top:2rem;padding-top:1rem;border-top:1px solid #e5e7eb}@media (max-width: 768px){.legal-modal{width:100%;max-height:100vh;border-radius:0}.legal-content{padding:1.5rem}.legal-content h3{font-size:1.1rem}}.legal-content::-webkit-scrollbar{width:8px}.legal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.legal-content::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.legal-content::-webkit-scrollbar-thumb:hover{background:#555}
