@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@900&display=swap";html,body,#root{height:100%;margin:0;padding:0;font-family:Arial,sans-serif}.layout-container{display:flex;height:100vh;width:100%}.sidebar{position:fixed;top:90px;left:20px;background:#fff;border-radius:22px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 6px 22px #00000026;z-index:1000;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;transform:translate(0);opacity:1}.sidebar.hidden{transform:translate(-150%);opacity:0;pointer-events:none}.button-section{display:flex;flex-direction:column;align-items:center;gap:6px}.icon-btn{width:56px;min-height:54px;border-radius:14px;cursor:pointer;padding:6px 4px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;box-shadow:none;color:#444;transition:background .2s ease,transform .2s ease,filter .2s ease}.icon-btn svg{color:#555}.icon-btn span{font-size:11px;font-weight:500;line-height:1;white-space:nowrap}.icon-btn:hover{background:#3388ff14;transform:none;filter:none}.icon-btn.inactive{opacity:.4;color:#adb5bd;pointer-events:auto}.icon-btn.logout-style{color:#adb5bd}.crown-btn{color:#596de2}.mypixel-btn{color:#38f}.friends-btn{color:#22c55e}.grid-btn{color:#ef4444}@media (max-width: 768px){.sidebar{top:90px;left:12px;transform:scale(.95)}.icon-btn{width:52px;min-height:50px}.icon-btn span{font-size:10px}}@media (max-width: 480px){.sidebar{top:80px;left:10px}.icon-btn{width:48px}}.map{width:100%;height:100%}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffffb3;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:2000}.spinner{border:4px solid #ddd;border-top:4px solid #0077ff;border-radius:50%;width:36px;height:36px;animation:spin 1s linear infinite;margin-bottom:8px}.search-container{position:absolute;top:20px;left:20px;z-index:2500;display:flex;flex-direction:column}.search-top{position:relative;display:flex;align-items:center;gap:6px;background:#fff;padding:8px 12px;border-radius:16px;box-shadow:0 4px 14px #0000002e;transition:all .2s;z-index:3001;width:380px;box-sizing:border-box}.search-top.open{border-bottom-left-radius:12px;border-bottom-right-radius:12px}.search-top input{flex:1;min-width:0;padding:8px 12px;border:1px solid #e5e5e5;border-radius:12px;outline:none;font-size:14px;background:#fafafa}.search-top input:focus{background:#fff;border-color:#38f}.search-top button{display:flex!important;align-items:center!important;justify-content:center!important;width:35px!important;height:35px!important;background-color:#00000080!important;color:#fff!important;border:none!important;border-radius:12px!important;padding:0!important;margin-left:5px!important;box-shadow:none!important}.search-top button svg,.search-top button i{font-size:20px!important}.search-popup{position:absolute;top:100%;left:0;width:100%;margin-top:8px;max-height:480px;background:#fff;border-radius:18px;box-shadow:0 10px 30px #00000026;overflow-y:auto;z-index:9999;animation:fadeInUp .25s ease-out}@keyframes fadeInUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.search-popup{position:absolute;top:100%;left:58px;width:357px;max-height:480px;background:#fff;border-radius:0 0 12px 12px;box-shadow:0 8px 20px #00000026;overflow-y:auto;z-index:9999;display:flex;flex-direction:column;transform-origin:top;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:scaleY(.9)}to{opacity:1;transform:scaleY(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.search-popup::-webkit-scrollbar{width:6px}.search-popup::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.section-title{font-size:13px;color:#888;font-weight:700;padding:10px 16px 6px;margin:0;background:#fdfdfd;border-bottom:1px solid #f0f0f0}.search-result-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid #f9f9f9}.search-result-item:last-child{border-bottom:none}.result-icon,.result-user-avatar{font-size:18px;margin-right:12px;width:24px;height:24px;display:flex;justify-content:center;align-items:center;flex-shrink:0}.result-user-avatar{background:#f0f0f0;border-radius:50%;font-size:14px}.result-info{display:flex;flex-direction:column;overflow:hidden}.result-title{font-size:15px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-sub{font-size:12px;color:#999;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-divider{height:6px;background-color:#f5f5f5;border-top:1px solid #eee;border-bottom:1px solid #eee;flex-shrink:0}.no-result{padding:20px;text-align:center;color:#aaa;font-size:13px}.close-search-popup{width:100%;padding:12px;background:#fff;border:none;border-top:1px solid #eee;color:#666;font-weight:600;cursor:pointer;font-size:13px;margin-top:auto}.close-search-popup:hover{background-color:#f9f9f9;color:#333}@media (max-width: 768px){.search-container{position:fixed!important;top:12px!important;left:12px!important;right:auto!important;width:auto!important;z-index:9000!important}.search-top{display:flex!important;align-items:center!important;width:calc(100vw - 320px)!important;padding:6px 8px!important;border-radius:18px!important;box-sizing:border-box!important;background:#fff!important}.search-top input{flex:1!important;min-width:0!important;width:0px!important;font-size:14px!important;padding:8px 5px!important;margin:0!important}.search-top button{display:flex!important;flex-shrink:0!important;width:36px!important;height:36px!important;background:#00000080!important;color:#fff!important;border-radius:12px!important;padding:0!important;margin-left:5px!important;align-items:center;justify-content:center}.search-top button svg,.search-top button i{font-size:30px!important}.search-popup{top:100%!important;width:100%!important;margin-top:10px!important;z-index:99999!important}}@media (max-width: 480px){.search-top{width:calc(100vw - 150px)!important}.search-top button{width:32px!important;height:32px!important;background:#00000080!important;color:#fff!important;border-radius:12px!important;padding:0!important;margin-left:5px!important}}.login-box{position:absolute;top:20px;right:20px;z-index:2000;display:flex;align-items:center;gap:12px;background:#fff;padding:7px 13px;border-radius:14px;box-shadow:0 2px 6px #00000026}.profile-line{display:flex;align-items:center;gap:10px}.profile-text,.guest-label{font-weight:700;color:#333;font-size:14px;white-space:nowrap}.user-emoji{font-size:22px;padding:4px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(#f3f3f3,#f3f3f3) padding-box,linear-gradient(135deg,#4f8bff,#3bb7ff,#60d4ff) border-box;border:3px solid transparent;transition:background .15s ease,transform .15s ease}.user-emoji:hover{background:linear-gradient(#e2e2e2,#e2e2e2) padding-box,linear-gradient(135deg,#4f8bff,#3bb7ff,#60d4ff) border-box;transform:scale(1.12)}.login-btn{padding:6px 12px;background-color:#38f;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;transition:background .2s}.login-btn:hover{background-color:#27d}.user-points{background:#fff;padding:20px 4.5px;border-radius:12px;box-shadow:0 2px 6px #0003;border:1px solid #ddd;display:flex;flex-direction:column;align-items:flex-start;gap:15px;font-weight:700;font-size:15px;color:#333;align-self:center;margin-top:-10px}.map-floating-group{position:fixed;bottom:28px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:auto}.map-float-btn{min-width:52px;height:52px;padding:6px 10px;border-radius:16px;background:#fff;color:#555;border:none;box-shadow:0 6px 18px #00000040;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;font-size:13px;font-weight:600;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.map-float-btn:hover{transform:scale(1.08);background:#f5f7fa}.map-float-btn{transition:opacity .25s ease,filter .25s ease}.map-float-btn.dimmed svg{opacity:.4}.map-float-btn svg{display:block}.map-float-btn span{font-size:11px;line-height:1;white-space:nowrap}.map-float-btn.locate{background:#38f;color:#fff}.map-float-btn.locate:hover{background:#27d}@media (max-width: 768px){.map-floating-group{bottom:20px;right:14px;gap:6px}.map-float-btn{min-width:46px;height:42px;border-radius:14px}.map-float-btn span{font-size:10px}}.mypixels-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:flex;align-items:center;justify-content:center;background:#00000073;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.mypixels-modal{width:min(520px,92vw);height:65vh;max-height:80vh;background:#fff;border-radius:24px;box-shadow:0 10px 30px #00000040,0 0 0 1px #ffffff0d;display:flex;flex-direction:column;overflow:hidden}.mypixels-header{display:flex;flex-direction:column;gap:10px;padding:14px 20px 12px;border-bottom:1px solid #f3f3f3}.mypixels-header-top{display:flex;align-items:center;justify-content:space-between}.mypixels-title{margin:0;font-size:15px;font-weight:600}.mypixels-close{border:none;background:transparent;font-size:18px;cursor:pointer}.mypixels-tabs{display:flex;gap:10px}.mypixels-tab{flex:1;padding:10px 12px;border:1px solid #e8e8e8;background:#fafafa;border-radius:12px;cursor:pointer;font-weight:800;font-size:13px;transition:transform .15s ease,background .15s ease,border .15s ease}.mypixels-tab:hover{transform:translateY(-1px);background:#f3f7ff}.mypixels-tab.active{background:#e8f2ff;border-color:#3388ff59;box-shadow:0 6px 14px #3388ff26}.mypixels-body{flex:1;padding:16px 18px 20px;overflow-y:auto}.mypixels-empty{padding:40px 24px;text-align:center;font-size:14px;color:#777}.upload-delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border:none;border-radius:50%;background:#0000008c;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.upload-delete-btn:hover{background:#000000bf;transform:scale(1.05)}.mypixels-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:10px}.mypixel-card{background:transparent;border:none;box-shadow:none;padding:0;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s ease}.mypixel-card:hover{transform:translateY(-4px)}.mypixel-thumb{width:100%;aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;background-color:#f4f4f4;border:2px solid #0000007e;box-sizing:border-box;position:relative;box-shadow:0 4px 8px #0000000f}.mypixel-thumb img,.mypixel-thumb video{width:100%;height:100%;object-fit:cover;transform:none;display:block}.mypixel-date{display:block;margin-top:8px;font-size:12px;color:#555;font-weight:600;text-align:center}@media (max-width: 900px){.mypixels-list{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.mypixels-list{grid-template-columns:repeat(2,1fr);gap:14px}.mypixel-card{padding:14px}.mypixel-thumb{border-radius:8px}.mypixel-date{font-size:12px;padding:4px 6px}}@media (max-width: 768px){.login-box{top:15px;background:none!important;box-shadow:none!important;border:none!important;padding:0!important;transition:top .35s cubic-bezier(.25,1.25,.5,1);z-index:5000!important}.profile-line .profile-text,.login-btn{display:none!important}.user-emoji{width:32px;height:32px;padding:0;border-radius:50%;border-width:3px;font-size:20px!important;background:linear-gradient(#f3f3f3,#f3f3f3) padding-box,linear-gradient(135deg,#4f8bff,#3bb7ff,#60d4ff) border-box;border:3px solid transparent;display:flex;align-items:center;justify-content:center;animation:emojiBounceDown .35s ease-out}.profile-line{display:flex;align-items:center;justify-content:center;padding:5px!important}@keyframes emojiBounceDown{0%{transform:translateY(-12px);opacity:0}45%{transform:translateY(6px);opacity:1}70%{transform:translateY(-3px)}to{transform:translateY(0)}}}.search-follow-btn{padding:3px 10px;font-size:12px;font-weight:600;border-radius:12px;border:none;cursor:pointer;background-color:#38f;color:#fff;margin-left:auto;flex-shrink:0;transition:background .2s}.search-follow-btn:hover{background-color:#27d}.search-follow-btn.following{background-color:#e0e0e0;color:#555;border:1px solid #ccc}.search-follow-btn.following:hover{background-color:#d6d6d6}@media (max-width: 768px){.custom-zoom-container{display:none!important}}.login-btn.icon-only{width:40px;height:30px;background-color:#3b82f6;color:#fff;border-radius:12px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 5px #0000001a;transition:all .2s ease;margin-left:8px}.login-btn.icon-only:hover{background-color:#2564ebbe;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.login-btn.icon-only:active{transform:translateY(0);box-shadow:0 2px 3px #0000001a}.history-card{position:relative}.history-delete-btn,.history-hide-btn{position:absolute;top:6px;background:#0009;border:none;color:#fff;border-radius:50%;width:22px;height:22px;font-size:12px;cursor:pointer}.history-delete-btn{right:6px}.history-hide-btn{right:34px}.skeleton{pointer-events:none}.skeleton-box{width:100%;height:100%;background:#eee;border-radius:8px;animation:pulse 1.4s ease-in-out infinite}.skeleton-line{height:10px;margin-top:6px;background:#eee;border-radius:6px;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.map-container{width:100%;height:100%;margin:0;padding:0;position:relative}.map-container-wrapper{flex:1;position:relative;width:100%;height:100%}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#fffc;z-index:3000;display:flex;flex-direction:column;justify-content:center;align-items:center;pointer-events:none;font-weight:700;color:#333}.spinner{width:50px;height:50px;border:6px solid #ccc;border-top-color:#4285f4;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}@keyframes spin{to{transform:rotate(360deg)}}.search-results li{padding:8px 12px;cursor:pointer;border-bottom:1px solid #ddd}.search-results li:hover{background-color:#f0f0f0}.fade-cell{transition:opacity .45s ease-out;opacity:1}.fade-cell.hidden{opacity:0!important}.custom-zoom-container{position:absolute;top:150px;right:20px;z-index:3000;-webkit-user-select:none;user-select:none}.zoom-vertical-pill{display:flex;flex-direction:column;align-items:center;background:#fff;border-radius:28px;overflow:hidden;box-shadow:0 4px 12px #0000002e;border:2px solid #191a1b}.zoom-btn{width:30px;height:48px;background:none;border:none;font-size:26px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background .15s ease}.zoom-btn:hover{background:#f2f2f2}.zoom-btn:active{transform:scale(.95)}.leaflet-gridLinePane-pane,.leaflet-pixelPane-pane{transition:opacity .4s ease,filter .4s ease!important}.grid-hidden .leaflet-gridLinePane-pane,.grid-hidden .leaflet-pixelPane-pane{opacity:0;filter:blur(4px);pointer-events:none;transition:opacity .5s ease,filter .5s ease}.sidebar .icon-btn{transition:all .3s ease}.logout-style{opacity:.5;filter:grayscale(100%)}.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#f0f5ffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:10000}.login-modal-content{background:#fff;color:#1f2937;padding:28px 24px;border-radius:22px;width:90%;max-width:360px;text-align:center;box-shadow:0 20px 40px #0000002e;animation:modalPop .25s ease;position:relative;display:flex;flex-direction:column}@keyframes modalPop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.login-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;width:100%}.login-modal-header h3{font-size:18px;font-weight:700;color:#1e3a8a;margin:0}.close-btn{background:none;border:none;font-size:20px;color:#64748b;cursor:pointer;transition:transform .15s ease,color .15s ease;padding:4px}.close-btn:hover{transform:scale(1.1);color:#1e3a8a}.login-modal-body{width:100%}.login-icon{font-size:52px;margin:14px 0;color:#3b82f6;filter:drop-shadow(0 0 10px rgba(59,130,246,.3))}.login-modal-body p{margin:6px 0;font-size:15px;color:#374151;line-height:1.6}.login-modal-body .sub-text{font-size:13px;color:#64748b}.login-modal-footer{margin-top:22px;display:flex;gap:10px;width:100%}.btn-primary{background:linear-gradient(45deg,#3b82f6,#2563eb);color:#fff;border:none;padding:12px 0;border-radius:14px;font-weight:700;cursor:pointer;flex:1;box-shadow:0 6px 18px #3b82f659;transition:transform .15s ease,box-shadow .15s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 26px #3b82f673}.btn-secondary{background:#f1f5f9;color:#1e3a8a;border:1px solid #c7d2fe;padding:12px 0;border-radius:14px;cursor:pointer;flex:1;transition:background .2s,border .2s}.btn-secondary:hover{background:#e0e7ff;border-color:#93c5fd}@media (max-width: 480px){.login-modal-content{width:100%!important;height:100%!important;max-width:none!important;border-radius:0!important;justify-content:space-between;padding:20px 24px 30px;box-shadow:none;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal-header{margin-top:10px}.login-modal-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.login-icon{font-size:64px;margin-bottom:20px}.login-modal-body p{font-size:17px}.login-modal-footer{flex-direction:column-reverse;gap:12px;padding-bottom:20px}.btn-primary,.btn-secondary{width:100%;padding:16px 0;font-size:16px}}.mypixels-empty-state{padding-top:48px;padding-bottom:32px;display:flex;justify-content:center}.empty-card{background:#f9fafb;border-radius:20px;padding:36px 28px;text-align:center;max-width:320px;box-shadow:0 10px 25px #00000014;animation:fadeUp .4s ease}.empty-icon{font-size:48px;margin-bottom:12px}.empty-title{font-size:18px;font-weight:700;margin-bottom:8px}.empty-desc{font-size:14px;color:#666;line-height:1.5;margin-bottom:20px}.empty-action-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:999px;padding:12px 20px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.empty-action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.grid-pane{transition:opacity .25s ease;opacity:1}.grid-pane.grid-hidden{opacity:.1}html,body{height:100%;overflow:hidden}.shorts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:999999;display:flex;align-items:center;justify-content:center}.shorts-card{width:100%;height:100%;position:relative}.shorts-card img,.shorts-card video{width:100%;height:100%;object-fit:cover}.shorts-info{position:absolute;bottom:80px;left:16px;color:#fff}.shorts-text{font-size:16px;font-weight:600;margin-bottom:8px}.shorts-actions{font-size:14px;opacity:.9}@keyframes pixelPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.shorts-root{width:100%;height:100%;overflow:hidden;touch-action:pan-y;background:#f5f5f5}.shorts-root--fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999999}.shorts-root--modal{position:relative;height:600px;background:transparent}.shorts-track{height:100%;transition:transform .35s ease-out}.shorts-card{position:relative;width:100%;height:100%;max-width:420px;margin:0 auto;display:flex;flex-direction:column;background:#f5f5f5}.shorts-top-space{height:48px;flex-shrink:0}.shorts-root--modal .shorts-top-space{height:12px}.shorts-media{margin:0 12px;aspect-ratio:4 / 5;background:#000;border-radius:14px;overflow:hidden}.shorts-media img,.shorts-media video{width:100%;height:100%;object-fit:cover}.shorts-ui{margin:12px;padding:14px 14px 18px;background:#fff;border-radius:16px;box-shadow:0 6px 20px #0000001f;color:#111}.shorts-profile{display:flex;align-items:center;gap:10px;margin-bottom:8px}.shorts-avatar{width:36px;height:36px;border-radius:50%;background:#eee;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden}.shorts-avatar img{width:100%;height:100%;object-fit:cover}.shorts-username{font-size:14px;font-weight:600}.shorts-text{font-size:14px;line-height:1.45;word-break:keep-all;color:#222}.shorts-actions{position:absolute;right:16px;bottom:120px;display:flex;flex-direction:column;align-items:center;gap:6px}.shorts-root--modal .shorts-actions{bottom:80px;right:20px}.shorts-actions button{width:52px;height:52px;border-radius:50%;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);font-size:24px;color:#fff;cursor:pointer;transition:transform .15s ease}.shorts-actions button:active{transform:scale(1.25)}.shorts-actions span{font-size:13px;color:#fff}.emoji-pop{position:absolute;pointer-events:none;font-size:18px;animation:emojiPop .8s ease-out forwards}@keyframes emojiPop{0%{opacity:0;transform:translate(0) scale(.6)}15%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--x),var(--y)) scale(1.4)}}@media (prefers-reduced-motion: reduce){.shorts-track{transition:none}.emoji-pop{animation:none;opacity:1}}.pvm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;padding:22px;z-index:9999;animation:fadeIn .25s ease;pointer-events:auto}.pvm-overlay.simple{padding:0}.pvm-fullscreen-img{width:100%;height:100%;object-fit:contain;animation:fadeIn .25s ease}.pvm-box{width:100%;max-width:480px;background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 10px 35px #00000040;animation:popIn .25s ease;margin:0 auto}@keyframes popIn{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.pvm-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid #e9e9e9}.pvm-user{display:flex;align-items:center;gap:6px}.pvm-emoji{font-size:22px}.pvm-userid{font-size:15px;font-weight:600;color:#333}.pvm-menu-btn{font-size:26px;cursor:pointer;padding:6px 8px}.pvm-slider{width:100%;aspect-ratio:4 / 5;max-height:600px;overflow:hidden;position:relative;background:#000}.pvm-slider-inner{display:flex;width:100%;height:100%;min-width:100%;transition:transform .35s cubic-bezier(.25,.46,.45,.94)}.pvm-slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.pvm-image,.pvm-video{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;z-index:1}.pvm-image.cover,.pvm-video.cover{width:100%;height:100%;object-fit:cover}.pvm-dots{display:flex;justify-content:center;gap:8px;margin:10px 0 6px}.pvm-dots .dot{width:7px;height:7px;background:#ccc;border-radius:50%;transition:all .3s ease}.pvm-dots .dot.active{width:18px;background:#3b82f6;border-radius:6px}.pvm-like-row{display:flex;align-items:center;gap:10px;padding:14px 18px 0}.pvm-like-btn{background:transparent;border:none;font-size:17px;cursor:pointer;font-weight:600}.pvm-like-count{font-size:15px;color:#444}.pvm-text{padding:10px 18px 20px;font-size:15px;white-space:pre-line;color:#333;line-height:1.45;max-height:120px;overflow-y:auto;-webkit-overflow-scrolling:touch}.pvm-text::-webkit-scrollbar{display:none}.pvm-text{scrollbar-width:none}.pvm-heart-burst{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;pointer-events:none}.pvm-heart-burst span{position:absolute;font-size:75px;opacity:0;animation:heartPop .7s ease forwards}.pvm-heart-burst span:nth-child(1){animation-delay:0s}.pvm-heart-burst span:nth-child(2){animation-delay:.08s}.pvm-heart-burst span:nth-child(3){animation-delay:.16s}@keyframes heartPop{0%{transform:translateY(10px) scale(.4);opacity:0}30%{transform:translateY(-20px) scale(1.1);opacity:1}to{transform:translateY(-50px) scale(1.25);opacity:0}}.pvm-options-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease;z-index:10000}.pvm-options-box{width:100%;max-width:480px;margin:0 auto;position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;padding:14px 0;animation:sheetUp .25s ease}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pvm-options-box:before{content:"";width:42px;height:5px;background:#ccc;border-radius:50px;margin:6px auto 12px}.pvm-options-box button{width:100%;display:flex;align-items:center;gap:10px;padding:14px 22px;background:transparent;border:none;border-bottom:1px solid #eee;font-size:16px;cursor:pointer;transition:background .15s}.pvm-options-box button:hover{background:#f8f8f8}.pvm-options-box button:last-child{border-bottom:none}.pvm-close{margin:10px 18px 0;padding:14px;background:#ffe5e5;border-radius:12px;border:1px solid #ffbebe;font-weight:700;text-align:center}.pvm-close:hover{background:#ffd4d4}.pvm-slider .slick-slider,.pvm-slider .slick-list,.pvm-slider .slick-track{height:100%!important}.pvm-slider .slick-slide{height:100%!important;display:flex!important;align-items:center;justify-content:center}.pvm-slider .slick-slide>div{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pvm-video,.pvm-image{max-width:100%;max-height:100%;object-fit:contain}.pvm-follow-btn{margin-left:10px;padding:4px 12px;font-size:13px;font-weight:600;border:none;border-radius:16px;cursor:pointer;background-color:#38f;color:#fff;transition:all .2s ease}.pvm-follow-btn:hover{background-color:#27d}.pvm-follow-btn.following{background-color:#e0e0e0;color:#555;border:1px solid #ccc}.pvm-follow-btn.following:hover{background-color:#d6d6d6;color:#333;content:"언팔로우"}.pvm-user{display:flex;align-items:center}.search-popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;min-height:100vh;z-index:99999!important;display:flex;align-items:center;justify-content:center;background:#00000059;pointer-events:auto}.search-popup-modal{width:360px;max-width:calc(100% - 32px);max-height:520px;background:#fff;border-radius:8px;box-shadow:0 12px 30px #00000040;position:relative;overflow:hidden;box-sizing:border-box;animation:popupScale .18s ease-out}@keyframes popupScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.search-popup-close-x{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#f3f4f6;font-size:18px;cursor:pointer;z-index:2}.search-popup-close-x:hover{background:#e5e7eb}.search-popup-content{max-height:420px;overflow-y:auto;padding-top:4px;box-sizing:border-box}.section-title{font-size:13px;color:#888;font-weight:700;padding:12px 16px 8px;background:#fdfdfd;border-bottom:1px solid #f0f0f0;margin:0}.search-results-list{list-style:none;padding:0;margin:0}.search-result-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;border-bottom:1px solid #f5f5f5;transition:background .12s}.search-result-item:hover{background-color:#f0f8ff}.result-icon{margin-right:12px;font-size:18px}.result-title{font-size:14px;font-weight:600;color:#333}.result-sub{font-size:12px;color:#999;margin-top:2px}.search-highlight{color:#3b82f6;font-weight:800}.close-search-popup{width:100%;padding:14px;background:#fff;border:none;border-top:1px solid #eee;font-weight:700;cursor:pointer}.close-search-popup:hover{background:#fafafa}@media (max-width: 768px){.search-popup-modal{width:calc(100% - 200px);max-height:90vh;border-radius:8px;z-index:99999!important}.search-popup-close-x{top:8px;right:17px}}@media (max-width: 480px){.search-popup-overlay{align-items:stretch;justify-content:stretch;z-index:99999!important}.search-popup-modal{width:100%!important;max-width:100%!important;height:100dvh;max-height:100dvh;border-radius:0;display:flex;flex-direction:column}.search-popup-content{flex:1;max-height:none;overflow-y:auto}.search-popup-close-x{top:8px;right:10px}.close-search-popup{padding:13px;font-size:16px;background:#fff;border-top:1px solid #eee}}.shorts-card{position:relative;overflow:hidden}.ad-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100000}.ad-modal{background:#fff;width:90%;max-width:420px;border-radius:14px;overflow:hidden;position:relative}.ad-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#000000a6;color:#fff;border:none;cursor:pointer;z-index:20;display:flex;align-items:center;justify-content:center}.ad-modal-media{max-height:55vh;overflow:hidden}.ad-modal-media img,.ad-modal-media video{width:100%;max-height:55vh;object-fit:cover;display:block}.ad-modal-content{padding:14px}.ad-modal-content .ad-link{display:inline-block;margin-top:10px;font-weight:600;color:#007aff;text-decoration:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:24px;border-radius:20px;width:320px;text-align:center;box-shadow:0 4px 15px #0000001a}.modal-title{margin-top:0;margin-bottom:20px;font-size:18px;font-weight:700;color:#333}.upload-dropzone{border:2px dashed #cdd3db;border-radius:18px;background:#fafbfc;cursor:pointer;display:flex;flex-direction:column;height:220px;overflow:hidden;transition:.25s;margin-bottom:20px}.upload-dropzone:hover{border-color:#4f46e5;background:#f9f8ff}.dropzone-top{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fafbfc;color:#888;gap:8px}.upload-icon{font-size:32px;margin-bottom:5px}.dropzone-top p{margin:0;font-size:15px}.dropzone-bottom{height:50px;display:flex;align-items:center;justify-content:center;background:#fff;border-top:1px solid #eee;color:#333;font-size:14px;font-weight:600}.upload-dropzone:hover .dropzone-bottom{color:#4f46e5}.upload-dropzone.has-preview{border-style:solid;padding:0;background:#000}.image-preview{width:100%;height:100%;object-fit:contain}.modal-actions{display:flex;flex-direction:column;gap:10px}.submit-btn{background:#3b82f6;color:#fff;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer}.submit-btn:disabled{background:#ccc;cursor:not-allowed}.cancel-btn{background:#f3f4f6;color:#333;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer}.crop-container{position:relative;width:100%;height:220px;background:#333;border-radius:18px;overflow:hidden;margin-bottom:10px}.zoom-slider-container{display:flex;align-items:center;gap:10px;margin-bottom:20px;font-size:14px;color:#555;padding:0 10px}.zoom-range{flex:1;cursor:pointer}* --------------------------------------------------- 😀 이모티콘 선택 팝업 스타일 --------------------------------------------------- */ .emoji-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;justify-content:flex-end;align-items:flex-start;padding-right:40px;padding-top:90px;z-index:99999!important;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.emoji-modal{background:#fff;padding:20px;border-radius:20px;width:280px;box-shadow:0 10px 30px #0003;animation:popupFade .2s ease-out;display:flex;flex-direction:column;gap:15px}@keyframes popupFade{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.emoji-user-info{font-size:16px;font-weight:700;color:#333;text-align:left;padding-left:4px}.emoji-box{background:#f8f9ff;border:2px solid #eef2ff;padding:15px;border-radius:16px}.emoji-title{margin:0 0 12px;font-size:15px;font-weight:600;color:#555;text-align:center}.emoji-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.emoji-item{font-size:24px;cursor:pointer;text-align:center;transition:transform .15s ease;padding:4px;border-radius:8px}.emoji-item:hover{transform:scale(1.2);background-color:#fff;box-shadow:0 2px 5px #0000001a}.emoji-actions{display:flex;flex-direction:column;gap:4px;margin-top:5px}.emoji-menu-btn{width:100%;padding:12px 0;text-align:center;font-size:15px;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:.2s;color:#fff}.emoji-menu-btn.login,.emoji-menu-btn.logout{background:#3b82f6;padding:18px 0}.emoji-menu-btn.login:hover,.emoji-menu-btn.logout:hover{background:#2563eb}.emoji-menu-btn.feedback{background:#4b5563b2;padding:5px 0}.emoji-menu-btn.feedback:hover{background:#ff0202b0}.emoji-close-btn{width:100%;padding:12px 0;background:#f3f4f6;color:#4b5563;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:15px;margin-top:4px}.emoji-close-btn:hover{background:#e5e7eb}.emoji-menu-btn.photo-upload{background:#ffffff48;color:#3b82f6;border:2px solid #dbeafe;padding:7px 0;margin-bottom:16px;font-size:14px;box-shadow:0 2px 5px #3b82f60d}.emoji-menu-btn.photo-upload:hover{background:#f7efff;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f626}.emoji-menu-btn.photo-upload:active{transform:translateY(0);box-shadow:none}.emoji-modal-overlay.upload-layer{z-index:3100}.photo-preview-area{width:100%;height:200px;background-color:#f3f4f6;border-radius:12px;border:2px dashed #d1d5db;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;position:relative;margin-bottom:12px}.photo-preview-img{width:100%;height:100%;object-fit:cover}.photo-placeholder p{color:#9ca3af;font-size:14px;margin-bottom:8px}.photo-select-btn{background:#fff!important;color:#4b5563!important;border:1px solid #d1d5db!important;padding:6px 16px!important;font-size:13px!important;border-radius:20px!important;cursor:pointer;display:inline-block;margin-top:8px;box-shadow:0 1px 2px #0000000d;position:absolute;bottom:10px;z-index:10}.photo-select-btn:hover{background:#f9fafb!important}.photo-description-input{width:100%;height:60px;border:1px solid #e5e7eb;border-radius:12px;padding:10px;font-size:14px;resize:none;outline:none;font-family:inherit;margin-bottom:10px}.photo-description-input:focus{border-color:#3b82f6;background-color:#eff6ff}.emoji-guest-lock{padding:20px 10px;text-align:center;background:#f8f9fa;border-radius:12px;border:1px dashed #dee2e6;margin-top:10px}.emoji-guest-lock .lock-icon{font-size:32px;margin-bottom:10px}.emoji-guest-lock p{font-size:14px;color:#666;line-height:1.6;margin-bottom:15px}.emoji-menu-btn.login-link{background-color:#3eaaff;color:#fff;font-weight:700;border-radius:8px;padding:8px 16px;font-size:13px}.emoji-menu-btn.login-link:hover{background-color:#2b95e9}@media (max-width: 480px){.emoji-modal{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.emoji-user-info{position:sticky;top:0;background:#fff;padding:12px 0;z-index:5}.emoji-modal-overlay{justify-content:center;align-items:center;padding:0}.emoji-modal{width:100vw;height:100vh;max-width:none;max-height:none;border-radius:0;padding:16px;display:flex;flex-direction:column;justify-content:flex-start;animation:none}.emoji-modal{overflow-y:auto}.emoji-close-btn{padding:16px 0;font-size:16px}.emoji-item{font-size:20px}.emoji-grid{gap:10px}.photo-preview-area{height:160px}}.profile-gradient-border{width:120px;height:120px;padding:4px;border-radius:50%;background:linear-gradient(135deg,#4a90e2,#7f7fd5,#91eae4);display:flex;align-items:center;justify-content:center;box-sizing:border-box;transition:transform .2s ease}.profile-gradient-border:hover{transform:scale(1.05)}.profile-photo{width:100%;height:100%;border-radius:50%;object-fit:cover;background:#fff;display:block}.profile-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:99999;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.profile-modal-content{background:#fff;border-radius:20px;width:90%;max-width:420px;box-shadow:0 10px 30px #00000040;animation:profileModalFadeIn .3s ease-out}@keyframes profileModalFadeIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.adslot-box-vertical{display:flex;flex-direction:row;align-items:stretch;gap:12px;padding:12px;background:#fff;border-radius:18px;box-shadow:0 4px 25px #00000026;position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:auto;max-width:95vw;z-index:1000}.adslot{position:relative;width:100px;display:flex;flex-direction:column;border-radius:12px;overflow:hidden;cursor:pointer;background:#f8f9fa;border:1px solid rgba(0,0,0,.05);transition:all .2s ease;flex-shrink:0}.adslot:hover{transform:translateY(-5px);box-shadow:0 6px 16px #0003}.ad-media{width:100%;height:100%;object-fit:cover;display:block}.ad-card-top{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:#f8f9fa}.ad-image{width:100%;height:100%;object-fit:cover;display:block}.ad-card-bottom{position:relative;padding:7px 3px 5px;background:#fff;display:flex;flex-direction:column;gap:0px}.ad-card-bottom .ad-badge{position:absolute;top:1px;left:4px;font-size:6px;font-weight:900;letter-spacing:.3px;color:#fff;background:#111;padding:2px 3px;border-radius:3px;line-height:1;z-index:1}.ad-title{font-size:10px;font-weight:800;color:#222;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ad-desc{font-size:8px;color:#adb5bd;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.adslot.upload-slot{position:relative;align-self:center;flex-shrink:0;z-index:20;width:14px;min-height:80px;border-radius:999px;background:transparent;border:1px dashed rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.65;overflow:visible;transition:opacity .25s ease,border-color .25s ease,background .25s ease}.adslot.upload-slot:before{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:999px;z-index:1}.upload-plus{position:relative;z-index:2;font-size:14px;font-weight:600;color:#00000059;transition:all .25s ease;pointer-events:none}.adslot.upload-slot:hover{opacity:1;border-color:#007bff73;background:radial-gradient(circle at center,rgba(0,123,255,.08),transparent 70%)}.adslot.upload-slot:hover .upload-plus{color:#007bff;transform:scale(1.2)}.adslot.upload-slot:active:after{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;border-radius:50%;background:#007bff2e;animation:pulse .6s ease-out;z-index:0}@keyframes pulse{0%{transform:scale(.2);opacity:.8}to{transform:scale(1);opacity:0}}.ripple-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.adslot.upload-slot:active .ripple-layer:after{content:"";position:absolute;left:50%;top:50%;width:10px;height:10px;background:#007bff4d;border-radius:50%;transform:translate(-50%,-50%);animation:ripple .6s ease-out}@keyframes ripple{0%{transform:translate(-50%,-50%) scale(.2);opacity:.6}to{transform:translate(-50%,-50%) scale(6);opacity:0}}.adslot.upload-slot.logout-style{opacity:.35;border-color:#0000000d;cursor:default;pointer-events:auto}.adslot.upload-slot.logout-style .upload-plus{color:#0003}.ad-badge{position:absolute;top:6px;left:6px;font-size:8px;font-weight:900;color:#fff;background:#212529bf;padding:2px 5px;border-radius:3px;text-transform:uppercase;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2}.ad-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:#dee2e6}@media (max-width: 768px){.adslot-box-vertical{bottom:15px;gap:8px;padding:10px;left:230px!important;right:auto!important}.adslot{width:90px}.adslot.upload-slot{width:20px;min-height:75px}.upload-text{font-size:18px}}@media (max-width: 480px){.adslot-box-vertical{bottom:16px;gap:6px;padding:8px;left:20px!important;right:auto!important;transform:none!important}.adslot{width:80px}.adslot.upload-slot{width:15px;min-height:65px}.upload-text{font-size:12px}.ad-desc{display:none}}.adslot.filled .ad-card-bottom .ad-title,.adslot.filled .ad-card-bottom .ad-desc{display:none}.upload-slot:before{content:none!important}.upload-slot:after{display:none!important}.ad-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center}.ad-modal-content{background-color:#fff;width:90%;max-width:500px;border-radius:16px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;overflow:hidden;animation:fadeInScale .2s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ad-modal-header{padding:20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.ad-modal-title{margin:0;font-size:1.25rem;font-weight:700;color:#333}.ad-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;transition:color .2s}.ad-modal-close:hover{color:#333}.ad-modal-body{padding:30px 20px;display:flex;flex-direction:column;gap:15px}.ad-target-option{display:flex;align-items:center;padding:15px 20px;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s ease;background:#fff}.ad-target-option:hover{border-color:#bbdefb;background-color:#f8fbff}.ad-target-option.selected{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 1px #3b82f6 inset}.option-icon{font-size:24px;margin-right:15px;width:40px;height:40px;background-color:#f5f5f5;border-radius:50%;display:flex;align-items:center;justify-content:center}.ad-target-option.selected .option-icon{background-color:#fff}.option-title{font-weight:700;font-size:1rem;color:#333;margin-bottom:4px}.option-desc{font-size:.85rem;color:#666}.option-arrow{margin-left:auto;width:20px;height:20px;position:relative;transition:transform .25s ease}.option-arrow:before{content:"";position:absolute;top:6px;left:6px;width:6px;height:6px;border-right:2px solid #6b7280;border-bottom:2px solid #6b7280;transform:rotate(45deg)}.ad-target-option.selected .option-arrow{transform:rotate(180deg)}.ad-modal-footer{padding:20px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:10px}.btn-cancel{padding:10px 20px;border-radius:8px;border:1px solid #ddd;background:#fff;color:#666;font-weight:600;cursor:pointer}.btn-next{padding:10px 24px;border-radius:8px;border:none;background:#3b82f6;color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.btn-next:disabled{background:#a5b4fc;cursor:not-allowed}.btn-next:not(:disabled):hover{background:#2563eb}.upload-slot{display:flex;justify-content:center;align-items:center;height:25px;padding:1px;background:#f0f6ff;border:2px dashed #4f8bff}.upload-slot:hover{background:#e4f0ff}.upload-text{font-size:13px;font-weight:700;color:#37f}.ad-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;z-index:9999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ad-modal-content{background:#fff;width:90%;max-width:380px;border-radius:16px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}.ad-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.ad-modal-title{margin:0;font-size:18px;font-weight:700;color:#333}.ad-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#999}.ad-modal-body{padding:20px;display:flex;flex-direction:column;gap:12px}.ad-target-option{display:flex;flex-direction:column;align-items:stretch;padding:12px 16px;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s ease;background-color:#fff}.ad-target-option:hover{background-color:#f9f9f9;border-color:#bbb}.ad-target-option.selected{border-color:#007bff;background-color:#f0f7ff}.option-icon{font-size:24px;margin-right:16px}.option-text{display:flex;flex-direction:column}.option-title{font-size:15px;font-weight:600;color:#333}.option-desc{font-size:12px;color:#777;margin-top:2px}.ad-modal-footer{padding:16px 20px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:10px;background-color:#fafafa}.btn-cancel{padding:10px 16px;border-radius:8px;border:1px solid #ddd;background:#fff;color:#666;font-weight:600;cursor:pointer}.btn-next{padding:10px 24px;border-radius:8px;border:none;background:#007bff;color:#fff;font-weight:600;cursor:pointer}.btn-next:disabled{background:#ccc;cursor:not-allowed}.back-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#666;margin-right:10px}.search-mode{display:flex;flex-direction:column;gap:10px;min-height:300px}.search-input-box{position:relative;display:flex;align-items:center}.search-input-box input{width:100%;padding:12px 14px;font-size:15px;border:1px solid #ddd;border-radius:8px;outline:none;transition:border-color .2s}.search-input-box input:focus{border-color:#007bff}.spinner-small{position:absolute;right:12px;animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-my-location{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background-color:#f1f3f5;color:#007bff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-my-location:hover{background-color:#e9ecef}.search-result-list{list-style:none;padding:0;margin:0;border:1px solid #eee;border-radius:8px;max-height:180px;overflow-y:auto;background:#fff}.search-result-list li{padding:10px 12px;border-bottom:1px solid #f5f5f5;cursor:pointer;display:flex;flex-direction:column}.search-result-list li:hover{background-color:#f8f9fa}.search-result-list li:last-child{border-bottom:none}.res-name{font-size:14px;font-weight:700;color:#333}.res-sub{font-size:11px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-res{padding:15px;text-align:center;color:#999;font-size:13px}.selected-preview{margin-top:auto;padding:12px;background-color:#e3f2fd;color:#1565c0;border-radius:8px;font-size:14px;text-align:center}.ad-target-option.expandable{border:1px solid #e5e7eb;border-radius:14px;padding:14px;margin-bottom:12px;cursor:pointer;transition:all .25s ease;background:#fff}.ad-target-option.expandable.selected{border-color:#4f46e5;background:#f8f9ff}.option-header{display:flex;align-items:center;gap:12px}.option-expanded{max-height:0;overflow:hidden;opacity:0;transition:all .3s ease;font-size:14px;color:#374151}.ad-target-option.selected .option-expanded{max-height:200px;opacity:1;margin-top:12px}.option-warning{margin-top:8px;font-size:13px;color:#b91c1c}.btn-select-target{margin-top:12px;padding:8px 12px;border-radius:8px;border:none;background:#4f46e5;color:#fff;cursor:pointer}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.creation-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.creation-modal-content{background:#fff;width:92%;max-width:520px;border-radius:18px;overflow:hidden;box-shadow:0 20px 60px #00000040;animation:slideUp .35s ease;font-family:Pretendard,Noto Sans KR,sans-serif}.creation-header{padding:18px 22px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;font-size:20px;font-weight:700;background:#fafafa}.creation-body{padding:24px;display:flex;flex-direction:column;gap:22px}.file-upload-btn{width:93%;min-height:50px;padding:16px;text-align:center;background:linear-gradient(135deg,#eef3ff,#f8faff);color:#2563eb;border:2px dashed #93b4ff;border-radius:14px;display:flex;cursor:pointer;font-weight:700;font-size:15px;transition:all .2s ease;margin-bottom:20px}.file-upload-btn:hover{background:#eef2ff;border-color:#3b82f6;transform:translateY(-1px)}.preview-grid{display:flex;gap:12px}.preview-item{position:relative;width:90px;height:90px;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;background:#f9fafb}.remove-btn{position:absolute;top:6px;right:6px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:12px}.main-tag{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:11px;text-align:center;padding:4px 0;font-weight:600}.input-group label{display:block;font-size:14px;font-weight:600;margin-bottom:6px;color:#374151}.input-group input,.input-group textarea{width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;transition:border .2s}.input-group input:focus,.input-group textarea:focus{border-color:#3b82f6;outline:none}.creation-footer{padding:16px 20px;border-top:1px solid #f0f0f0;text-align:right;background:#fafafa}.submit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:12px 28px;border-radius:12px;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s ease}.submit-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px #3b82f659}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.preview-grid{display:flex;gap:12px;flex-wrap:wrap}.preview-item{width:110px;height:110px;border-radius:14px;overflow:hidden;border:1px solid #e5e7eb;background:#f9fafb;position:relative}.preview-item img,.preview-item video{width:100%;height:100%;object-fit:cover}.friend-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:4000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.friend-modal-box{background:#fff;width:360px;max-width:90%;height:500px;border-radius:20px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}.friend-modal-header{padding:18px 20px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;background:#fff}.friend-modal-title{font-size:18px;font-weight:700;margin:0;color:#333;display:flex;align-items:center;gap:8px}.friend-count{font-size:14px;background:#f0f0f0;color:#666;padding:2px 8px;border-radius:12px}.friend-modal-close{background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:4px;transition:color .2s}.friend-modal-close:hover{color:#333}.friend-modal-body{flex:1;overflow-y:auto;padding:10px 0;background:#fbfbfb}.friend-list{list-style:none;padding:0;margin:0}.friend-item{display:flex;align-items:center;padding:12px 20px;cursor:pointer;transition:background .2s;background:#fff;border-bottom:1px solid #f7f7f7}.friend-item:hover{background-color:#f0f8ff}.friend-avatar-wrapper{width:48px;height:48px;margin-right:15px;flex-shrink:0}.friend-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid #eee}.friend-avatar-placeholder{width:100%;height:100%;border-radius:50%;background:#eef2f5;display:flex;align-items:center;justify-content:center;font-size:24px}.friend-info{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}.friend-name{font-size:16px;font-weight:600;color:#333;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-location{font-size:12px;font-weight:500}.friend-location.active{color:#3b82f6}.friend-location.unknown{color:#aaa}.go-btn{padding:6px 12px;background:#eef2ff;color:#4f46e5;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer}.friend-item:hover .go-btn{background:#4f46e5;color:#fff}.friend-empty-state{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#888;padding:20px}.empty-icon{font-size:40px;margin-bottom:10px}.friend-empty-state p{font-size:16px;font-weight:600;margin:0 0 5px;color:#555}.empty-sub{font-size:13px;line-height:1.5;color:#999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-container{display:flex;height:100vh;width:100vw;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.image-section{flex:1.2;background:#eaeaea;position:relative;overflow:hidden}.map-frame{position:relative;width:100%;height:100%;overflow:hidden}.map-bg{width:100%;height:100%;object-fit:cover;object-position:center center}.memory-pin{position:absolute;display:flex;flex-direction:column;align-items:center;z-index:5;transform:translate(-50%,-50%)}.memory-pin img{width:150px;height:150px;object-fit:cover;border-radius:18px;box-shadow:0 12px 30px #00000059;transition:transform .3s ease}.memory-pin:hover img{transform:scale(1.05)}.memory-pin.large img{width:190px;height:190px}@media (max-width: 1024px){.memory-pin img{width:120px;height:120px;border-radius:12px;box-shadow:0 6px 15px #0000004d}.memory-pin.large img{width:140px;height:140px}.memory-pin:hover img{transform:none}}.pin-1{top:20%;left:20%}.pin-2{top:80%;right:15%}.pin-4{top:50%;right:45%}.pin-3{bottom:25%;left:70%}.pin-dot{width:14px;height:14px;background:#ff6b3d;border-radius:50%;border:3px solid #fff;position:relative;box-shadow:0 0 #ff6b3d99;animation:pulse 1.8s infinite;margin-top:-10px;z-index:6}@keyframes pulse{0%{box-shadow:0 0 #ff6b3d99}70%{box-shadow:0 0 0 10px #ff6b3d00}to{box-shadow:0 0 #ff6b3d00}}.pin-label{background:#fff;padding:10px 14px;border-radius:14px;margin-top:8px;text-align:center;box-shadow:0 8px 20px #00000040;min-width:120px}.pin-label strong{display:block;font-size:.9rem;font-weight:700;color:#333}.pin-label span{font-size:.75rem;color:#888}.map-attribution{position:absolute;bottom:15px;right:15px;font-size:10px;color:#ffffffb3;z-index:10;pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.5)}.policy-link-btn{background:none;border:none;color:#666;text-decoration:underline;cursor:pointer;font-size:.8rem;margin-left:5px;padding:0}.policy-link-btn:hover{color:#333}.policy-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.policy-modal-content{background:#fff;padding:30px;border-radius:16px;width:90%;max-width:500px;box-shadow:0 10px 25px #0003;text-align:left;animation:fadeIn .3s ease}.policy-modal-content h3{margin-top:0;margin-bottom:15px;font-size:1.2rem;color:#333}.policy-text{max-height:300px;overflow-y:auto;background:#f9f9f9;padding:15px;border-radius:8px;font-size:.9rem;color:#555;line-height:1.6;margin-bottom:20px;border:1px solid #eee}.policy-text h4{margin-top:15px;margin-bottom:5px;color:#444}.close-policy-btn{width:100%;padding:12px;background:#222;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background .2s}.close-policy-btn:hover{background:#444}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-section{flex:1;display:flex;justify-content:center;align-items:center;padding:40px}.login-card{width:100%;max-width:420px}.logo{font-family:Montserrat,sans-serif;font-size:3.4rem;font-weight:900;letter-spacing:-.08em;margin-bottom:6px;color:#111}.welcome-text{font-size:1.6rem;font-weight:700;margin-bottom:36px;line-height:1.3;color:#333}.button-group{display:flex;flex-direction:column;gap:12px}.btn{height:52px;border-radius:999px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;justify-content:center;align-items:center}.google-btn{border:1px solid #e5e7eb;background:#fff;color:#333}.google-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014;border-color:#d1d5db}.google-icon{width:18px;height:18px;margin-right:10px}.guest-btn{background:#f4f4f5;border:none;color:#555}.guest-btn:hover{background:#e5e7eb}.footer{margin-top:28px;font-size:.8rem;color:#888;line-height:1.5}@media (max-width: 768px){.login-container{flex-direction:column}.image-section{display:none}.form-section{padding:20px}.logo{font-size:2.5rem}.welcome-text{font-size:1.4rem}}
