.app{min-height:100vh;display:flex;flex-direction:column}.top-bar{position:sticky;top:0;z-index:200;display:flex;justify-content:flex-end;align-items:center;padding:.4rem .75rem;background:transparent;min-height:44px}.language-switcher{display:flex;gap:.25rem;align-items:center}.lang-btn{background:none;border:none;padding:.2rem .3rem;cursor:pointer;border-radius:6px;line-height:1;opacity:.55;transition:opacity .2s,transform .15s;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.lang-btn img{display:block;border-radius:2px}.lang-btn:hover{opacity:.8}.lang-btn.active{opacity:1;transform:scale(1.15);filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}.app-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem 2rem;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:center;align-items:center}.app-header h1{color:#333;font-size:2rem;font-weight:700;margin:0}.app-main{flex:1}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#f44;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;margin:1rem 2rem 0;border-radius:8px}.error-banner button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0 .5rem}.error-banner button:hover{opacity:.8}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}@media (max-width: 768px){.app-header{padding:1rem}.app-header h1{font-size:1.5rem}.lang-btn img{width:20px;height:15px}}.gift-card-form-container{display:flex;justify-content:center;width:100%}.form-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000026;width:100%;max-width:600px}.form-card h2{color:#333;margin-bottom:2rem;font-size:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:600;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545;background-color:#fff5f5;box-shadow:0 0 0 3px #dc35451f}.form-group textarea{resize:vertical;min-height:100px}.form-group input[type=checkbox]{width:auto;margin-right:.5rem;cursor:pointer}.form-group label.checkbox-label{display:flex;align-items:center;cursor:pointer;font-weight:400}.radio-group{display:flex;gap:.75rem;flex-wrap:wrap;padding:.75rem;background:#f8f9fa;border-radius:8px;border:2px solid #e9ecef;margin-top:.5rem}.radio-label{display:flex;align-items:center;cursor:pointer;font-weight:500;padding:.6rem 1.25rem;border-radius:6px;border:2px solid transparent;transition:all .2s ease;flex:1;min-width:150px;justify-content:center}.radio-label:hover{background:#e9ecef}.radio-label input[type=radio]{width:18px!important;height:18px;min-width:18px;flex-shrink:0;margin:0 .6rem 0 0;padding:0!important;border:none!important;box-shadow:none!important;cursor:pointer;accent-color:#667eea}.radio-label:has(input[type=radio]:checked){background:#e7f0ff;border-color:#667eea;color:#667eea}.radio-label span{-webkit-user-select:none;user-select:none;font-size:1rem}.form-group small{display:block;color:#6c757d;font-size:.85rem;margin-top:.25rem}.loading-templates{padding:1rem;text-align:center;color:#6c757d;font-style:italic}.error-message{display:flex;align-items:flex-start;gap:.3rem;color:#dc3545;font-size:.875rem;font-weight:600;margin-top:.4rem}.error-message:before{content:"⚠";flex-shrink:0;font-style:normal}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.form-actions button{min-width:120px}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.template-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:.5rem}.template-thumbnail{position:relative;border:2px solid #e9ecef;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;background:#fff;box-shadow:0 2px 8px #0000001a}.template-thumbnail:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.template-thumbnail.selected{border-color:#667eea;border-width:3px;box-shadow:0 4px 16px #667eea4d}.template-thumbnail.selected:after{content:"✓";position:absolute;top:8px;right:8px;background:#667eea;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;z-index:10;box-shadow:0 2px 4px #0003}.template-preview{width:100%;height:180px;position:relative;overflow:hidden;background:#f8f9fa;display:flex;align-items:center;justify-content:center}.template-preview-full{height:80vh;max-height:800px;display:flex;align-items:center;justify-content:center}.template-iframe-full{width:1200px;height:1900px;border:none;pointer-events:auto;position:absolute;background:#fff}.template-iframe-wrapper-full{width:1200px;height:1900px;position:relative;transform-origin:top left}.template-iframe-wrapper{width:120px;height:170px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.template-iframe{width:1200px;height:1700px;border:none;pointer-events:none;transform:scale(.1);transform-origin:top left;position:absolute;top:0;left:0;background:#fff}.template-name{padding:.75rem;text-align:center;font-size:.85rem;font-weight:600;color:#333;background:#fff;border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:.5rem}.template-preview-button{border:none;background:transparent;color:#667eea;font-size:.8rem;cursor:pointer;text-decoration:underline;padding:0}.template-preview-button:hover{color:#4c5ccf}@media (max-width: 768px){.form-card{padding:1.5rem}.form-card h2{font-size:1.5rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.template-thumbnails{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.template-preview{height:150px}}.amount-pills{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.amount-pill{padding:.5rem 1.25rem;border:2px solid #e9ecef;border-radius:20px;background:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#333}.amount-pill:hover{border-color:#667eea;color:#667eea}.amount-pill.selected{background:#667eea;border-color:#667eea;color:#fff}.amount-pills.error{padding:.5rem;border-radius:8px;background-color:#fff5f5;outline:2px solid #dc3545;outline-offset:2px}.ai-message-writer{margin-top:.5rem}.ai-writer-toggle{background:none;border:none;color:#667eea;font-size:.875rem;font-weight:500;cursor:pointer;padding:0;text-decoration:underline}.ai-writer-toggle:hover{color:#4c5ccf}.ai-writer-panel{margin-top:.75rem;padding:1.25rem;background:#f8f9ff;border:2px solid #e0e4ff;border-radius:8px;display:flex;flex-direction:column;gap:1rem}.ai-writer-inputs{display:flex;flex-direction:column;gap:.75rem}.ai-writer-inputs .form-group{margin-bottom:0}.tone-pills{display:flex;gap:.5rem;flex-wrap:wrap}.tone-pill{padding:.375rem .875rem;border:2px solid #e9ecef;border-radius:20px;background:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.tone-pill:hover{border-color:#667eea;color:#667eea}.tone-pill.selected{background:#667eea;border-color:#667eea;color:#fff}.ai-generate-btn{align-self:flex-start}.ai-writer-error{color:#dc3545;font-size:.875rem;margin:0}.ai-writer-result{display:flex;flex-direction:column;gap:.5rem}.ai-writer-result textarea{width:100%;padding:.75rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .3s}.ai-writer-result textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.ai-refinements{display:flex;gap:.5rem;flex-wrap:wrap}.refinement-btn{padding:.375rem .75rem;background:#fff;border:1px solid #dee2e6;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s;color:#495057}.refinement-btn:hover:not(:disabled){background:#f8f9fa;border-color:#667eea;color:#667eea}.refinement-btn:disabled{opacity:.5;cursor:not-allowed}.payment-success-container{display:flex;justify-content:center;width:100%}.payment-success-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000026;width:100%;max-width:600px;text-align:center}.success-icon{margin-bottom:1.5rem;display:flex;justify-content:center;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.payment-success-card h1{color:#28a745;margin-bottom:1rem;font-size:2rem;font-weight:700}.success-message{color:#6c757d;font-size:1rem;margin-bottom:2rem;line-height:1.6}.order-details{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin:1.5rem 0;text-align:left}.order-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e9ecef}.order-detail-row:last-child{border-bottom:none}.order-label{font-weight:600;color:#333;font-size:.95rem}.order-value{color:#333;font-size:.95rem}.order-status{text-transform:capitalize;color:#28a745;font-weight:600}.receipt-link{color:#667eea;text-decoration:none;font-weight:500}.receipt-link:hover{text-decoration:underline}.success-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin:1.5rem 0;color:#6c757d;font-size:.95rem;line-height:1.5}.success-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.success-actions .btn{min-width:200px}@media (max-width: 768px){.payment-success-card{padding:1.5rem}.order-detail-row{flex-direction:column;align-items:flex-start;gap:.5rem}.success-actions .btn{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
