@import"https://fonts.googleapis.com/css2?family=Great+Vibes&family=Inter:wght@400;500;600;700&display=swap";.login-overlay{position:fixed;inset:0;background:#00000080;background:var(--shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000001;animation:fadeIn .2s ease}.login-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:2px solid var(--border);border-radius:16px;box-shadow:0 10px 40px var(--shadow);max-width:450px;width:90%;z-index:2000002}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid var(--border)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.modal-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.error-message{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem}.success-message{padding:.75rem;background:#efe;border:1px solid #cfc;border-radius:8px;color:#3c3;font-size:.9rem}.status-message{padding:.75rem;background:#eef;border:1px solid #ccf;border-radius:8px;color:#339;font-size:.9rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group textarea{padding:.75rem;border:2px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.submit-btn{padding:.875rem;border-radius:10px;background:var(--accent);color:#fff;font-weight:600;font-size:1rem;transition:all .2s ease;margin-top:.5rem}.submit-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.modal{max-width:95%}}.modal-overlay{position:fixed;inset:0;background:#00000080;background:var(--shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999999;animation:fadeIn .2s ease}.settings-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);border:2px solid var(--border);border-radius:20px;box-shadow:0 10px 40px var(--shadow);max-width:450px;width:90%;max-height:85vh;overflow-y:auto;z-index:1000000;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-primary)}.panel-header h2{margin:0;font-size:1.4rem;color:var(--text-title);font-family:Great Vibes,cursive;font-weight:400}.close-btn{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border:none;cursor:pointer}.close-btn:hover{background:var(--accent);color:#fff;transform:rotate(90deg)}.panel-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.setting-group{display:flex;flex-direction:column;gap:.6rem}.setting-group>label{font-weight:600;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.theme-toggle-large{width:100%;padding:.8rem;border-radius:12px;background:var(--bg-primary);border:2px solid var(--border);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--text-primary);font-weight:600}.theme-toggle-large:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 4px 12px var(--shadow)}.theme-toggle-large span{font-size:1.1rem}.theme-toggle-large .toggle-sub{font-size:.8rem;color:var(--text-secondary);font-weight:400}.mode-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.mode-btn{padding:.75rem;border-radius:12px;background:var(--bg-tertiary);border:2px solid transparent;display:flex;flex-direction:column;align-items:center;gap:.4rem;transition:all .2s ease;color:var(--text-secondary);font-weight:500;cursor:pointer}.mode-btn:hover{border-color:var(--accent);transform:translateY(-2px);color:var(--text-primary)}.mode-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px var(--shadow)}.mode-emoji{font-size:1.4rem}.advanced-settings{display:flex;flex-direction:column;gap:1.2rem;background:var(--bg-tertiary);padding:1rem;border-radius:12px;border:1px dashed var(--border)}.range-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.range-value,.range-value-input{background:var(--bg-primary);padding:.1rem .4rem;border-radius:4px;font-size:.8rem;color:var(--accent);font-weight:600}.range-value-input{border:none;width:3rem;text-align:center;font-family:inherit;appearance:none;-moz-appearance:textfield}.range-value-input::-webkit-outer-spin-button,.range-value-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.range-value-input:focus{outline:2px solid var(--accent);background:var(--bg-tertiary)}.slider{width:100%;height:6px;border-radius:3px;background:var(--bg-primary);outline:none;appearance:none;-webkit-appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s ease;border:2px solid white;box-shadow:0 2px 4px #0000001a}.slider::-webkit-slider-thumb:hover{transform:scale(1.1);background:var(--accent-hover)}.dual-slider{display:flex;gap:1rem}.range-wrapper{flex:1;display:flex;flex-direction:column;gap:.4rem;background:var(--bg-primary);padding:.6rem;border-radius:8px}.sub-label{font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase}.range-value-small{font-size:.7rem;color:var(--text-secondary);text-align:right}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;color:var(--text-primary);transition:background .2s ease}.checkbox-label:hover{background:var(--bg-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}@media(max-width:768px){.settings-panel{width:100%;height:100%;max-height:100vh;max-width:100%;border-radius:0;border:none}.panel-header{position:sticky;top:0;z-index:20}.mode-buttons{grid-template-columns:repeat(3,1fr)}}.header{background:var(--bg-primary);border-bottom:2px solid var(--border);padding:.75rem 1.5rem;position:sticky;top:0;z-index:20000;box-shadow:0 4px 12px var(--shadow);transition:background-color .3s ease,border-color .3s ease}.header-content{max-width:1600px;margin:0 auto;display:flex;justify-content:space-between;padding:0 1.5rem;position:relative;background-color:var(--bg-primary);transition:background-color .3s ease}:global([data-theme=dark]) .header{background-color:#2a2a2a;border-bottom:1px solid #444}.logo-link{display:block;transition:transform .3s ease}.logo-link:hover{transform:scale(1.03)}.header-logo{height:5.5rem;width:auto;object-fit:contain;transition:all .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}:global([data-theme=dark]) .header-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.5)) brightness(1.2)}.header-title{display:none}.header-title:hover{transform:scale(1.02) rotate(-1deg)}.header-actions{display:flex;align-items:center;gap:.75rem}.icon-btn{width:42px;height:42px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border);color:var(--text-secondary);font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:2px 2px 0 var(--border)}.icon-btn:hover{transform:translateY(-2px);box-shadow:2px 4px 0 var(--border);background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn:active{transform:translateY(0);box-shadow:0 0 0 var(--border)}.primary-btn{padding:.6rem 1.4rem;border-radius:25px;background:var(--accent);color:#fff;font-weight:600;font-size:1rem;border:2px solid transparent;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px var(--shadow)}.primary-btn:hover{background:var(--accent-hover);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px var(--shadow)}.primary-btn:active{transform:translateY(0)}.text-btn{padding:.5rem 1rem;color:var(--text-secondary);font-size:.9rem;font-weight:600;transition:color .2s ease}.text-btn:hover{color:var(--accent)}@media(max-width:768px){.header{padding:.5rem 1rem;overflow-x:hidden}.header-content{padding:0 .5rem}.header-logo{height:3.5rem}.header-title{font-size:2.2rem}.header-actions{gap:.5rem}.icon-btn{width:38px;height:38px;font-size:1.1rem}.primary-btn{padding:.5rem 1rem;font-size:.9rem}.text-btn{display:none}}.comment-cloud-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:105;overflow:hidden}.comment-bubble{position:absolute;transform:translate(-50%,-50%);background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);padding:8px 14px;border-radius:20px;color:#fff;font-size:.9rem;max-width:200px;box-shadow:0 4px 12px #0003;animation:floatIn .5s ease-out forwards,drift 6s ease-in-out infinite alternate;pointer-events:auto;transition:transform .2s,background .2s}.comment-bubble:hover{background:#ffffff40;transform:translate(-50%,-50%) scale(1.05);z-index:110}.comment-bubble.own-comment{border-color:#64c8ff80;background:#3264964d}.comment-text{word-wrap:break-word;text-shadow:0 1px 2px rgba(0,0,0,.5)}.comment-meta{font-size:.7rem;opacity:.7;margin-top:4px;text-align:right}.comment-input-bar{position:absolute;bottom:80px;left:50%;transform:translate(-50%);display:flex;gap:8px;background:#0009;padding:8px;border-radius:30px;pointer-events:auto;width:90%;max-width:400px;border:1px solid rgba(255,255,255,.2)}.comment-input-bar input{background:transparent;border:none;color:#fff;flex:1;padding:8px 12px;outline:none}.comment-input-bar button{background:#fff;color:#000;border:none;border-radius:20px;padding:6px 16px;font-weight:700;cursor:pointer;transition:opacity .2s}.comment-input-bar button:disabled{opacity:.5;cursor:not-allowed}@keyframes floatIn{0%{opacity:0;transform:translate(-50%,-40%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes drift{0%{margin-top:0}to{margin-top:-10px}}@media(max-width:400px){.comment-bubble{font-size:.8rem;padding:6px 10px}}.lightbox{position:fixed;inset:0;z-index:21000;display:flex;align-items:center;justify-content:center;padding:2rem}.lightbox-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:-1}.lightbox-content{max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;width:auto;height:auto}.lightbox-image{max-width:100%;max-height:75vh;object-fit:contain;border-radius:4px;box-shadow:0 20px 60px #000000b3;border:5px solid white;transition:transform .2s ease,filter .15s ease,opacity .15s ease}.lightbox-image-wrapper{position:relative;display:inline-block;max-width:100%}.lightbox-caption{position:absolute;bottom:0;left:0;width:100%;padding:2rem 1rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.6) 60%,transparent 100%);color:#fffffff2;font-size:1.1rem;text-align:center;display:flex;flex-direction:column;gap:.25rem;z-index:20;border-bottom-left-radius:4px;border-bottom-right-radius:4px;text-shadow:0 2px 4px rgba(0,0,0,.8);pointer-events:none}.caption-year{font-size:.8rem;opacity:.8;text-transform:uppercase;letter-spacing:1px;font-weight:500}.lightbox-close{position:absolute;top:0;left:-60px;right:auto;width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:2005;cursor:pointer}.lightbox-close:hover{background:#ffffff40;transform:rotate(90deg)}.lightbox-favorite{position:absolute;top:0;right:-60px;width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:2001;cursor:pointer}.lightbox-favorite:hover,.lightbox-favorite.active{background:#ffffff40;transform:scale(1.1)}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:2.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:2001;cursor:pointer;padding-bottom:4px}.lightbox-nav:hover{background:#ffffff40;transform:translateY(-50%) scale(1.1)}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-counter{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:.5rem 1.2rem;background:#00000080;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fffc;border-radius:20px;font-size:.9rem;font-weight:500;z-index:2001;pointer-events:none}@media(max-width:768px){.lightbox{padding:0}.lightbox-favorite{width:44px;height:44px;font-size:1.2rem;top:-50px;left:auto;right:0;background:#0006}.lightbox-close{width:44px;height:44px;font-size:1.2rem;top:-50px;left:0;right:auto;background:#0006;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:50%;z-index:2005;position:absolute}.admin-id-badge{top:.5rem;left:.5rem;font-size:.75rem;padding:.3rem .5rem}.lightbox-image-wrapper{margin-top:5.5rem}.lightbox-nav{width:44px;height:44px;font-size:1.8rem;background:#0006;top:auto;bottom:1.5rem;transform:none}.lightbox-prev{left:15%}.lightbox-next{right:15%}.lightbox-image{max-height:60vh;border-width:0}.lightbox-caption{width:90%;font-size:1rem;padding:.6rem}}.lightbox-bottom-controls{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;z-index:2001;pointer-events:auto}.lightbox-bottom-controls .lightbox-counter{position:static;transform:none}.lightbox-dice-btn{display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border:none;cursor:pointer;transition:all .2s ease}.lightbox-dice-btn:hover:not(:disabled){transform:scale(1.08)}.lightbox-dice-btn:disabled{cursor:not-allowed;opacity:.7}.casino-table{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.6rem 1.2rem;background:linear-gradient(145deg,#1a7a3c,#0d5c2a);border:3px solid #8b6914;border-radius:30px;box-shadow:inset 0 2px 8px #0000004d,0 4px 12px #0006}.dice-3d{width:36px;height:36px;background:linear-gradient(135deg,#fff,#e8e8e8);border-radius:6px;position:relative;box-shadow:2px 2px 4px #0000004d,inset -1px -1px 2px #0000001a,inset 1px 1px 2px #fffc;transition:transform .1s ease}.pip{position:absolute;width:7px;height:7px;background:#1a1a1a;border-radius:50%;box-shadow:inset 0 1px 2px #0006}.dice-one .pip{background:#c00;box-shadow:inset 0 1px 2px #0000004d}.pip-center{top:50%;left:50%;transform:translate(-50%,-50%)}.pip-top-left{top:5px;left:5px}.pip-top-right{top:5px;right:5px}.pip-bottom-left{bottom:5px;left:5px}.pip-bottom-right{bottom:5px;right:5px}.pip-middle-left{top:50%;left:5px;transform:translateY(-50%)}.pip-middle-right{top:50%;right:5px;transform:translateY(-50%)}.lightbox-dice-btn.rolling .dice-3d{animation:dice-roll-bounce .2s ease-in-out infinite}.lightbox-dice-btn.rolling .dice-3d:nth-child(2){animation-delay:.1s;animation-name:dice-roll-bounce-alt}@keyframes dice-roll-bounce{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-8px) rotate(90deg)}50%{transform:translateY(0) rotate(180deg)}75%{transform:translateY(-4px) rotate(270deg)}to{transform:translateY(0) rotate(360deg)}}@keyframes dice-roll-bounce-alt{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-6px) rotate(-90deg)}50%{transform:translateY(0) rotate(-180deg)}75%{transform:translateY(-10px) rotate(-270deg)}to{transform:translateY(0) rotate(-360deg)}}.lightbox-image.slot-blur{filter:blur(20px) brightness(1.2) saturate(1.5);opacity:.8;animation:spiral-vortex .4s linear infinite;transition:none;transform-origin:center center;border-radius:50%;border-color:transparent}@keyframes spiral-vortex{0%{transform:scale(1) rotate(0);filter:blur(10px)}25%{transform:scale(.4) rotate(calc(90deg * var(--direction, 1)));filter:blur(25px)}50%{transform:scale(.6) rotate(calc(180deg * var(--direction, 1)));filter:blur(20px)}75%{transform:scale(.3) rotate(calc(270deg * var(--direction, 1)));filter:blur(30px)}to{transform:scale(1) rotate(calc(360deg * var(--direction, 1)));filter:blur(0px)}}.lightbox-image:not(.slot-blur){animation:landing-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes landing-pop{0%{transform:scale(.4);opacity:.5;border-radius:50%}to{transform:scale(1);opacity:1;border-radius:4px}}.lightbox-image-wrapper.shuffling{position:relative;overflow:hidden;border-radius:50%}.lightbox-image-wrapper.shuffling:before{content:"";position:absolute;top:50%;left:50%;width:200%;height:200%;transform:translate(-50%,-50%);background:radial-gradient(circle,transparent 30%,rgba(255,255,255,.1) 35%,transparent 40%,rgba(255,255,255,.1) 45%,transparent 50%);animation:vortex-spin .5s linear infinite;pointer-events:none;z-index:10}.lightbox-image-wrapper.shuffling:after{content:"";position:absolute;inset:0;background:radial-gradient(circle,transparent 20%,rgba(0,0,0,.4) 100%);pointer-events:none;z-index:11;border-radius:50%}@keyframes vortex-spin{0%{transform:translate(-50%,-50%) rotate(0) scale(1)}to{transform:translate(-50%,-50%) rotate(360deg) scale(1.5)}}@keyframes motion-lines{0%{background-position:0 0}to{background-position:0 30px}}@media(max-width:768px){.lightbox-bottom-controls{bottom:1.5rem;gap:.5rem}.lightbox-image{max-height:60vh}.casino-table{padding:.5rem 1rem;gap:.5rem}.dice-3d{width:32px;height:32px}.pip{width:6px;height:6px}.pip-top-left{top:4px;left:4px}.pip-top-right{top:4px;right:4px}.pip-bottom-left{bottom:4px;left:4px}.pip-bottom-right{bottom:4px;right:4px}.pip-middle-left{left:4px}.pip-middle-right{right:4px}}.admin-id-badge{position:absolute;top:1.5rem;left:1.5rem;z-index:20002;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);padding:.5rem .8rem;border-radius:8px;color:#fff;font-family:monospace;font-size:.9rem;cursor:copy;display:flex;align-items:center;gap:.5rem}.admin-id-badge:hover{background:#000c;border-color:#fff6;transform:translateY(1px)}.badge-label{opacity:.6;font-size:.8rem;text-transform:uppercase}.badge-id{font-weight:700;letter-spacing:.5px}.badge-feedback{margin-left:.5rem;font-size:.8rem;color:#4cd137;animation:fade-in-out 2s ease forwards}@keyframes fade-in-out{0%{opacity:0;transform:translate(-4px)}10%{opacity:1;transform:translate(0)}80%{opacity:1}to{opacity:0}}.lightbox-comments-toggle{position:absolute;top:20px;right:70px;background:#0006;border:none;color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .2s,background .2s;z-index:102}.lightbox-comments-toggle:hover{background:#000000b3;transform:scale(1.1)}.lightbox-comments-toggle.active{background:#64c8ff66;box-shadow:0 0 10px #64c8ff4d}@media(max-width:600px){.lightbox-comments-toggle{top:15px;right:60px;width:36px;height:36px;font-size:1rem}}.empty-state{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary);font-size:1.2rem;text-align:center;padding:2rem}.gallery-grid-virtual{display:block;padding:2rem;width:100%;max-width:1600px;margin:0 auto}.gallery-item{position:relative;background:#fff;overflow:hidden;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem;break-inside:avoid;width:100%}.gallery-item:hover{transform:translateY(-5px);z-index:5;box-shadow:0 10px 20px #00000026}.image-wrapper{width:100%;height:auto;overflow:hidden;display:block}.gallery-item img{width:100%;height:auto;display:block;object-fit:cover;transition:transform .5s ease}.gallery-item:hover img{transform:scale(1.1)}.favorite-btn{position:absolute;top:.5rem;right:.5rem;background:#ffffffe6;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:scale(.8);transition:all .2s ease;box-shadow:0 2px 5px #0000001a;z-index:2}.gallery-item:hover .favorite-btn,.favorite-btn.active{opacity:1;transform:scale(1)}.active{opacity:1}.favorite-btn:hover{transform:scale(1.1)}.photo-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);padding:2rem .5rem .5rem;font-size:.85rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);transform:translateY(0);text-align:center;font-weight:500}@media(max-width:1200px){.gallery-grid{column-count:4}}@media(max-width:900px){.gallery-grid{column-count:3}}@media(max-width:600px){.gallery-grid{column-count:2;padding:1rem;column-gap:1rem}.gallery-item{margin-bottom:1rem}.favorite-btn{opacity:1;width:36px;height:36px;font-size:1.1rem;transform:scale(1)}.photo-caption{opacity:1;font-size:.8rem;padding:.75rem}}.sprinkle-container{position:relative;width:100%;min-height:calc(100vh - 100px);height:100%;overflow:hidden}.sprinkle-photo{position:absolute;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px var(--shadow);transition:transform .3s ease,box-shadow .3s ease,filter .3s;cursor:pointer;-webkit-user-select:none;user-select:none;backface-visibility:hidden;will-change:transform,left,top}.sprinkle-photo.pop-in{animation:fadeInScale 1.2s cubic-bezier(.2,.8,.2,1) forwards}@keyframes fadeInScale{0%{opacity:0;scale:.8}to{opacity:1;scale:1}}.sprinkle-photo:hover{transform:translate(-50%,-50%) var(--photo-rotation) scale(1.05)!important;box-shadow:0 12px 32px var(--shadow);z-index:10000!important;filter:brightness(1.1)}.sprinkle-photo img{width:100%;height:100%;object-fit:cover}.sprinkle-photo .favorite-btn{position:absolute;top:.5rem;right:.5rem;width:36px;height:36px;border-radius:50%;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1.1rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;z-index:2}.sprinkle-photo:hover .favorite-btn,.sprinkle-photo .favorite-btn.active{opacity:1}.sprinkle-photo .favorite-btn:hover{transform:scale(1.15)}.sprinkle-photo .photo-caption{position:absolute;bottom:0;left:0;right:0;padding:.75rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;font-size:.85rem;opacity:1;transition:opacity .3s ease}@media(max-width:768px){.sprinkle-container{padding:1rem}.sprinkle-photo .favorite-btn{display:none}.sprinkle-photo .photo-caption{opacity:1;font-size:.75rem;padding:.5rem}}.sprinkle-container.paused{visibility:hidden;pointer-events:none}.orbit-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;min-height:calc(100vh - 80px);padding:1rem;overflow:hidden}.orbit-track{position:relative;width:100%;max-width:1200px;height:400px;display:flex;align-items:center;justify-content:center;perspective:1000px}.orbit-photo{position:absolute;width:250px;height:auto;max-height:85%;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px var(--shadow);transition:all .6s cubic-bezier(.4,0,.2,1);cursor:pointer;animation:orbitEnter .6s ease-out backwards}@keyframes orbitEnter{0%{opacity:0;transform:scale(.8)}}.orbit-photo.focused{box-shadow:0 12px 40px var(--shadow)}.orbit-photo img{width:100%;height:100%;object-fit:cover}.orbit-photo .favorite-btn{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:50%;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1.2rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;z-index:2}.orbit-photo.focused .favorite-btn,.orbit-photo:hover .favorite-btn,.orbit-photo .favorite-btn.active{opacity:1}.orbit-photo .favorite-btn:hover{transform:scale(1.15)}.orbit-photo .photo-caption{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;font-size:.95rem;text-align:center}.orbit-controls{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;position:relative;z-index:100}.orbit-nav{width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.orbit-nav:hover{background:var(--accent-hover);transform:scale(1.1)}.orbit-counter{font-size:1.1rem;font-weight:600;color:var(--text-primary);min-width:80px;text-align:center}@media(max-width:768px){.orbit-container{padding:1rem}.orbit-track{height:300px}.orbit-photo{width:200px;height:auto}.orbit-photo .favorite-btn{opacity:1;width:36px;height:36px;font-size:1.1rem}.orbit-controls{gap:1.5rem;margin-bottom:1.5rem}.orbit-nav{width:44px;height:44px;font-size:1.8rem}.orbit-counter{font-size:1rem}}:root[data-theme=warm]{--bg-primary: #FFFCF5;--bg-secondary: #FFF6E0;--bg-tertiary: #FFECC0;--text-primary: #1A1A1A;--text-secondary: #5C544D;--text-title: #A64193;--accent: #F582AE;--accent-hover: #D9608B;--border: #E8DCC0;--shadow: rgba(0, 0, 0, .05);--overlay: rgba(255, 252, 245, .95)}:root[data-theme=dark]{--bg-primary: #1A1A1A;--bg-secondary: #252525;--bg-tertiary: #333333;--text-primary: #E0E0E0;--text-secondary: #A0A0A0;--text-title: #D69ADE;--accent: #FF8906;--accent-hover: #E67A05;--border: #404040;--shadow: rgba(0, 0, 0, .4);--overlay: rgba(26, 26, 26, .95)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:none;transition:all .2s ease}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font-family:inherit}html{scroll-behavior:smooth}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--accent-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes popIn{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .4s ease}.pop-in{animation:popIn .4s cubic-bezier(.68,-.55,.265,1.55)}.empty-favorites-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;padding:2rem;animation:fadeIn .4s ease}.empty-favorites-state p{font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.empty-favorites-state .empty-sub{font-size:1rem;color:var(--text-secondary)}.main-stage{width:100%;min-height:calc(100vh - 80px);position:relative;transition:background-color .3s ease}.main-stage.sprinkle-mode,.main-stage.orbit-mode{overflow:hidden;height:calc(100vh - 80px)}.loading-state,.error-state{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary);font-size:1.2rem;text-align:center;padding:2rem}.error-state{color:#c33}.file-count{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.empty-favorites-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary);font-size:1.5rem;text-align:center;padding:2rem}.empty-favorites-state .empty-sub{font-size:1rem;margin-top:.5rem;opacity:.7}
