*{box-sizing:border-box;margin:0;padding:0}body{font-family:Roboto,sans-serif;background-color:#f4f4f9;min-height:100vh}#root{min-height:100vh}.fc-topbar{background:#d62828;padding:8px 20px;display:flex;justify-content:flex-start}.fc-topbar .social-links a{margin-right:12px;font-size:22px;color:#fff;transition:.3s;text-decoration:none}.fc-topbar .social-links a:hover{color:#ffcccb}.fc-header{display:flex;justify-content:center;padding:20px 0;border-bottom:2px solid #eee;margin-bottom:20px;background:#fff}.fc-header img{max-height:70px}.upload-container{max-width:1000px;margin:0 auto;padding:20px;background:#fff;border-radius:8px}.upload-box{border:2px dashed #999;border-radius:12px;padding:30px;text-align:center;cursor:pointer;color:#555;background:#fafafa;transition:.3s;display:block}.upload-box:hover{border-color:#333;background:#f0f0f0}.upload-box input{display:none}.message{margin:10px 0;text-align:center;font-weight:700;padding:10px;border-radius:5px}.message.success{color:#fff;background:green}.message.error{color:#a30000;background:#ffe5e5;border:2px dashed #a30000}.image-count{font-size:14px;margin:10px 0;text-align:center}.image-count.warn{color:#a30000;font-weight:700}.preview-grid{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin:20px 0}.preview-item{position:relative;transition:transform .2s}.preview-item:hover{transform:scale(1.03)}.preview-item img{width:110px;height:110px;object-fit:cover;border:2px solid #ddd;border-radius:10px;display:block}.preview-item.preview-item-portrait img{width:100px;height:133px}.preview-item.preview-item-landscape img{width:130px;height:87px}.preview-item.preview-item-square img{width:110px;height:110px}.preview-item .delete{position:absolute;top:-10px;right:-10px;background:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:red;font-weight:700;border:1px solid #ddd;z-index:10}.preview-item.polaroid{background:#fff;padding:6px 6px 0;border-radius:4px;box-shadow:0 3px 10px #00000026,0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.preview-item.polaroid:hover{transform:translateY(-3px) rotate(1deg);box-shadow:0 6px 20px #0003,0 2px 6px #0000001a}.preview-item.polaroid img{width:120px;height:120px;border:none;border-radius:2px;display:block}.preview-item.polaroid .polaroid-caption{height:32px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#333;text-align:center;padding:4px 2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.preview-item.polaroid .polaroid-caption.empty{color:#bbb;font-style:italic}.preview-item.polaroid .delete{top:-8px;right:-8px}.btn-foot{display:flex;justify-content:space-between;align-items:center;margin-top:15px;gap:10px;flex-wrap:wrap}.btn{padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px;transition:.2s;border:2px solid transparent;background:#fff;color:#333;display:inline-flex;align-items:center;gap:6px}.btn:disabled,.btn.disabled{opacity:.6;cursor:not-allowed}.btn.danger{border-color:#ff4d4d;color:#ff4d4d}.btn.danger:hover:not(:disabled){background:#ff4d4d;color:#fff}.btn.primary{border-color:#1e88e5;color:#fff;background:#1e88e5}.btn.primary:hover:not(:disabled){background:#1565c0}.btn.primary:disabled{background:#ccc;border-color:#ccc}.btn.whats{border-color:#25d366;color:#25d366}.btn.whats:hover{background:#25d366;color:#fff}.btn.green{border-color:#2e7d32;color:#fff;background:#2e7d32}.btn.green:hover:not(:disabled){background:#1b5e20}.finalize-form{margin-top:20px;padding:16px;border:1px solid #eee;border-radius:10px;background:#fafafa}.form-grid{display:grid;grid-template-columns:1fr;gap:12px;max-width:420px;margin:0 auto}.form-item label{display:block;font-weight:700;margin-bottom:6px}.form-item input,.form-item select{width:100%;padding:10px;border:1px solid #ccc;border-radius:8px;font-size:14px;background:#fff}.form-actions{display:flex;justify-content:center;margin-top:14px}.success-title{text-align:center;font-weight:800;font-size:20px;color:#2e7d32;margin:20px 0}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.login-box{background:#fff;padding:30px;border-radius:10px;box-shadow:0 4px 8px #0000001a;max-width:400px;width:100%}.login-box h1{text-align:center;margin-bottom:20px;font-size:24px}.login-box form{display:flex;flex-direction:column}.login-box label{font-weight:500;margin-bottom:5px}.login-box input{padding:10px;margin-bottom:15px;border:1px solid #ddd;border-radius:5px;font-size:16px}.login-box button{padding:10px;background-color:#4caf50;color:#fff;border:none;border-radius:5px;font-size:16px;cursor:pointer;font-weight:500}.login-box button:hover{background-color:#45a049}.admin-container{max-width:1200px;margin:0 auto;padding:20px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.admin-header h1{font-size:24px}.client-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.client-table th,.client-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #eee}.client-table th{background:#f5f5f5;font-weight:600}.client-table tr:hover{background:#fafafa}.client-table tr.clickable-row{cursor:pointer;transition:background .2s}.client-table tr.clickable-row:hover{background:#e3f2fd}.client-table tr.old-item{background:#fff8e1}.client-table tr.old-item:hover{background:#ffecb3}.admin-title{display:flex;flex-direction:column;gap:4px}.admin-title h1{margin:0;font-size:24px}.admin-subtitle{font-size:14px;color:#666;display:flex;align-items:center;gap:8px}.whatsapp-link{color:#25d366;font-size:20px;transition:transform .2s}.whatsapp-link:hover{transform:scale(1.2)}.admin-actions{display:flex;gap:10px;flex-wrap:wrap}.admin-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filter-input{padding:10px 14px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:200px}.filter-input:focus{outline:none;border-color:#1e88e5}.filter-select{padding:10px 14px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.admin-selection-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f5f5f5;border-radius:8px;margin-bottom:16px;flex-wrap:wrap;gap:10px}.selection-info{font-size:14px;color:#666;font-weight:500}.selection-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-small{padding:6px 12px;font-size:12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;transition:.2s}.btn-small:hover{background:#f5f5f5;border-color:#999}.btn-small.danger{color:#d32f2f;border-color:#ffcdd2}.btn-small.danger:hover{background:#ffebee}.client-info{display:flex;flex-direction:column;gap:2px}.client-info strong{font-size:14px}.client-email{font-size:12px;color:#666}.action-buttons{display:flex;gap:8px}.btn-icon{width:36px;height:36px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;color:#666}.btn-icon:hover{background:#f5f5f5;color:#333}.btn-icon.primary{color:#1e88e5;border-color:#90caf9}.btn-icon.primary:hover{background:#e3f2fd}.btn-icon.danger{color:#d32f2f;border-color:#ffcdd2}.btn-icon.danger:hover{background:#ffebee}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.empty-state,.loading-state{text-align:center;padding:40px;background:#fff;border-radius:8px;color:#666}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px;padding:20px;background:#fff;border-radius:8px}.photo-grid-square{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.photo-grid-portrait{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.photo-grid-landscape{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.photo-grid-polaroid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.photo-item{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a;background:#f5f5f5}.photo-item:hover{transform:scale(1.03);box-shadow:0 4px 12px #0003}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-grid-portrait .photo-item{aspect-ratio:3/4}.photo-grid-landscape .photo-item{aspect-ratio:3/2}.photo-item.polaroid-frame{aspect-ratio:8/10;background:#fff;padding:8px 8px 28px;box-shadow:0 3px 10px #00000026,0 1px 3px #0000001a;border-radius:4px}.photo-item.polaroid-frame:hover{transform:translateY(-3px) rotate(1deg)}.photo-item.polaroid-frame img{border-radius:2px}.photo-grid.photo-grid-large{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.photo-grid.photo-grid-medium{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.photo-grid.photo-grid-small{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.photo-item{position:relative}.photo-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:20px 8px 8px;text-align:center}.photo-resolution{font-size:10px;color:#fff;font-weight:500}.photo-item.polaroid-frame .photo-info{bottom:28px}.photo-download-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:#ffffffe6;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s}.photo-item:hover .photo-download-btn{opacity:1}.photo-download-btn:hover{background:#fff;transform:scale(1.1)}.photo-item.polaroid-frame .photo-download-btn{top:14px;right:14px}.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.lightbox img{max-width:90%;max-height:90%;object-fit:contain;border-radius:4px}.lightbox-close{position:absolute;top:20px;right:30px;font-size:40px;color:#fff;background:none;border:none;cursor:pointer;opacity:.8}.lightbox-close:hover{opacity:1}.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:90%;max-height:90%}.lightbox-content img{max-width:100%;max-height:calc(90vh - 80px);object-fit:contain;border-radius:4px}.lightbox-actions{display:flex;gap:12px}.lightbox-actions .btn{padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:.2s}.lightbox-actions .btn.primary{background:#1e88e5;color:#fff;border:none}.lightbox-actions .btn.primary:hover{background:#1565c0}.lightbox-actions .btn:not(.primary){background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.lightbox-actions .btn:not(.primary):hover{background:#ffffff4d}.lightbox-copies-badge{background:#1e88e5;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}.lightbox-copies-badge i{font-size:12px}.photo-item .copies-badge{position:absolute;top:8px;left:8px;background:#1e88e5;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px;box-shadow:0 2px 4px #0003;z-index:5}.photo-item .copies-badge i{font-size:10px}.photo-item.polaroid-frame .copies-badge{top:14px;left:14px}@media(max-width:600px){.btn-foot{flex-direction:column}.btn{width:100%;justify-content:center}}.photo-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.photo-editor-modal{background:#fff;border-radius:12px;max-width:650px;width:100%;max-height:95vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.photo-editor-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;gap:10px}.photo-editor-header h2{font-size:18px;font-weight:600;margin:0}.photo-editor-size-badge{background:#e3f2fd;color:#1565c0;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.photo-editor-header .close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;line-height:1;margin-left:auto}.photo-editor-header .close-btn:hover{color:#333}.photo-editor-content{padding:20px}.photo-editor-preview{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.photo-editor-canvas-container{display:flex;flex-direction:column;align-items:center}.photo-editor-canvas{border-radius:4px;box-shadow:0 4px 12px #00000026}.preview-hint{margin-top:8px;font-size:12px;color:#888}.photo-editor-controls{display:flex;flex-direction:column;gap:16px}.control-section{display:flex;flex-direction:column;gap:8px}.control-section label{display:block;font-weight:600;font-size:14px}.control-row{flex-direction:row;gap:20px;flex-wrap:wrap}.zoom-slider-container{display:flex;align-items:center;gap:10px}.zoom-slider-container input[type=range]{flex:1;height:6px;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ddd;outline:none}.zoom-slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#1e88e5;cursor:pointer}.zoom-slider-container input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#1e88e5;cursor:pointer;border:none}.reset-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:8px 12px;cursor:pointer;color:#666;transition:.2s}.reset-btn:hover{background:#eee;color:#333}.caption-editor{display:flex;flex-direction:column;gap:16px}.caption-input-container{display:flex;flex-direction:column;gap:6px}.caption-input-container label{font-weight:600;font-size:14px}.caption-input-container input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;width:100%}.caption-input-container input:focus{outline:none;border-color:#1e88e5}.char-count{font-size:12px;color:#888;text-align:right}.caption-options{display:flex;gap:20px;flex-wrap:wrap}.font-selector,.color-selector{display:flex;flex-direction:column;gap:8px}.font-selector label,.color-selector label{font-weight:600;font-size:14px}.font-buttons{display:flex;gap:6px}.font-btn{width:44px;height:44px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:16px;transition:.2s}.font-btn:hover{border-color:#999}.font-btn.active{border-color:#1e88e5;background:#e3f2fd}.color-buttons{display:flex;gap:6px}.color-btn{width:32px;height:32px;border:3px solid #fff;border-radius:50%;cursor:pointer;box-shadow:0 0 0 1px #ddd;transition:.2s}.color-btn:hover{transform:scale(1.1)}.color-btn.active{box-shadow:0 0 0 2px #1e88e5}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:.2s;min-width:60px}.filter-btn:hover{border-color:#999}.filter-btn.active{border-color:#1e88e5;background:#e3f2fd}.filter-preview{width:40px;height:40px;border-radius:4px;background:linear-gradient(135deg,#f5af19,#f12711)}.filter-btn span{font-size:10px;font-weight:500;color:#666}.filter-btn.active span{color:#1565c0}.orientation-buttons{display:flex;gap:10px}.orientation-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 16px;border:2px solid #ddd;border-radius:10px;background:#fff;cursor:pointer;transition:.2s;min-width:80px}.orientation-btn:hover{border-color:#999;background:#f5f5f5}.orientation-btn.active{border-color:#1e88e5;background:#e3f2fd}.orientation-icon{width:32px;height:auto;color:#666}.orientation-btn.active .orientation-icon{color:#1565c0}.orientation-btn span{font-size:11px;font-weight:500;color:#666}.orientation-btn.active span{color:#1565c0}.border-style-buttons{display:flex;gap:10px}.border-style-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 16px;border:2px solid #ddd;border-radius:10px;background:#fff;cursor:pointer;transition:.2s;min-width:80px}.border-style-btn:hover{border-color:#999;background:#f5f5f5}.border-style-btn.active{border-color:#1e88e5;background:#e3f2fd}.border-style-icon{width:28px;height:auto;border:1px solid #ccc;border-radius:2px}.border-style-btn.active .border-style-icon{border-color:#1565c0}.border-style-btn span{font-size:11px;font-weight:500;color:#666}.border-style-btn.active span{color:#1565c0}.caption-input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;width:100%}.caption-input:focus{outline:none;border-color:#1e88e5}.photo-editor-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;border-top:1px solid #eee;flex-wrap:wrap}.photo-editor-info{display:flex;align-items:center;gap:6px;font-size:12px;color:#888}.photo-editor-info i{color:#1e88e5}.photo-editor-actions{display:flex;gap:12px}.photo-editor-footer .cancel-btn{background:#f5f5f5;border:1px solid #ddd;color:#666;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:.2s}.photo-editor-footer .cancel-btn:hover{background:#eee}.photo-editor-footer .save-btn{background:#2e7d32;border:none;color:#fff;padding:10px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:.2s}.photo-editor-footer .save-btn:hover:not(:disabled){background:#1b5e20}.photo-editor-footer .save-btn:disabled{opacity:.6;cursor:not-allowed}.copies-control{display:flex;align-items:center;gap:12px}.copies-btn{width:36px;height:36px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;color:#333;display:flex;align-items:center;justify-content:center;transition:.2s}.copies-btn:hover:not(:disabled){border-color:#1e88e5;background:#e3f2fd;color:#1565c0}.copies-btn:disabled{opacity:.4;cursor:not-allowed}.copies-value{font-size:20px;font-weight:700;color:#1565c0;min-width:40px;text-align:center}.copies-badge{position:absolute;bottom:8px;left:8px;background:#1e88e5;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px;box-shadow:0 2px 4px #0003;z-index:5}.copies-badge i{font-size:10px}.preview-item.polaroid .copies-badge{bottom:auto;top:8px;left:8px}.limits-info{color:#666;font-weight:400}.image-count.warn .limits-info{color:#d32f2f}.photo-edit-hint{background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;padding:12px 16px;margin:15px 0;display:flex;align-items:center;gap:10px;color:#1565c0;font-size:14px}.photo-edit-hint i{font-size:18px}.photo-edit-hint strong{color:#0d47a1}.preview-item.editable .edit-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;gap:4px;border-radius:8px;transition:background .2s}.preview-item.polaroid.editable .edit-overlay{top:6px;left:6px;right:6px;bottom:auto;height:120px;border-radius:2px}.preview-item.editable .edit-overlay i{font-size:24px}.preview-item.editable:hover .edit-overlay{background:#1e88e5b3}.preview-item .edit-check{position:absolute;top:-6px;right:-6px;background:#2e7d32;color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;box-shadow:0 2px 4px #0003;z-index:5}.preview-item.polaroid .edit-check{top:10px;right:10px}.download-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}.download-modal{background:#fff;border-radius:12px;padding:40px 50px;text-align:center;box-shadow:0 10px 40px #0000004d;max-width:320px;width:90%}.download-modal h3{margin:0 0 20px;font-size:18px;color:#333}.download-spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top-color:#1e88e5;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.download-progress-text{color:#666;font-size:14px;margin:0}.fc-header.clickable{cursor:pointer;transition:opacity .2s}.fc-header.clickable:hover{opacity:.85}@media(max-width:600px){.photo-editor-overlay{padding:10px}.photo-editor-modal{max-height:95vh}.photo-editor-content{padding:15px}.control-row{flex-direction:column;gap:12px}.filter-buttons{justify-content:center}.photo-editor-footer{flex-direction:column;gap:12px}.photo-editor-info{justify-content:center}.photo-editor-actions{width:100%;flex-direction:column-reverse}.photo-editor-footer .btn{width:100%;text-align:center;justify-content:center}.download-modal{padding:30px 25px}}
