*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}.lego-brick{background:#ff6b35;background:var(--brick-color,#ff6b35);border-radius:4px;box-shadow:inset 0 -2px 0 #0003,inset 2px 0 0 #fff3,0 2px 4px #0000001a;position:relative}.lego-brick:before{background:#ff6b35;background:var(--brick-color,#ff6b35);border-radius:6px 6px 0 0;box-shadow:inset 0 1px 0 #ffffff4d,0 1px 2px #0003;left:50%;transform:translateX(-50%);width:12px}.lego-brick-4x2:before,.lego-brick:before{content:"";height:8px;position:absolute;top:-4px}.lego-brick-4x2:before{background:radial-gradient(circle at 20% 50%,#ff6b35 6px,#0000 0),radial-gradient(circle at 80% 50%,#ff6b35 6px,#0000 0);background:radial-gradient(circle at 20% 50%,var(--brick-color,#ff6b35) 6px,#0000 6px),radial-gradient(circle at 80% 50%,var(--brick-color,#ff6b35) 6px,#0000 6px);background-size:25% 100%;left:0;right:0}.lego-background{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-repeat:repeat;background-size:500px 200px;opacity:.15}.lego-background-single{background-image:url(/static/media/lego-brick-pattern.6aed5fec06d771c61e74.svg);background-repeat:repeat;background-size:200px 100px;opacity:.2}.lego-btn{background:linear-gradient(145deg,#ff6b35,#e55a2b);background:linear-gradient(145deg,var(--brick-color,#ff6b35),var(--brick-color-dark,#e55a2b));border:none;border-radius:8px;box-shadow:0 4px 0 #e55a2b,0 6px 12px #0003;box-shadow:0 4px 0 var(--brick-color-dark,#e55a2b),0 6px 12px #0003;color:#fff;cursor:pointer;font-weight:700;padding:1rem 2rem;position:relative;text-shadow:0 1px 2px #0000004d;transition:all .3s ease}.lego-btn:before{background:#ff6b35;background:var(--brick-color,#ff6b35);border-radius:10px 10px 0 0;box-shadow:inset 0 2px 0 #ffffff4d,0 1px 3px #0000004d;content:"";height:12px;left:50%;position:absolute;top:-6px;transform:translateX(-50%);width:20px}.lego-btn:hover{box-shadow:0 6px 0 #e55a2b,0 8px 16px #0000004d;box-shadow:0 6px 0 var(--brick-color-dark,#e55a2b),0 8px 16px #0000004d;transform:translateY(-2px)}.lego-btn:active{box-shadow:0 2px 0 #e55a2b,0 3px 6px #0003;box-shadow:0 2px 0 var(--brick-color-dark,#e55a2b),0 3px 6px #0003;transform:translateY(2px)}.lego-card{background:#fff;border-radius:12px;box-shadow:0 4px 0 #e0e0e0,0 6px 20px #0000001a;overflow:hidden;position:relative;transition:all .3s ease}.lego-card:before{background:radial-gradient(circle at 15px 6px,#ff6b35 4px,#0000 0),radial-gradient(circle at 45px 6px,#f7931e 4px,#0000 0),radial-gradient(circle at 75px 6px,#ffc107 4px,#0000 0);background-repeat:repeat-x;background-size:30px 100%;content:"";height:12px;left:20px;position:absolute;right:20px;top:-6px}.lego-card:hover{box-shadow:0 6px 0 #e0e0e0,0 10px 25px #00000026;transform:translateY(-4px)}.lego-red{--brick-color:#dc3545;--brick-color-dark:#c82333}.lego-blue{--brick-color:#007bff;--brick-color-dark:#0056b3}.lego-green{--brick-color:#28a745;--brick-color-dark:#1e7e34}.lego-yellow{--brick-color:#ffc107;--brick-color-dark:#e0a800}.lego-orange{--brick-color:#fd7e14;--brick-color-dark:#e8690b}.lego-purple{--brick-color:#6f42c1;--brick-color-dark:#59359a}.lego-separator{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 0;background-repeat:repeat-x;background-size:500px 200px;border-radius:8px;height:40px;margin:2rem 0;opacity:.4}.lego-loader{align-items:end;display:flex;gap:4px;justify-content:center}.lego-loader .brick{animation:legoBounce 1.4s ease-in-out infinite;border-radius:4px;height:20px;position:relative;width:20px}.lego-loader .brick,.lego-loader .brick:before{background:#ff6b35;background:var(--brick-color,#ff6b35)}.lego-loader .brick:before{border-radius:4px 4px 0 0;content:"";height:6px;left:50%;position:absolute;top:-3px;transform:translateX(-50%);width:8px}.lego-loader .brick:first-child{animation-delay:-.32s}.lego-loader .brick:nth-child(2){animation-delay:-.16s}.lego-loader .brick:nth-child(3){animation-delay:0s}@keyframes legoBounce{0%,80%,to{transform:scale(1) translateY(0)}40%{transform:scale(1.1) translateY(-10px)}}.lego-studs{position:relative}.lego-studs:after{background:radial-gradient(circle at 25% 25%,#ffffff4d 3px,#0000 0),radial-gradient(circle at 75% 25%,#ffffff4d 3px,#0000 0),radial-gradient(circle at 25% 75%,#ffffff4d 3px,#0000 0),radial-gradient(circle at 75% 75%,#ffffff4d 3px,#0000 0);background-size:30px 30px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}@media (max-width:768px){.lego-btn{padding:.75rem 1.5rem}.lego-btn:before{height:10px;width:16px}.lego-background{background-size:180px 30px}}.App{background:#f8f9fa;display:flex;flex-direction:column;min-height:100vh;position:relative}.App:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -80px;background-repeat:repeat-x;background-size:400px 160px;content:"";height:40px;left:0;opacity:.1;position:fixed;right:0;top:0;z-index:-1}.header{background:#fff;border-bottom:3px solid #e0e0e0;padding:1rem 2rem;position:relative;z-index:100}.header-content{align-items:center;box-sizing:border-box;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;width:100%}.header-spacer{width:30px}.logo{align-items:center;display:flex;gap:.5rem;text-decoration:none}.logo-icon{font-size:2rem}.logo-text{color:#ff6b35;font-size:1.5rem;font-weight:700;margin:0}.hamburger{background:none;border:none;cursor:pointer;height:25px;position:relative;width:30px;z-index:1001}.hamburger span{background:#333;border-radius:2px;display:block;height:3px;margin:5px 0;transition:all .3s ease;width:100%}.hamburger.open span:first-child{transform:rotate(45deg) translate(7px,7px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.side-menu{height:100vh;left:-320px;position:fixed;top:0;transition:left .3s ease;width:320px;z-index:1000}.side-menu.open{left:0}.side-menu:not(.open) .menu-overlay{display:none}.menu-overlay{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.menu-content{background:#fff;box-shadow:5px 0 15px #0000001a;height:100%;overflow-y:auto;position:relative;z-index:999}.menu-header{border-bottom:2px solid #f0f0f0;padding:2rem;text-align:center}.menu-header h2{color:#333;font-size:1.5rem;margin:0}.menu-items{list-style:none;margin:0;padding:0}.menu-items li{border-bottom:1px solid #f0f0f0}.menu-item{background:none;border:none;color:#333;cursor:pointer;display:block;font-size:1.1rem;padding:1.25rem 2rem;text-align:left;text-decoration:none;transition:all .3s ease;width:100%}.menu-item:hover{background:#f8f9fa;color:#ff6b35;transform:translateX(5px)}.menu-item.active{background:#fff5f2;border-right:4px solid #ff6b35;color:#ff6b35;font-weight:600}.logout-btn{color:#666!important;font-size:.9rem!important}.logout-btn:hover{background:#ffebee!important;color:#d32f2f!important}.loading-container{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);bottom:0;display:flex;justify-content:center;left:0;min-height:100vh;position:fixed;right:0;top:0;z-index:9999}.loading-spinner{animation:bounce 1s infinite;color:#fff;font-size:2rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-30px)}60%{transform:translateY(-15px)}}.app-main{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}@media (max-width:768px){.header{padding:.75rem 1rem}.logo-text{font-size:1.3rem}.app-main{padding:1rem}.side-menu{left:-280px;width:280px}.menu-header{padding:1.5rem}.menu-item{font-size:1rem;padding:1rem 1.5rem}}@media (max-width:480px){.header-content{padding:0}.logo-text{font-size:1.2rem}.side-menu{left:-260px;width:260px}.hamburger{height:15px;width:20px}}.home{margin:0 auto;max-width:1000px;padding:0}.hero-section{background:linear-gradient(135deg,#ff6b35,#f7931e);border-radius:20px;color:#fff;margin-bottom:3rem;overflow:hidden;padding:3rem 2rem;position:relative;text-align:center}.hero-section:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -80px;background-repeat:repeat-x;background-size:400px 160px;content:"";filter:brightness(1.3) contrast(.8);height:30px;left:0;opacity:.4;position:absolute;right:0;top:-15px}.hero-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #0000004d}.hero-description{font-size:1.2rem;line-height:1.6;margin-bottom:2rem;opacity:.9}.quick-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.action-btn{align-items:center;border:none;border-radius:12px;box-shadow:0 4px 0 #0000001a,0 6px 12px #0003;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:700;gap:.5rem;padding:1rem 2rem;position:relative;text-decoration:none;transition:all .3s ease}.action-btn.primary{background:#fff;color:#ff6b35}.action-btn.primary:before{background:#fff;border-radius:10px 10px 0 0;box-shadow:inset 0 2px 0 #ff6b3533;content:"";height:12px;left:50%;position:absolute;top:-6px;transform:translateX(-50%);width:20px}.action-btn.secondary{background:#fff3;border:2px solid #ffffff4d;color:#fff}.action-btn.secondary:before{background:#ffffff4d;border-radius:10px 10px 0 0;box-shadow:inset 0 2px 0 #fff3;content:"";height:12px;left:50%;position:absolute;top:-6px;transform:translateX(-50%);width:20px}.action-btn:hover{box-shadow:0 6px 0 #0000001a,0 8px 16px #0000004d;transform:translateY(-2px)}.action-btn.primary:hover{background:#f8f9fa}.action-btn.secondary:hover{background:#ffffff4d}.recent-section{margin-bottom:3rem}.section-title{color:#333;font-size:1.8rem;margin-bottom:1.5rem;text-align:center}.recent-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.recent-card{background:#fff;border-radius:16px;box-shadow:0 4px 0 #e0e0e0,0 6px 20px #0000001a;cursor:pointer;overflow:hidden;position:relative;transition:all .3s ease}.recent-card:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -40px;background-repeat:repeat-x;background-size:300px 120px;border-radius:4px 4px 0 0;content:"";height:20px;left:15px;opacity:.8;position:absolute;right:15px;top:-10px;z-index:1}.recent-card:hover{box-shadow:0 6px 0 #e0e0e0,0 12px 30px #0003;transform:translateY(-6px)}.recent-image-container{height:180px;overflow:hidden;position:relative}.recent-image{height:100%;object-fit:cover;width:100%}.photo-badge{background:#000000b3;border-radius:12px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem;position:absolute;right:10px;top:10px}.recent-content{padding:1rem}.recent-name{color:#333;font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.recent-date{color:#666;font-size:.9rem}.view-all{text-align:center}.view-all-btn{background:#f8f9fa;border:2px solid #e1e5e9;border-radius:25px;color:#666;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.view-all-btn:hover{background:#e9ecef;border-color:#adb5bd;color:#495057}.stats-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #0000001a;padding:2rem}.sync-status-notice{border-radius:12px;margin-bottom:2rem;padding:1rem;text-align:center;transition:all .3s ease}.sync-status-notice p{font-size:.9rem;line-height:1.5;margin:0}.sync-status-notice.checking{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.sync-status-notice.synced{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.sync-status-notice.local-only{background:#f0f8ff;border:1px solid #b8daff;color:#004085}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));justify-items:center}.stat-card{padding:1rem;text-align:center}.stat-number{color:#ff6b35;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#666;font-weight:600}@media (max-width:768px){.hero-section{margin-bottom:2rem;padding:2rem 1.5rem}.hero-title{font-size:2rem}.hero-description{font-size:1.1rem}.quick-actions{align-items:center;flex-direction:column}.action-btn{justify-content:center;max-width:300px;text-align:center;width:100%}.recent-grid{gap:1rem;grid-template-columns:1fr}.stats-section{text-align:center}.stats-grid{gap:.5rem;grid-template-columns:repeat(3,1fr);justify-items:center;max-width:100%}.stat-card{padding:.5rem}.stat-number{font-size:1.8rem}}.recent-image-container .video-thumbnail{height:100%;position:relative;width:100%}.recent-image-container .video-thumbnail video{border-radius:inherit;height:100%;object-fit:cover;width:100%}.recent-image-container .play-overlay{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:40px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:40px}.recent-card:hover .play-overlay{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}.photo-upload{background:#fff;border-radius:20px;box-shadow:0 8px 0 #e0e0e0,0 12px 32px #00000026;margin:0 auto;max-width:600px;padding:2rem;position:relative}.photo-upload:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -60px;background-repeat:repeat-x;background-size:400px 160px;border-radius:6px 6px 0 0;content:"";height:24px;left:20px;opacity:.8;position:absolute;right:20px;top:-12px}.upload-title{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:2rem;text-align:center}.upload-form{gap:1.5rem}.form-group,.upload-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-label{color:#555;font-size:1rem}.form-input{background:#f8f9fa;padding:1rem;transition:border-color .3s ease}.form-input:focus{background:#fff}.file-input{display:none}.file-input-label{align-items:center;background:#f8f9fa;border:2px dashed #e1e5e9;border-radius:12px;color:#666;cursor:pointer;display:flex;font-weight:600;gap:.5rem;justify-content:center;padding:1rem;transition:all .3s ease}.file-input-label:hover{background:#fff5f2;border-color:#ff6b35;color:#ff6b35}.file-input-label.error{background:#f8d7da;border-color:#dc3545;color:#721c24}.file-upload-section{display:flex;flex-direction:column;gap:.75rem}.file-requirements{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:.5rem;padding:.75rem}.requirements-text{color:#495057;font-size:.85rem;line-height:1.4;margin:0}.error-messages{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;margin:1rem 0;padding:1rem}.error-header{color:#721c24;font-size:.95rem;font-weight:700;margin-bottom:.5rem}.error-list{color:#721c24;margin:0;padding-left:1.25rem}.error-item{font-size:.9rem;line-height:1.3;margin-bottom:.25rem}.previews{margin-top:1rem}.previews-title{color:#555;font-size:1.1rem;margin-bottom:1rem}.preview-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.preview-item{aspect-ratio:1;background:#f8f9fa;border-radius:12px;overflow:hidden;position:relative}.preview-image{display:block;height:100%;object-fit:cover;width:100%}.remove-btn{align-items:center;background:#f00c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;position:absolute;right:8px;top:8px;transition:background .3s ease;width:24px}.remove-btn:hover{background:red}.submit-btn{background:linear-gradient(145deg,#ff6b35,#e55a2b);border:none;border-radius:12px;box-shadow:0 4px 0 #e55a2b,0 6px 12px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:1rem;padding:1rem 2rem;position:relative;text-shadow:0 1px 2px #0000004d;transition:all .3s ease}.submit-btn:before{background:#ff6b35;border-radius:10px 10px 0 0;box-shadow:inset 0 2px 0 #ffffff4d,0 1px 3px #0000004d;content:"";height:12px;left:50%;position:absolute;top:-6px;transform:translateX(-50%);width:20px}.submit-btn:hover{box-shadow:0 6px 0 #e55a2b,0 8px 16px #0000004d;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}@media (max-width:768px){.photo-upload{border-radius:16px;margin:0;padding:1.5rem}.upload-title{font-size:1.3rem}.preview-grid{gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.requirements-text{font-size:.8rem}.error-messages{padding:.75rem}.error-item{font-size:.85rem}}.zoom-modal{background:#000000e6;bottom:0;cursor:zoom-out;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.zoom-content,.zoom-modal{align-items:center;display:flex;justify-content:center}.zoom-content{max-height:90vh;max-width:90vw;position:relative}.zoom-image{border-radius:8px;box-shadow:0 4px 20px #00000080;max-height:90vh;max-width:100%;object-fit:contain}.zoom-close{align-items:center;background:#ffffffe6;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:0;top:-40px;transition:all .2s ease;width:40px}.zoom-close:hover{background:#fff;transform:scale(1.1)}@media (max-width:768px){.zoom-close{background:#fffffff2;right:10px;top:10px}}.preview-item .video-thumbnail{height:100%;position:relative;width:100%}.preview-item .video-thumbnail video{border-radius:inherit;height:100%;object-fit:cover;width:100%}.preview-item .play-overlay{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:30px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:30px}.preview-item:hover .play-overlay{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}.photo-gallery{width:100%}.gallery-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.gallery-title-section{display:flex;flex-direction:column;gap:1rem}.gallery-title{color:#333;font-size:1.5rem;font-weight:700;margin:0}.view-toggle{background:#f8f9fa;border:2px solid #e9ecef;border-radius:25px;display:flex;gap:.5rem;padding:.25rem}.toggle-btn{border-radius:20px;color:#666;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.toggle-btn:hover{background:#ff6b351a;color:#ff6b35}.toggle-btn.active{background:#ff6b35;box-shadow:0 2px 8px #ff6b354d;color:#fff}.gallery-add-btn{background:linear-gradient(145deg,#ff6b35,#e55a2b);border:none;border-radius:12px;box-shadow:0 4px 0 #e55a2b,0 6px 12px #0003;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;padding:.75rem 1.5rem;position:relative;transition:all .3s ease}.gallery-add-btn:before{background:#ff6b35;border-radius:8px 8px 0 0;box-shadow:inset 0 1px 0 #ffffff4d;content:"";height:8px;left:50%;position:absolute;top:-4px;transform:translateX(-50%);width:16px}.gallery-add-btn:hover{box-shadow:0 6px 0 #e55a2b,0 8px 16px #0000004d;transform:translateY(-2px)}.gallery-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:1rem 0}.creation-card{background:#fff;border-radius:16px;box-shadow:0 4px 0 #e0e0e0,0 6px 20px #0000001a;overflow:hidden;position:relative;transition:all .3s ease}.card-clickable-area{cursor:pointer}.creation-card:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -30px;background-repeat:repeat-x;background-size:250px 100px;border-radius:3px 3px 0 0;content:"";height:16px;left:10px;opacity:.9;position:absolute;right:10px;top:-8px;z-index:1}.creation-card:hover{box-shadow:0 6px 0 #e0e0e0,0 16px 40px #0003;transform:translateY(-8px)}.card-image-container{height:200px;overflow:hidden;position:relative;width:100%}.card-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.creation-card:hover .card-image{transform:scale(1.05)}.photo-count{background:#000000b3;border-radius:12px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem;position:absolute;right:12px;top:12px}.card-content{padding:1.25rem}.creation-name{color:#333;font-size:1.2rem;font-weight:700;line-height:1.3;margin-bottom:.5rem}.creation-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.creation-actions{display:flex;gap:.5rem}.delete-btn,.edit-btn{-webkit-tap-highlight-color:transparent;background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:.5rem;position:relative;touch-action:manipulation;transition:all .2s ease;z-index:100}.edit-btn:hover{background:#f0f0f0}.delete-btn:hover{background:#ffebee}.edit-name-container,.edit-name-input{margin-bottom:.5rem;position:relative;z-index:100}.edit-name-input{border:2px solid #ff6b35;border-radius:4px;font-family:inherit;font-size:1rem;padding:.5rem;width:100%}.edit-actions{display:flex;gap:.5rem;position:relative;z-index:100}.cancel-btn,.save-btn{border:none;border-radius:4px;flex:1 1;font-size:1rem;padding:.25rem .5rem;transition:all .2s ease}.save-btn{background:#4caf50;color:#fff}.save-btn:hover{background:#45a049}.cancel-btn{background:#f44336;color:#fff}.cancel-btn:hover{background:#d32f2f}.creation-date{color:#666;font-size:.9rem}.card-overlay{align-items:center;background:#ff6b35e6;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.creation-card:hover .card-overlay{opacity:1}.overlay-content{color:#fff;text-align:center}.view-text{font-size:1.1rem;font-weight:700}.gallery-empty{align-items:center;display:flex;justify-content:center;min-height:400px}.empty-state{max-width:400px;padding:2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-title{color:#333;font-size:1.5rem;margin-bottom:1rem}.empty-message{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.get-started-btn{background:linear-gradient(135deg,#ff6b35,#f7931e);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:1rem;padding:1rem 2rem;transition:all .3s ease}.get-started-btn:hover{box-shadow:0 6px 20px #ff6b354d;transform:translateY(-2px)}@media (max-width:768px){.gallery-header{flex-direction:column;text-align:center}.gallery-title{font-size:1.3rem}.gallery-add-btn{max-width:300px;width:100%}.gallery-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:.5rem 0}.card-image-container{height:180px}.card-content{padding:1rem}.creation-name{font-size:1.1rem}}.photos-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:1rem 0}.photo-tile{aspect-ratio:1;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transition:all .3s ease}.photo-tile:hover{box-shadow:0 4px 20px #0003;transform:scale(1.02)}.photo-tile-container{height:100%;position:relative;width:100%}.photo-tile-image{display:block;height:100%;object-fit:cover;width:100%}.photo-overlay{background:linear-gradient(#0000,#000c);bottom:0;color:#fff;left:0;opacity:0;padding:.75rem .5rem .5rem;position:absolute;right:0;transition:opacity .3s ease}.photo-tile:hover .photo-overlay{opacity:1}.photo-info{text-align:left}.photo-creation-name{font-size:.85rem;font-weight:600;line-height:1.2;margin-bottom:.2rem}.photo-date{font-size:.75rem;opacity:.9}.photo-modal{position:fixed;z-index:1000}.photo-modal,.photo-modal-content{background:#000;height:100%;left:0;overflow:hidden;top:0;width:100%}.photo-modal-content{align-items:center;display:flex;flex-direction:column;justify-content:center;position:absolute}.modal-close-btn{background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2rem;height:40px;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:40px;z-index:1001}.modal-close-btn:hover{background:#000000e6;transform:scale(1.1)}.modal-photo{display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;touch-action:pinch-zoom;-webkit-user-select:none;user-select:none;width:auto}.modal-info{background:linear-gradient(#0000,#000c);bottom:0;color:#fff;left:0;pointer-events:none;position:absolute;right:0;text-align:center}.modal-creation-name{color:#fff;font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.modal-creation-name,.modal-date{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;text-shadow:0 2px 4px #000c}.modal-date{color:#ffffffe6;font-size:.95rem;margin-bottom:1rem}.view-creation-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ff6b35e6;border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:700;padding:.75rem 1.5rem;pointer-events:auto;transition:all .3s ease}.view-creation-btn:hover{box-shadow:0 6px 20px #ff6b354d;transform:translateY(-2px)}.modal-nav-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.8rem;height:50px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:50px;z-index:1002}.modal-nav-prev{left:1rem}.modal-nav-next{right:1rem}.modal-nav-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.modal-photo-counter{background:#000000b3;border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;left:50%;padding:.5rem 1rem;position:absolute;top:1rem;transform:translateX(-50%);z-index:1001}@media (max-width:768px){.gallery-header{align-items:stretch;flex-direction:column;gap:1.5rem}.gallery-title-section{align-items:center;text-align:center}.gallery-title{font-size:1.3rem}.modal-photo{touch-action:pinch-zoom}.modal-close-btn{font-size:1.4rem;height:50px;right:1rem;top:env(safe-area-inset-top,1rem);width:50px}.modal-nav-btn{font-size:2rem;height:60px;width:60px}.modal-nav-prev{left:.5rem}.modal-nav-next{right:.5rem}.modal-photo-counter{font-size:1rem;padding:.75rem 1.25rem;top:env(safe-area-inset-top,1rem)}.modal-info{padding-bottom:env(safe-area-inset-bottom,1rem)}}.gallery-add-btn{margin:0 auto;max-width:300px;width:100%}.photos-grid{gap:3px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.photo-creation-name{font-size:.8rem}.photo-date{font-size:.7rem}.modal-info{padding:1rem}.modal-nav-btn{font-size:1.5rem;height:40px;width:40px}.modal-nav-prev{left:.5rem}.modal-nav-next{right:.5rem}.modal-photo-counter{font-size:.8rem;padding:.4rem .8rem;top:.5rem}.gallery-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:.5rem 0}.card-image-container{height:180px}.card-content{padding:1rem}.creation-name{font-size:1.1rem}.creation-info{align-items:flex-start;flex-direction:column;gap:.5rem}.creation-actions{justify-content:flex-end;width:100%}.delete-btn,.edit-btn{font-size:1.5rem;min-height:44px;min-width:44px;padding:.75rem}.card-overlay{display:none}@media (max-width:480px){.gallery-grid{gap:1rem;grid-template-columns:1fr}.creation-card{margin:0 auto;max-width:350px}.photos-grid{gap:2px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.card-image-container .video-thumbnail{height:100%;position:relative;width:100%}.card-image-container .video-thumbnail video{border-radius:inherit;height:100%;object-fit:cover;width:100%}.card-image-container .play-overlay{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:50px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:50px}.creation-card:hover .play-overlay{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}@media (max-width:768px){.card-image-container .play-overlay{font-size:14px;height:40px;width:40px}}@media (max-width:480px){.card-image-container .play-overlay{font-size:12px;height:30px;width:30px}}.photo-tile-container .video-thumbnail{height:100%;position:relative;width:100%}.photo-tile-container .video-thumbnail video{border-radius:inherit;height:100%;object-fit:cover;width:100%}.photo-tile-container .play-overlay{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:40px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:40px}.photo-tile:hover .play-overlay{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}.creation-view{margin:0 auto;max-width:800px;padding:1rem}.creation-header{margin-bottom:2rem;text-align:center}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.back-btn{background:#f8f9fa;border:2px solid #e1e5e9;border-radius:25px;color:#666;cursor:pointer;font-weight:600;margin-bottom:1.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.back-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-2px)}.title-section{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.creation-title{color:#333;font-size:2rem;font-weight:700;margin-bottom:.5rem}.inline-actions{align-items:center;display:flex;gap:.5rem}.icon-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:18px;padding:4px;transition:all .3s ease}.icon-btn:hover{background:#0000001a;transform:translateY(-1px)}.icon-btn.delete-icon:hover{background:#dc35451a;color:#dc3545}.creation-meta{color:#666;font-size:.9rem}.photo-viewer{background:#fff;border-radius:20px;box-shadow:0 8px 32px #0000001a;padding:1.5rem}.main-photo-container{background:#f8f9fa;border-radius:16px;margin-bottom:1.5rem;overflow:hidden;position:relative}.main-photo{display:block;height:auto;max-height:600px;object-fit:contain;width:100%}.nav-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:50px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:50px}.nav-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.nav-btn:disabled{cursor:not-allowed;opacity:.3}.prev-btn{left:15px}.next-btn{right:15px}.photo-counter{background:#000000b3;border-radius:20px;bottom:15px;color:#fff;font-size:.9rem;font-weight:600;left:50%;padding:.5rem 1rem;position:absolute;transform:translateX(-50%)}.photo-thumbnails{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));max-width:100%;padding:.5rem 0}.thumbnail-container{display:inline-block;position:relative}.thumbnail{aspect-ratio:1;background:none;border:3px solid #0000;border-radius:12px;cursor:pointer;flex-shrink:0;overflow:hidden;transition:all .3s ease;width:100%}.delete-media-btn{align-items:center;background:#f00c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:4px;top:4px;transition:background .3s ease;width:20px;z-index:10}.delete-media-btn:hover{background:red}.thumbnail:hover{border-color:#ff6b35;transform:scale(1.05)}.thumbnail.active{border-color:#ff6b35;box-shadow:0 0 0 2px #ff6b354d}.thumbnail-image{display:block;height:100%;object-fit:cover;width:100%}.add-media-section{border-top:1px solid #e9ecef;margin-top:1.5rem;padding-top:1rem;text-align:center}.add-media-btn{margin-bottom:1rem}.selected-files-info{align-items:center;display:flex;flex-direction:column;gap:.75rem}.file-count{color:#666;font-size:.9rem;font-weight:600}.upload-selected-btn{background:linear-gradient(145deg,#ff6b35,#e55a2b)!important;border-color:#e55a2b!important;color:#fff!important}.upload-selected-btn:hover{background:linear-gradient(145deg,#e55a2b,#d14d26)!important;transform:translateY(-2px)}.edit-name-section{align-items:center;display:flex;flex-direction:column;gap:.75rem}.edit-name-input{background:#f8f9fa;border:2px solid #e1e5e9;border-radius:12px;font-size:1.25rem;font-weight:600;min-width:250px;padding:.75rem 1rem;text-align:center;transition:border-color .3s ease}.edit-name-input:focus{background:#fff;border-color:#ff6b35;outline:none}.edit-name-actions{display:flex;gap:.5rem}.cancel-btn,.save-btn{align-items:center;border:2px solid #e1e5e9;border-radius:50%;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:36px;justify-content:center;transition:all .3s ease;width:36px}.save-btn{background:#d4edda;border-color:#c3e6cb;color:#155724}.save-btn:hover{background:#c3e6cb;border-color:#b1dfbb;transform:translateY(-2px)}.cancel-btn{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.cancel-btn:hover{background:#f5c6cb;border-color:#f1b0b7;transform:translateY(-2px)}@media (max-width:768px){.creation-view{padding:.5rem}.creation-title{font-size:1.5rem}.photo-viewer{border-radius:16px;padding:1rem}.nav-btn{font-size:1.2rem;height:40px;width:40px}.prev-btn{left:10px}.next-btn{right:10px}.photo-thumbnails{gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(85px,1fr))}.icon-btn{font-size:20px;padding:6px}.title-section{gap:.5rem}.edit-name-input{font-size:1.1rem;min-width:200px}}@media (max-width:480px){.main-photo{max-height:400px}.photo-thumbnails{justify-content:flex-start}}.video-thumbnail{display:inline-block;height:100%;position:relative;width:100%}.video-thumbnail video{height:100%;object-fit:cover;width:100%}.play-overlay{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;font-size:18px;font-weight:700;height:50px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:50px}.thumbnail .play-overlay{font-size:12px;height:25px;width:25px}.video-thumbnail:hover .play-overlay{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}.main-photo[controls]{height:auto;max-height:600px;max-width:100%;width:100%}.login-container{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:20px;box-shadow:0 4px 0 #0000001a,0 10px 30px #0003;max-width:400px;overflow:hidden;padding:2rem;position:relative;width:100%}.login-card:before{background-image:url(/static/media/lego-multicolor-pattern.0a8911daf2f79047c1ab.svg);background-position:0 -40px;background-repeat:repeat-x;background-size:300px 120px;content:"";height:20px;left:0;opacity:.6;position:absolute;right:0;top:-10px}.login-header{margin-bottom:2rem;text-align:center}.login-title{color:#333;font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#666;font-size:.95rem;line-height:1.5}.form-group,.login-form{margin-bottom:1.5rem}.form-label{color:#333;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-input{border:2px solid #e1e5e9;border-radius:12px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.form-input:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a;outline:none}.auth-message{border-radius:8px;font-size:.9rem;margin-bottom:1rem;padding:.75rem;text-align:center}.auth-message.error{background:#ffebee;border:1px solid #ffcdd2;color:#c62828}.auth-message.success{background:#e8f5e8;border:1px solid #c8e6c9;color:#2e7d32}.auth-btn{background:linear-gradient(135deg,#ff6b35,#f7931e);border:none;border-radius:12px;box-shadow:0 4px 0 #e55a2b,0 6px 12px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:.875rem;position:relative;transition:all .3s ease;width:100%}.auth-btn:before{background:#ff6b35;border-radius:10px 10px 0 0;box-shadow:inset 0 2px 0 #fff3;content:"";height:12px;left:50%;position:absolute;top:-6px;transform:translateX(-50%);width:20px}.auth-btn:hover:not(:disabled){box-shadow:0 6px 0 #e55a2b,0 8px 16px #0000004d;transform:translateY(-2px)}.auth-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.auth-toggle{margin-bottom:1.5rem;text-align:center}.toggle-btn{background:none;border:none;color:#ff6b35;cursor:pointer;font-size:.95rem;font-weight:600;text-decoration:underline;transition:all .2s ease}.toggle-btn:hover{color:#e55a2b}.guest-notice{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;text-align:center}.guest-notice p{color:#666;font-size:.85rem;line-height:1.4;margin:0}@media (max-width:480px){.login-container{padding:.5rem}.login-card{padding:1.5rem}.login-title{font-size:1.6rem}}
/*# sourceMappingURL=main.1b8a4384.css.map*/