@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;900&family=Cormorant+Garamond:wght@300;400;600&family=Montserrat:wght@300;400;600&display=swap);code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}.App{min-height:100vh;text-align:center}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:linear-gradient(45deg,#667eea,#764ba2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(45deg,#764ba2,#667eea)}.upload-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;margin:1rem auto 0;max-width:600px;padding:1.5rem 1rem}.upload-container{text-align:center}.upload-toggle-btn{background:linear-gradient(135deg,#8e44ad,#a569bd);border:none;border-radius:50px;box-shadow:0 6px 20px #8e44ad4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:0;padding:12px 24px;transition:all .3s ease}.upload-toggle-btn:hover{background:linear-gradient(135deg,#7d3c98,#8e44ad);box-shadow:0 12px 30px #8e44ad66;transform:translateY(-2px)}.upload-toggle-btn:active{transform:translateY(0)}.upload-toggle-btn:disabled{background:#6c757d80;box-shadow:none;cursor:not-allowed;transform:none}.admin-indicator{align-items:center;animation:slideInFromTop .3s ease-out;background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:15px;box-shadow:0 8px 25px #e74c3c4d;color:#fff;display:flex;justify-content:space-between;margin:1rem auto;max-width:600px;padding:1rem 2rem}.admin-indicator span{font-size:1.1rem;font-weight:600}.exit-admin-btn{background:#fff3;border:2px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.exit-admin-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.welcome-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);background-image:url(/static/media/background-pattern.d280f3343b10afa7d68f.svg),linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);background-position:50%,50%;background-repeat:repeat,no-repeat;background-size:400px 400px,100% 100%;font-family:Montserrat,sans-serif;min-height:100vh;overflow-x:hidden;position:relative}.background-decoration{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:1}.corner-ornament{background:linear-gradient(45deg,#8e44ad,#a569bd);border-radius:50%;height:200px;opacity:.15;position:absolute;width:200px}.corner-ornament.top-left{left:-100px;top:-100px}.corner-ornament.top-right{right:-100px;top:-100px}.main-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:rgba(42,25,74,.332);border:1px solid #520c6f4d;border-radius:30px;box-shadow:0 25px 50px #0006;margin:1.5rem auto;max-width:1000px;padding:1.5rem;position:relative;z-index:2}.event-header{background:linear-gradient(135deg,#2a194a4d,#520c6f33);border:2px solid #8e44ad4d;border-radius:25px;box-shadow:0 15px 35px #0003;margin-bottom:2rem;padding:2rem 0;position:relative;text-align:center}.event-header:before{top:-15px}.event-header:after,.event-header:before{background:linear-gradient(90deg,#0000,#a569bd 20%,#8e44ad 50%,#a569bd 80%,#0000);border-radius:15px;content:"";height:30px;left:50%;opacity:.6;position:absolute;transform:translateX(-50%);width:80%}.event-header:after{bottom:-15px}.event-header .decorative-border-top{top:-25px}.event-header .decorative-border-bottom,.event-header .decorative-border-top{background:repeating-linear-gradient(90deg,#0000,#0000 10px,#a569bd 0,#a569bd 15px);height:20px;left:50%;opacity:.4;position:absolute;transform:translateX(-50%);width:90%}.event-header .decorative-border-bottom{bottom:-25px}.event-header:after,.event-header:before{background-image:url(/static/media/elegant-border.48b703b3419c26e0fda2.svg);background-position:50%;background-repeat:no-repeat;background-size:contain;content:"";height:40px;left:50%;opacity:.6;position:absolute;transform:translateX(-50%);width:200px}.event-header:before{top:0}.event-header:after{bottom:0}.main-title{color:#ecf0f1;font-family:Playfair Display,serif;font-size:4rem;font-weight:900;margin-bottom:.5rem;position:relative;text-shadow:2px 2px 4px #0000004d;z-index:15}.quinceanera-name{color:#a569bd;font-family:Cormorant Garamond,serif;font-size:3rem;font-weight:600;margin-bottom:1rem;text-shadow:0 0 10px #a569bd80}.event-subtitle,.quinceanera-name{font-style:italic;position:relative;z-index:15}.event-subtitle{color:#bdc3c7;font-family:Montserrat,sans-serif;font-size:1.3rem;font-weight:400}.gallery-section{animation:fadeInUp 1s ease-out;margin-top:-.5rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.event-header{animation:fadeInUp 1.2s ease-out}.quinceanera-name{animation:slideInFromRight 1.5s ease-out .3s both}.event-subtitle{animation:fadeInUp 1.8s ease-out .6s both}.main-title{animation:slideInFromLeft 1.5s ease-out}.quinceanera-image-container{height:300px;left:50%;pointer-events:auto;position:absolute;top:50%;transform:translate(-50%,-50%);width:200px;z-index:1}.quinceanera-image{filter:drop-shadow(0 10px 20px rgba(142,68,173,.3));height:100%;object-fit:contain;width:100%}.quinceanera-name:hover{animation:pulse .6s ease-in-out;text-shadow:0 0 20px #a569bdcc}@media (max-width:768px){.main-container{border-radius:20px;margin:1rem;padding:1.5rem}.main-title{font-size:3rem}.quinceanera-name{font-size:2.5rem}.event-subtitle{font-size:1.1rem}.quinceanera-image-container{height:225px;left:50%;top:50%;transform:translate(-50%,-50%);width:150px}}@media (max-width:480px){.main-container{padding:1rem}.main-title{font-size:2.5rem}.quinceanera-name{font-size:2rem}.event-subtitle{font-size:1rem}.quinceanera-image-container{height:160px;left:50%;top:50%;transform:translate(-50%,-50%);width:120px}}.footer{animation:fadeInUp 1s ease-out 2.5s both;border-top:1px solid #8e44ad33;margin-top:3rem;padding:2rem 1rem;position:relative;text-align:center;z-index:2}.footer-text{color:#bdc3c7;font-size:.9rem;font-weight:400;margin:0}.designer-link{background:none;border:none;color:#a569bd;cursor:pointer;font-size:.9rem;font-weight:600;margin:0;padding:0;text-decoration:underline;-webkit-text-decoration-color:#8e44ad80;text-decoration-color:#8e44ad80;transition:all .3s ease}.designer-link:hover{color:#8e44ad;-webkit-text-decoration-color:#8e44ad;text-decoration-color:#8e44ad;transform:scale(1.05)}@media (max-width:768px){.footer{padding:1.5rem 1rem}.designer-link,.footer-text{font-size:.8rem}}@media (max-width:480px){.footer{padding:1rem}.designer-link,.footer-text{font-size:.75rem}}*{-webkit-tap-highlight-color:transparent}:focus{outline:none!important}:focus-visible{outline:none!important}.photo-gallery{padding:1rem 0}.loading-gallery{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{border:4px solid #ffffff1a;border-left-color:#8e44ad;margin-bottom:20px}.loading-gallery p{color:#fff;font-size:1.1rem;margin:0;opacity:.8}.upload-section{margin-bottom:3rem}button{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}button,button:active,button:focus{outline:none!important}button:focus-visible{outline:none!important}.upload-area{margin:0 auto;max-width:500px}.file-input{display:none}.upload-label{cursor:pointer;display:block;transition:all .3s ease}.upload-placeholder{background:linear-gradient(135deg,#2c3e50,#34495e);background-image:url(/static/media/upload-area.68615132ddc073ab306e.svg);background-position:center 20px;background-repeat:no-repeat;background-size:200px 150px;border:2px dashed #8e44ad;border-radius:20px;color:#ecf0f1;padding:8rem 3rem 3rem;text-align:center;transition:all .3s ease}.upload-placeholder:hover{background:linear-gradient(135deg,#34495e,#2c3e50);border-color:#a569bd;box-shadow:0 10px 30px #8e44ad4d;transform:translateY(-2px)}.upload-placeholder span{display:none}.upload-placeholder p{color:#ecf0f1;font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.upload-placeholder small{color:#bdc3c7;font-size:.9rem}.selected-file{background:linear-gradient(135deg,#34495e,#2c3e50);border:2px solid #8e44ad;border-radius:20px;color:#ecf0f1;padding:2rem;text-align:center}.selected-file span{display:block;font-size:2.5rem;margin-bottom:1rem}.selected-file p{font-weight:600;margin-bottom:1rem;word-break:break-all}.author-input{background:#34495ecc;border:2px solid #34495e;border-radius:8px;color:#ecf0f1;font-family:Montserrat,sans-serif;font-size:1rem;margin-bottom:1rem;padding:10px 12px;transition:all .3s ease;width:100%}.author-input:focus{border-color:#8e44ad;box-shadow:0 0 0 3px #8e44ad33;outline:none}.author-input::placeholder{color:#bdc3c7}.upload-btn{background:linear-gradient(45deg,#8e44ad,#a569bd);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.upload-btn:hover:not(:disabled){box-shadow:0 5px 15px #8e44ad66;transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.6}.gallery-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:2rem}.photo-card{background:#2a194acc;border:1px solid #520c6f4d;border-radius:20px;box-shadow:0 10px 30px #0000004d;overflow:hidden;transition:all .3s ease}.photo-card:hover{border-color:#520c6f80;box-shadow:0 20px 40px #0006;transform:translateY(-5px)}.photo-image{display:block;height:250px;object-fit:cover;position:relative;transition:all .3s ease;width:100%;z-index:10}.photo-image:hover{box-shadow:0 5px 15px #8e44ad4d;transform:scale(1.02)}.photo-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#2c3e50e6,#34495ee6);border-radius:0 0 20px 20px;color:#ecf0f1;flex-direction:column;gap:.5rem;padding:.8rem 1rem}.photo-actions,.photo-info{align-items:center;display:flex}.photo-actions{flex-shrink:0;flex-wrap:nowrap;gap:.3rem;justify-content:center;min-width:0}.photo-time{color:#bdc3c7;margin:0}.comments-count{border-radius:15px}.comments-count,.like-button{align-items:center;background:#8e44ad1a;border:1px solid #8e44ad4d;box-sizing:border-box;color:#8e44ad;display:flex;flex-shrink:0;font-size:.75rem;font-weight:500;gap:2px;height:24px;justify-content:center;padding:2px 6px;white-space:nowrap;width:50px}.like-button{-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;cursor:pointer;outline:none!important;transition:all .3s ease}.like-button:hover:not(:disabled){background:#8e44ad33;border-color:#8e44ad80;box-shadow:0 4px 12px #8e44ad33;transform:translateY(-1px)}.like-button:focus{box-shadow:0 0 0 2px #8e44ad33;outline:none!important}.like-button:active{outline:none!important;transform:translateY(0)}.like-button:focus-visible{outline:none!important}.like-button:focus-within{outline:none!important}.like-button:disabled{cursor:not-allowed;opacity:.7}.like-button.liking{animation:pulse 1.5s ease-in-out infinite;background:#f39c1226;border-color:#f39c1266;color:#f39c12}.delete-button{-webkit-tap-highlight-color:transparent;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#e74c3c1a;border:2px solid #e74c3c4d;border-radius:25px;color:#e74c3c;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;height:36px;justify-content:center;min-width:36px;outline:none!important;padding:6px 10px;transition:all .3s ease}.delete-button:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c80;box-shadow:0 4px 12px #e74c3c33;transform:translateY(-1px)}.delete-button:focus{box-shadow:0 0 0 2px #e74c3c33;outline:none!important}.delete-button:active{outline:none!important;transform:translateY(0)}.delete-button:disabled{cursor:not-allowed;opacity:.7}.delete-button.deleting{animation:pulse 1.5s ease-in-out infinite;background:#f39c1226;border-color:#f39c1266;color:#f39c12}.empty-gallery{color:#bdc3c7;padding:4rem 2rem;text-align:center}.empty-gallery span{display:block;font-size:4rem;margin-bottom:1rem}.empty-gallery p{font-size:1.2rem;font-weight:500;margin-bottom:.5rem}.empty-gallery small{color:#7f8c8d;font-size:1rem}@media (max-width:768px){.gallery-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.selected-file,.upload-placeholder{padding:2rem}.selected-file span,.upload-placeholder span{font-size:2rem}.upload-area{max-width:400px}}@media (max-width:480px){.gallery-grid{gap:.8rem;grid-template-columns:repeat(2,1fr)}.photo-card{margin:0}.photo-image{height:180px}.photo-info{padding:.8rem 1rem}.like-button,.photo-time{font-size:.8rem}.like-button{padding:6px 12px}.upload-area{max-width:100%}.selected-file,.upload-placeholder{padding:1.5rem}.upload-placeholder p{font-size:1rem}.upload-placeholder small{font-size:.8rem}}@media (max-width:360px){.gallery-grid{gap:.6rem;grid-template-columns:repeat(2,1fr)}.photo-image{height:150px}.photo-info{padding:.6rem .8rem}}.photo-upload{margin:0 auto;max-width:500px;padding:15px;width:100%}.upload-area{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:2px dashed #8e44ad4d;border-radius:20px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:180px;padding:40px 20px;position:relative;text-align:center;transition:all .2s ease}.upload-area:hover{background:#ffffff1a;border-color:#8e44ad99;box-shadow:0 8px 25px #8e44ad33;transform:translateY(-2px)}.upload-area.drag-active{background:#8e44ad1a;border-color:#8e44adcc;box-shadow:0 12px 30px #8e44ad4d;transform:scale(1.02)}.upload-area.uploading{background:#f39c121a;border-color:#f39c1299;pointer-events:none}.upload-icon{color:#8e44adb3;font-size:3rem;margin-bottom:15px;transition:all .3s ease}.upload-area:hover .upload-icon{color:#8e44ad;transform:scale(1.1)}.upload-area.drag-active .upload-icon{color:#8e44ad;transform:scale(1.2)}.upload-area h3{color:#fff;font-size:1.4rem;font-weight:600;margin:0 0 10px}.upload-area p{color:#fffc;font-size:.95rem;line-height:1.5;margin:5px 0}.file-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%;z-index:1}.upload-progress{max-width:300px;width:100%}.progress-bar{background:#ffffff1a;border-radius:3px;box-shadow:inset 0 1px 3px #0003;height:6px;margin-bottom:15px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#8e44ad,#a569bd);border-radius:3px;box-shadow:0 0 10px #8e44ad80;height:100%;transition:width .3s ease}@media (max-width:768px){.photo-upload{padding:10px}.upload-area{min-height:160px;padding:25px 15px}.upload-area h3{font-size:1.2rem}.upload-area p{font-size:.85rem}.upload-icon{font-size:2.5rem}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.upload-area.uploading .upload-icon{animation:pulse 2s infinite}.photo-detail-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);background-image:url(/static/media/background-pattern.d280f3343b10afa7d68f.svg),linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);background-position:50%,50%;background-repeat:repeat,no-repeat;background-size:400px 400px,100% 100%;display:flex;flex-direction:column;min-height:100vh}.floating-back-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#8e44ad,#a569bd);border:1px solid #ffffff1a;border-radius:25px;box-shadow:0 6px 20px #8e44ad4d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;justify-content:center;left:20px;padding:12px 20px;position:fixed;top:20px;z-index:1000}.floating-back-btn:hover{background:linear-gradient(135deg,#7d3c98,#8e44ad);box-shadow:0 8px 25px #8e44ad66;transform:translateY(-2px)}.floating-like-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;border:1px solid #ffffff1a;border-radius:50%;bottom:15px;box-shadow:0 6px 20px #e74c3c4d;color:#fff;cursor:pointer;display:flex;font-size:1.3rem;font-weight:600;height:50px;justify-content:center;position:absolute;right:15px;width:50px;z-index:100}.floating-like-btn:hover{background:#0000;box-shadow:0 8px 25px #e74c3c66;transform:translateY(-2px)}.floating-like-btn.liking{animation:heartPulse .6s ease-in-out;background:#0000}@keyframes heartPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.header-like-btn{align-items:center;background:#ff3b30;border:none;border-radius:20px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.25rem;padding:.5rem 1rem;transition:none}.header-like-btn:hover{background:#d70015;transform:translateY(-1px)}.header-like-btn.liking{background:#8e8e93;cursor:not-allowed}.main-image-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 25px #0003;margin:.5rem;order:-1;overflow:hidden}.image-container{align-items:center;background:#f8f8f80c;cursor:pointer;display:flex;height:60vh;justify-content:center;max-height:500px;min-height:300px;position:relative;width:100%}.main-image{max-height:100%;max-width:100%;object-fit:contain;transition:none}.image-container:hover .main-image{transform:scale(1.02)}.image-container:after{background:#000000b3;border-radius:20px;bottom:1rem;color:#fff;content:"👆 Toca para ver en pantalla completa";font-size:.8rem;left:50%;opacity:0;padding:.5rem 1rem;pointer-events:none;position:absolute;transform:translateX(-50%);transition:none}.image-container:hover:after{opacity:1}.info-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 25px #0003;flex:1 1;margin:.5rem;padding:1.5rem}.photo-meta{align-items:center;border-bottom:1px solid #f2f2f7;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1rem 0}.photo-time{color:#ffffffb3;font-size:.9rem;font-weight:500}.like-count{align-items:center;color:#fff;display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.like-count .heart-icon{font-size:1.1rem}.action-buttons{display:flex;flex-direction:column;gap:.75rem}.action-button{align-items:center;background:#007aff;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:none}.action-button:hover{background:#0056cc;box-shadow:0 4px 12px #007aff4d;transform:translateY(-1px)}.action-button.like-action{background:#ff3a3000}.action-button.like-action:hover{background:#d7001506;box-shadow:0 4px 12px #ff3b304d}.action-button.like-action.liking{background:#8e8e93;box-shadow:none;cursor:not-allowed;transform:none}.comments-placeholder{background:#0707f20f;border:2px dashed #c7c7cc;border-radius:12px;color:#8e8e93;padding:2rem;text-align:center}.comments-placeholder p{font-size:.9rem;margin:0}.image-only-view{background:#000;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:1000}.image-only-header{align-items:center;background:#000000b3;display:flex;justify-content:space-between;left:0;padding:1rem;position:absolute;right:0;top:0;z-index:1001}.close-image-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:40px;justify-content:center;transition:none;width:40px}.close-image-btn:hover{background:#ffffff4d;transform:scale(1.1)}.image-counter{color:#fff;font-size:.9rem;font-weight:500}.image-only-container{align-items:center;cursor:grab;display:flex;flex:1 1;justify-content:center;overflow:hidden;-webkit-user-select:none;user-select:none}.image-only-container:active{cursor:grabbing}.fullscreen-image{max-height:90%;max-width:100%;object-fit:contain;transition:none}.image-only-controls{align-items:center;background:#000000b3;border-radius:25px;bottom:2rem;color:#fff;display:flex;gap:.75rem;left:50%;padding:.75rem 1rem;position:absolute;transform:translateX(-50%)}.image-only-controls button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;height:35px;justify-content:center;transition:none;width:35px}.image-only-controls button:hover{background:#ffffff4d;transform:scale(1.1)}.image-only-controls span{font-size:.9rem;font-weight:500;margin:0 .5rem;min-width:50px;text-align:center}.photo-detail-error,.photo-detail-loading{align-items:center;background:#f5f5f5;color:#333;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e5e5ea;border-radius:50%;border-top-color:#007aff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.photo-detail-error h2{color:#333;font-size:1.5rem;margin-bottom:2rem}.back-button{background:#007aff;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:1rem 2rem;transition:none}.back-button:hover{background:#0056cc;transform:translateY(-2px)}@media (min-width:768px){.photo-detail-page{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.mobile-header{background:#fffffff2;border-radius:15px;margin-bottom:1rem}.main-image-section{border-radius:20px;margin:0 0 1rem}.image-container{border-radius:20px;height:60vh;max-height:500px}.info-panel{border-radius:20px;margin:0;padding:2rem}.actions-section h3,.comments-section h3,.info-section h3{font-size:1.3rem}.info-label,.info-value{font-size:1rem}.action-button{font-size:1.1rem;padding:1.2rem 2rem}}@media (min-width:1024px){.photo-detail-page{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 400px;grid-template-rows:auto 1fr;margin:0 auto;max-width:1200px;padding:2rem}.mobile-header{grid-column:1/-1;margin-bottom:0}.main-image-section{grid-column:1;grid-row:2;margin:0}.info-panel{grid-column:2;grid-row:2;height:-webkit-fit-content;height:fit-content;margin:0;position:-webkit-sticky;position:sticky;top:120px}.image-container{height:60vh;max-height:500px}}.loading-dots{display:flex;gap:4px}.loading-dots:after,.loading-dots:before{animation:loadingDots 1.4s ease-in-out infinite both;background:#8e8e93;border-radius:50%;content:"";height:6px;width:6px}.loading-dots:before{animation-delay:-.32s}.loading-dots:after{animation-delay:-.16s}@keyframes loadingDots{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.image-skeleton{border-radius:8px;height:100%;width:100%}.image-skeleton,.skeleton-title{animation:skeletonLoading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%}.skeleton-title{border-radius:4px;height:24px;margin-bottom:1rem;width:60%}.skeleton-grid{display:flex;flex-direction:column;gap:.75rem}.skeleton-item{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.skeleton-label{width:40%}.skeleton-label,.skeleton-value{animation:skeletonLoading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px;height:16px}.skeleton-value{width:30%}@keyframes skeletonLoading{0%{background-position:-200% 0}to{background-position:200% 0}}.header-like-btn.loading{align-items:center;background:#e5e5ea;cursor:default;display:flex;justify-content:center;min-width:60px}.image-container.loading{cursor:default}.image-container.loading:hover .main-image{transform:none}.comments-section{background:hsla(0,0%,100%,.613);border-radius:15px;margin-top:1rem;padding:1.5rem}.comments-section h3{color:#333;font-size:1.3rem;font-weight:600;margin:0 0 1.5rem}.comment-form{margin-bottom:2rem}.form-group{margin-bottom:1rem}.comment-input{background:#fff;border:2px solid #e1e5e9;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:none;width:100%}.comment-input:focus{border-color:#8e44ad;box-shadow:0 0 0 3px #8e44ad1a;outline:none}.comment-textarea{background:#fff;border:2px solid #e1e5e9;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:1rem;min-height:80px;padding:12px 16px;resize:vertical;transition:none;width:100%}.comment-textarea:focus{border-color:#8e44ad;box-shadow:0 0 0 3px #8e44ad1a;outline:none}.submit-comment-btn{background:linear-gradient(135deg,#8e44ad,#a569bd);border:none;border-radius:25px;box-shadow:0 4px 15px #8e44ad4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:none}.submit-comment-btn:hover:not(:disabled){background:linear-gradient(135deg,#7d3c98,#8e44ad);box-shadow:0 6px 20px #8e44ad66;transform:translateY(-2px)}.submit-comment-btn:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.comments-list{max-height:400px;overflow-y:auto}.no-comments{color:#7f8c8d;font-style:italic;padding:2rem;text-align:center}.comment-item{background:#f8f9fa;border-left:4px solid #8e44ad;border-radius:12px;margin-bottom:1rem;padding:1rem}.comment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.comment-author{color:#8e44ad;font-size:.95rem;font-weight:600}.comment-time{color:#7f8c8d;font-size:.8rem}.comment-text{color:#333;font-size:.95rem;line-height:1.5}@media (max-width:768px){.comments-section{margin-top:.5rem;padding:1rem}.comments-section h3{font-size:1.2rem;margin-bottom:1rem}.comment-input,.comment-textarea{font-size:16px}.comment-header{align-items:flex-start;flex-direction:column;gap:.25rem}.comment-time{font-size:.75rem}}
/*# sourceMappingURL=main.dafb7cdc.css.map*/