@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fb;color:#1a1a2e;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:#4f6ef7;text-decoration:none}a:hover{text-decoration:underline}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:1rem;background:#f8f9fb}.spinner{width:2.5rem;height:2.5rem;border:3px solid #e8eaf0;border-top-color:#4f6ef7;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page{max-width:480px;margin:0 auto;min-height:100vh;background:#fff}.page-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #eef0f4;background:#fff;position:sticky;top:0;z-index:10}.page-header h1{font-size:1.125rem;font-weight:700;color:#1a1a2e}.page-body{padding:1.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.75rem 1.5rem;border-radius:.75rem;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,#4f6ef7,#3b5de7);color:#fff;box-shadow:0 2px 8px #4f6ef74d}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #4f6ef766}.btn-secondary{background:#f3f4f8;color:#4a5068;border:1px solid #e2e5ec}.btn-secondary:hover:not(:disabled){background:#eaecf2}.btn-danger{background:#fff5f5;color:#e53e3e;border:1px solid #feb2b2}.btn-danger:hover:not(:disabled){background:#fed7d7}.btn-ghost{background:transparent;color:#6b7280;padding:.5rem}.btn-block{width:100%}.btn-sm{padding:.5rem 1rem;font-size:.8125rem;border-radius:.625rem}.btn-lg{padding:1rem 2rem;font-size:1rem;border-radius:.875rem}.card{background:#fff;border:1px solid #eef0f4;border-radius:1rem;padding:1.125rem;margin-bottom:.75rem;transition:all .2s}.card:hover{border-color:#c7d2fe;box-shadow:0 2px 12px #4f6ef714}.card:active{transform:scale(.985)}.form-group{margin-bottom:1.125rem}.form-label{display:block;font-size:.8125rem;font-weight:600;margin-bottom:.375rem;color:#4a5068}.form-input{width:100%;padding:.75rem 1rem;border:1.5px solid #e2e5ec;border-radius:.75rem;font-size:.9375rem;outline:none;font-family:inherit;background:#fafbfc;transition:all .2s}.form-input:focus{border-color:#4f6ef7;box-shadow:0 0 0 3px #4f6ef71a;background:#fff}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem}.image-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:.375rem;cursor:pointer}.user-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:#fafbfc;border:1px solid #eef0f4;font-size:.875rem;color:#4a5068;border-radius:1rem}.badge{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-blue{background:#eef2ff;color:#4338ca}.badge-green{background:#ecfdf5;color:#059669}.badge-gray{background:#f3f4f8;color:#6b7280}.badge-purple{background:#f5f3ff;color:#7c3aed}.tabs{display:flex;border-bottom:2px solid #eef0f4;margin-bottom:1rem;gap:.25rem}.tab{padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:#9ca3af;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit;transition:all .2s}.tab.active{color:#4f6ef7;border-bottom-color:#4f6ef7;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(min-width:481px){.modal-overlay{align-items:center;padding:1rem}}.modal-content{background:#fff;border-radius:1.25rem 1.25rem 0 0;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;padding:1.5rem}@media(min-width:481px){.modal-content{border-radius:1.25rem}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{font-size:1.125rem;font-weight:700}.modal-close{background:#f3f4f8;border:none;width:2rem;height:2rem;border-radius:50%;font-size:1.125rem;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center}.empty-state{text-align:center;padding:3rem 1rem;color:#b0b7c3}.empty-state p{font-size:.9375rem}.home-hero{background:linear-gradient(135deg,#4f6ef7,#7c5cfc,#a855f7);padding:2.5rem 1.5rem 2rem;text-align:center;position:relative;overflow:hidden}.home-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 40%)}.home-hero *{position:relative}.home-hero h1{font-size:1.625rem;font-weight:700;color:#fff;margin-bottom:.25rem;letter-spacing:-.02em}.home-hero p{font-size:.875rem;color:#fffc}.home-container{max-width:480px;margin:0 auto;min-height:100vh;background:#fff}.home-body{padding:1.25rem 1.25rem 2rem}.step-bar{display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem 0;gap:0}.step-item{display:flex;align-items:center;gap:.5rem}.step-dot{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;background:#fff3;color:#ffffff80;transition:all .3s}.step-dot.active{background:#fff;color:#4f6ef7;box-shadow:0 2px 8px #00000026}.step-dot.done{background:#ffffffe6;color:#4f6ef7}.step-label{font-size:.75rem;color:#ffffff80;font-weight:500;display:none}.step-label.active{color:#fff;font-weight:600;display:block}.step-line{width:2rem;height:2px;background:#fff3;margin:0 .25rem}.step-line.done{background:#ffffffb3}.point-card{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1px solid #bbf7d0;border-radius:1rem;padding:1.125rem 1.25rem;margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:center}.point-label{font-size:.8125rem;color:#6b7280;margin-bottom:.125rem}.point-value{font-size:1.75rem;font-weight:700;color:#059669;letter-spacing:-.02em}.loc-card{background:#fff;border:1.5px solid #eef0f4;border-radius:1rem;padding:1.125rem 1.25rem;margin-bottom:.625rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:1rem}.loc-card:hover{border-color:#c7d2fe;box-shadow:0 4px 16px #4f6ef714}.loc-card:active{transform:scale(.985)}.loc-icon{width:3rem;height:3rem;border-radius:.875rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff);display:flex;align-items:center;justify-content:center;font-size:1.375rem;flex-shrink:0}.loc-info{flex:1;min-width:0}.loc-name{font-size:1.0625rem;font-weight:600;color:#1a1a2e;margin-bottom:.125rem}.loc-meta{font-size:.8125rem;color:#9ca3af;display:flex;gap:.75rem}.loc-arrow{color:#c7d2fe;font-size:1.25rem;flex-shrink:0}.album-card{background:#fff;border:1.5px solid #eef0f4;border-radius:1rem;padding:1.125rem 1.25rem;margin-bottom:.625rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:1rem}.album-card:hover{border-color:#c7d2fe;box-shadow:0 4px 16px #4f6ef714}.album-card:active{transform:scale(.985)}.album-icon{width:3rem;height:3rem;border-radius:.875rem;background:linear-gradient(135deg,#fef3c7,#fde68a);display:flex;align-items:center;justify-content:center;font-size:1.375rem;flex-shrink:0}.album-info{flex:1;min-width:0}.album-name{font-size:1.0625rem;font-weight:600;color:#1a1a2e;margin-bottom:.125rem}.album-meta{font-size:.8125rem;color:#9ca3af}.add-card{border:2px dashed #d5dae4;border-radius:1rem;padding:1rem;margin-bottom:.625rem;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;color:#4f6ef7;font-weight:600;font-size:.9375rem;background:#fafbfc;transition:all .2s;width:100%;font-family:inherit}.add-card:hover{border-color:#4f6ef7;background:#eef2ff}.section-title{font-size:.8125rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.875rem;padding-left:.125rem}.login-card{background:#fff;border-radius:1.25rem;padding:2.5rem 1.5rem;text-align:center;box-shadow:0 4px 24px #0000000f}.login-card h2{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}.login-card p{font-size:.9375rem;color:#9ca3af;margin-bottom:2rem;line-height:1.6}.google-btn{width:100%;padding:.875rem 1.5rem;border-radius:.875rem;font-size:1rem;font-weight:600;border:none;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.625rem;background:#fff;color:#374151;border:1.5px solid #e2e5ec;box-shadow:0 1px 4px #0000000f;transition:all .2s}.google-btn:hover{box-shadow:0 2px 8px #0000001a;border-color:#d1d5db}.google-btn:active{transform:scale(.98)}.google-btn svg{width:1.25rem;height:1.25rem}.inline-form{display:flex;gap:.5rem;margin-top:.75rem}.inline-form .form-input{flex:1}.back-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;color:#9ca3af;font-weight:500;cursor:pointer;background:none;border:none;font-family:inherit;padding:0;margin-bottom:1.25rem;transition:color .2s}.back-link:hover{color:#4f6ef7}.showcase{margin-bottom:1.5rem;text-align:center}.showcase-image-wrap{position:relative;width:100%;aspect-ratio:1 / 1;border-radius:1.25rem;overflow:hidden;background:#f3f4f8;margin-bottom:.875rem;box-shadow:0 8px 32px #0000001a}.showcase-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s ease-in-out}.showcase-image.active{opacity:1}.showcase-caption{font-size:.9375rem;font-weight:600;color:#1a1a2e;margin-bottom:.625rem;min-height:1.5em}.showcase-dots{display:flex;justify-content:center;gap:.5rem}.showcase-dot{width:.5rem;height:.5rem;border-radius:50%;background:#d5dae4;border:none;padding:0;cursor:pointer;transition:all .3s}.showcase-dot.active{width:1.5rem;border-radius:.25rem;background:#4f6ef7}.features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.feature-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;background:#fafbfc;border:1px solid #eef0f4;border-radius:1rem;transition:all .2s}.feature-item:hover{border-color:#c7d2fe}.feature-icon{width:2.75rem;height:2.75rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;background:linear-gradient(135deg,#eef2ff,#e8e0ff)}.feature-text{display:flex;flex-direction:column}.feature-text strong{font-size:.9375rem;font-weight:600;color:#1a1a2e;line-height:1.3}.feature-text span{font-size:.8125rem;color:#9ca3af;margin-top:.125rem}
