*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#4f46e5;--color-primary-light:#818cf8;--color-bg:#f9fafb;--color-surface:#fff;--color-text:#111827;--color-text-muted:#6b7280;--color-border:#e5e7eb;--color-danger:#ef4444;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--font-size-sm:14px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:24px;--safe-area-bottom:env(safe-area-inset-bottom,0px);--safe-area-top:env(safe-area-inset-top,0px)}body.dark-mode{--color-primary:#818cf8;--color-primary-light:#a5b4fc;--color-bg:#111827;--color-surface:#1f2937;--color-text:#f3f4f6;--color-text-muted:#9ca3af;--color-border:#374151;--color-danger:#f87171}body.dark-mode #root{background-color:#f9fafb;background-color:var(--color-bg)}body.dark-mode input,body.dark-mode textarea{background-color:#fff;background-color:var(--color-surface);border-color:#e5e7eb;border-color:var(--color-border);color:#111827;color:var(--color-text)}html{-webkit-text-size-adjust:100%;font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--color-bg);color:#111827;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif;line-height:1.5}#root,body{min-height:100dvh}#root{background-color:#fff;background-color:var(--color-surface);display:flex;flex-direction:column;margin:0 auto;max-width:430px;position:relative}[role=button],a,button{-webkit-tap-highlight-color:transparent;cursor:pointer;touch-action:manipulation}button{background:none;border:none;font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}input,textarea{-webkit-appearance:none;appearance:none;background-color:#fff;background-color:var(--color-surface);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-sm);color:#111827;color:var(--color-text);font-family:inherit;font-size:16px;font-size:var(--font-size-md);outline:none;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);width:100%}input:focus,textarea:focus{border-color:#4f46e5;border-color:var(--color-primary)}ol,ul{list-style:none}img{display:block;max-width:100%}.app{flex-direction:column;min-height:100dvh}.app,.page{display:flex}.page{flex:1 1;overflow-y:auto;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-xl) + var(--safe-area-bottom))}.page,.splash-screen{flex-direction:column}.splash-screen{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#a855f7);display:flex;gap:8px;justify-content:center;min-height:100dvh}.splash-logo{animation:splash-float 2s ease-in-out infinite;font-size:64px;line-height:1}@keyframes splash-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.splash-title{color:#fff;font-size:32px;font-weight:800;letter-spacing:-.5px;margin-top:8px}.splash-subtitle{color:#ffffffb3;font-size:15px;margin-top:4px}.splash-dots{display:flex;gap:6px;margin-top:24px}.splash-dot{animation:dot-blink 1.4s ease-in-out infinite;background-color:#fff6;border-radius:50%;height:8px;width:8px}.splash-dot:nth-child(2){animation-delay:.2s}.splash-dot:nth-child(3){animation-delay:.4s}@keyframes dot-blink{0%,80%,to{background-color:#ffffff4d;transform:scale(1)}40%{background-color:#ffffffe6;transform:scale(1.3)}}.login-page{background:linear-gradient(160deg,#4f46e5,#7c3aed 50%,#a855f7);gap:var(--spacing-lg);justify-content:center;min-height:100dvh;padding:var(--spacing-xl) var(--spacing-lg)}.login-header,.login-page{align-items:center;display:flex;flex-direction:column}.login-header{gap:var(--spacing-xs);text-align:center}.login-logo-circle{align-items:center;background-color:#ffffff26;border-radius:50%;display:flex;height:80px;justify-content:center;margin-bottom:var(--spacing-xs);width:80px}.login-logo{font-size:44px;line-height:1}.login-title{color:#fff;font-size:32px;font-weight:800;letter-spacing:-.5px}.login-subtitle{color:#ffffffb3;font-size:var(--font-size-sm)}.login-card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;gap:var(--spacing-lg);padding:var(--spacing-lg);width:100%}.login-card,.login-form{display:flex;flex-direction:column}.login-form{gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:500}.btn-primary{background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-md);font-weight:600;margin-top:var(--spacing-xs);padding:14px;transition:opacity .15s}.btn-primary:active{opacity:.85}.btn-primary:disabled{opacity:.5}.btn-link{background:none;border:none;color:var(--color-primary);font-size:inherit;font-weight:600;padding:0;text-decoration:underline}.login-divider{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-md)}.login-divider:after,.login-divider:before{background-color:var(--color-border);content:"";flex:1 1;height:1px}.btn-kakao{align-items:center;background-color:#fee500;border:none;border-radius:var(--radius-md);color:#3c1e1e;display:flex;font-size:var(--font-size-md);font-weight:600;gap:8px;justify-content:center;padding:14px;transition:filter .15s;width:100%}.btn-kakao:active{filter:brightness(.93)}.login-footer{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center}.login-error{background-color:#fee2e2;color:var(--color-danger)}.login-error,.login-message{border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.login-message{background-color:#d1fae5;color:#065f46}.tab-bar{background-color:var(--color-surface);border-top:1px solid var(--color-border);bottom:0;display:flex;left:50%;max-width:430px;padding-bottom:var(--safe-area-bottom);position:fixed;transform:translateX(-50%);width:100%;z-index:100}.tab-item{align-items:center;color:var(--color-text-muted);display:flex;flex:1 1;flex-direction:column;gap:3px;justify-content:center;padding:8px 0;transition:color .15s}.tab-item--active{color:var(--color-primary)}.tab-icon{align-items:center;display:flex;justify-content:center}.tab-icon,.tab-icon svg{height:24px;width:24px}.tab-label{font-size:10px;font-weight:500;letter-spacing:-.2px}.home-page{display:flex;flex-direction:column;min-height:100%}.home-sticky-top{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;z-index:10}.home-header{align-items:center;display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm)}.home-title{font-size:var(--font-size-xl);font-weight:700;letter-spacing:-.5px}.home-header-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.home-search-btn{align-items:center;border-radius:50%;color:var(--color-text);display:flex;height:36px;justify-content:center;transition:background-color .12s;width:36px}.home-search-btn:active{background-color:var(--color-bg)}.home-search-btn svg{height:22px;width:22px}.home-profile-btn{align-items:center;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;display:flex;gap:5px;padding:5px 10px 5px 6px;transition:background-color .12s}.home-profile-btn:active{background-color:#ede9fe}.home-profile-emoji{font-size:18px;line-height:1}.home-profile-name{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-bar-wrap{border-top:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md)}.search-bar,.search-bar-wrap{align-items:center;display:flex;gap:var(--spacing-sm)}.search-bar{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex:1 1;padding:8px 12px}.search-bar:focus-within{border-color:var(--color-primary)}.search-bar-icon{color:var(--color-text-muted);flex-shrink:0;height:18px;width:18px}.search-bar-input{background:none;border:none;color:var(--color-text);flex:1 1;font-size:var(--font-size-sm);min-width:0;outline:none}.search-bar-clear,.search-bar-input::placeholder{color:var(--color-text-muted)}.search-bar-clear{align-items:center;display:flex;flex-shrink:0;height:18px;justify-content:center;width:18px}.search-bar-clear svg{height:16px;width:16px}.search-bar-cancel{color:var(--color-primary);flex-shrink:0;font-size:var(--font-size-sm);font-weight:600;white-space:nowrap}.search-result-count{color:var(--color-text-muted);font-size:12px;font-weight:600;padding:var(--spacing-xs) 0}.timeline-empty-icon{font-size:36px;margin-bottom:var(--spacing-sm)}.filter-sort-row{align-items:center;border-top:1px solid var(--color-border);display:flex}.filter-sort-row .sort-wrap{padding-left:var(--spacing-md)}.category-filter-bar{display:flex;flex:1 1;gap:var(--spacing-xs);min-width:0;overflow-x:auto;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) var(--spacing-xs);scrollbar-width:none}.category-filter-bar:only-child{border-top:1px solid var(--color-border);padding-left:var(--spacing-md)}.category-filter-bar::-webkit-scrollbar{display:none}.category-filter-btn{align-items:center;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;color:var(--color-text-muted);display:inline-flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:500;gap:4px;padding:5px 12px;transition:background-color .12s,color .12s,border-color .12s;white-space:nowrap}.category-filter-btn--active{background-color:#ede9fe;border-color:var(--color-primary);color:var(--color-primary);font-weight:700}.sort-wrap{flex-shrink:0;position:relative}.sort-chip{align-items:center;background:none;border:none;border-radius:50%;color:var(--color-text-muted);display:inline-flex;flex-shrink:0;height:28px;justify-content:center;padding:0;width:28px}.sort-chip svg{height:16px;width:16px}.sort-chip:active{background-color:var(--color-bg)}.sort-menu{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001a;left:0;overflow:hidden;position:absolute;top:34px;z-index:20}.sort-menu button{background:none;color:var(--color-text);display:block;font-size:var(--font-size-sm);font-weight:500;padding:10px 20px;text-align:left;white-space:nowrap;width:100%}.sort-menu button:active{background-color:var(--color-bg)}.sort-menu-item--active{color:var(--color-primary)!important;font-weight:700!important}.timeline{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + 80px)}.timeline-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:2;padding:var(--spacing-xl) 0;text-align:center}.timeline-error{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.timeline-error p{color:var(--color-danger);font-size:var(--font-size-sm);word-break:break-all}.timeline-error button{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;text-decoration:underline}.year-group{flex-direction:column}.year-group,.year-header{display:flex;gap:var(--spacing-sm)}.year-header{align-items:center;padding:var(--spacing-xs) 0}.year-label{color:var(--color-text);font-size:var(--font-size-lg);font-weight:700;letter-spacing:-.5px}.year-count{color:var(--color-text-muted);font-size:var(--font-size-sm)}.record-title-row{align-items:center;display:flex;gap:var(--spacing-sm);justify-content:space-between;min-width:0}.record-title{flex:1 1;min-width:0}.record-dday{color:var(--color-primary)}.record-badge-upcoming,.record-dday{flex-shrink:0;font-size:11px;font-weight:700;white-space:nowrap}.record-badge-upcoming{background-color:#fef3c7;border:1px solid #fcd34d;border-radius:6px;color:#92400e;padding:2px 6px}.record-category-chip{align-items:center;align-self:flex-start;background-color:#ede9fe;border-radius:10px;color:var(--color-primary);display:inline-flex;font-size:11px;font-weight:600;gap:3px;padding:2px 7px}.record-meta-location{color:var(--color-text-muted)}.record-memo{margin-top:2px}.fab{align-items:center;background-color:var(--color-primary);border-radius:50%;bottom:calc(72px + var(--safe-area-bottom));box-shadow:0 4px 16px #4f46e566;color:#fff;display:flex;height:56px;justify-content:center;position:fixed;right:calc(50% - 215px + var(--spacing-md));transition:transform .15s,box-shadow .15s;width:56px}.fab:active{box-shadow:0 2px 8px #4f46e54d;transform:scale(.93)}.fab svg{height:28px;width:28px}@media (max-width:430px){.fab{right:var(--spacing-md)}}.ad-card{align-items:center;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;margin-top:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg)}.ad-label{align-self:flex-end;color:var(--color-text-muted);font-size:10px;font-weight:700;letter-spacing:1px}.ad-icon{font-size:28px;line-height:1}.ad-text{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600}.ad-contact{color:var(--color-text-muted);font-size:12px}.skeleton-list{flex-direction:column}.skeleton-card,.skeleton-list{display:flex;gap:var(--spacing-sm)}.skeleton-card{align-items:flex-start;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.skeleton-emoji{background-color:#e5e7eb;border-radius:var(--radius-sm);flex-shrink:0;height:40px;width:40px}.skeleton-body{display:flex;flex:1 1;flex-direction:column;gap:8px;padding-top:2px}.skeleton-line{background-color:#e5e7eb;border-radius:6px;height:12px}.skeleton-line--title{height:14px;width:65%}.skeleton-line--sub{width:40%}.skeleton-line--meta{width:55%}.skeleton-thumb{background-color:#e5e7eb;border-radius:var(--radius-sm);flex-shrink:0;height:60px;width:60px}.shimmer{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.category-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100%}.cat-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;justify-content:space-between;padding:0 var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.cat-header-title-main{font-size:var(--font-size-xl);font-weight:700}.cat-header-title{font-size:var(--font-size-lg);font-weight:600}.cat-header-back{align-items:center;color:var(--color-text);display:flex;height:36px;justify-content:center;width:36px}.cat-header-back svg{height:24px;width:24px}.cat-manage-btn{align-items:center;color:var(--color-primary);display:flex;font-size:var(--font-size-sm);font-weight:600;gap:2px}.cat-manage-btn svg{height:16px;width:16px}.cat-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);padding:var(--spacing-md)}.cat-grid-item{align-items:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:6px;justify-content:center;min-height:80px;padding:var(--spacing-lg) var(--spacing-sm);transition:background-color .15s}.cat-grid-item:active{background-color:#ede9fe;border-color:var(--color-primary-light)}.cat-grid-emoji{font-size:28px;line-height:1}.cat-grid-name{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;text-align:center}.cat-grid-count{color:var(--color-text-muted);font-size:12px}.cat-record-list{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.cat-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-xl) 0;text-align:center}.record-card{align-items:flex-start;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-md)}.record-card-left{align-items:center;background-color:var(--color-bg);border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.record-emoji{font-size:22px}.record-card-body{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.record-title{color:var(--color-text);font-size:var(--font-size-md);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-meta{font-size:12px}.record-memo,.record-meta{color:var(--color-text-muted)}.record-memo{font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-thumbnail{border-radius:var(--radius-sm);flex-shrink:0;height:60px;overflow:hidden;width:60px}.record-thumbnail img{height:100%;object-fit:cover;width:100%}.map-page{background-color:var(--color-bg);display:flex;flex-direction:column}.map-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;height:56px;justify-content:space-between;padding:0 var(--spacing-md)}.map-header-title{font-size:var(--font-size-xl);font-weight:700}.map-profile-btn{align-items:center;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;display:flex;gap:5px;padding:5px 10px 5px 6px;transition:background-color .12s}.map-profile-btn:active{background-color:#ede9fe}.map-profile-emoji{font-size:18px;line-height:1}.map-profile-name{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-container{height:calc(100dvh - 112px - env(safe-area-inset-bottom, 0px));min-height:300px;width:100%}.map-error{color:var(--color-text-muted);flex:1 1;font-size:var(--font-size-sm);justify-content:center}.map-error,.map-label{align-items:center;display:flex}.map-label{cursor:pointer;flex-direction:column;pointer-events:auto}.map-label-bubble{align-items:center;background-color:#fff;border:1.5px solid #e5e7eb;border:1.5px solid var(--color-border,#e5e7eb);border-radius:20px;box-shadow:0 2px 8px #0000002e;display:flex;gap:4px;max-width:140px;padding:5px 10px;transition:background-color .15s,border-color .15s;white-space:nowrap}.map-label:active .map-label-bubble{background-color:#ede9fe;border-color:#7c3aed;border-color:var(--color-primary,#7c3aed)}.map-label-cat{color:#7c3aed;color:var(--color-primary,#7c3aed);flex-shrink:0;font-size:12px;font-weight:600}.map-label-title{color:#1f2937;font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis}.map-label-stem{height:8px;width:2px}.map-label-dot,.map-label-stem{background-color:#7c3aed;background-color:var(--color-primary,#7c3aed)}.map-label-dot{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0000004d;height:10px;width:10px}.memories-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100%}.memories-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;padding:0 var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.memories-title{font-size:var(--font-size-xl);font-weight:700}.memories-content{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md)}.memories-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:2;padding:var(--spacing-xl) 0;text-align:center}.memories-empty-icon{font-size:40px;margin-bottom:var(--spacing-sm)}.year-filter{-webkit-overflow-scrolling:touch;display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:2px}.year-filter::-webkit-scrollbar{display:none}.year-btn{background-color:var(--color-surface);border:1.5px solid var(--color-primary);border-radius:20px;color:var(--color-primary);cursor:pointer;flex-shrink:0;font-size:var(--font-size-sm);font-weight:600;padding:8px 16px;transition:all .15s}.year-btn:active{opacity:.8}.year-btn--active{background-color:var(--color-primary);color:#fff}.year-summary{color:var(--color-text);font-size:var(--font-size-sm);font-weight:700;padding:0 2px}.anniversary-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.anniversary-section-label{color:var(--color-text);font-size:13px;font-weight:700}.anniversary-card{align-items:center;background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-md)}.anniversary-card:active{opacity:.9}.anniversary-emoji{flex-shrink:0;font-size:28px}.anniversary-text{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.anniversary-message{color:#fff;font-size:var(--font-size-sm);line-height:1.4}.anniversary-message strong{font-weight:800}.anniversary-sub{color:#ffffffb3;font-size:12px}.anniversary-days{background-color:#fff3;border-radius:var(--radius-sm);color:#fff;flex-shrink:0;font-size:15px;font-weight:800;padding:4px 8px}.memories-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.memories-section-header{align-items:center;background-color:var(--color-primary);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:8px var(--spacing-md)}.memories-period{color:#fff;font-size:var(--font-size-sm);font-weight:700}.memories-date{color:#ffffffbf;font-size:12px}.memory-card{align-items:flex-start;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-md)}.memory-card-left,.memory-card:active{background-color:var(--color-bg)}.memory-card-left{align-items:center;border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.memory-emoji{font-size:22px}.memory-card-body{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.memory-title{color:var(--color-text);font-size:var(--font-size-md);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memory-category{align-self:flex-start;background-color:#ede9fe;border-radius:10px;color:var(--color-primary);display:inline-block;font-size:11px;font-weight:600;padding:2px 7px}.memory-meta{font-size:12px}.memory-memo,.memory-meta{color:var(--color-text-muted)}.memory-memo{font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memory-thumbnail{border-radius:var(--radius-sm);flex-shrink:0;height:60px;overflow:hidden;width:60px}.memory-thumbnail img{height:100%;object-fit:cover;width:100%}.settings-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100%}.settings-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;padding:0 var(--spacing-md)}.settings-title{font-size:var(--font-size-xl);font-weight:700}.settings-body{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md)}.profile-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:var(--spacing-md);padding:var(--spacing-lg)}.profile-avatar,.profile-card{align-items:center;display:flex}.profile-avatar{background-color:var(--color-primary);border-radius:50%;color:#fff;flex-shrink:0;font-size:24px;font-weight:700;height:56px;justify-content:center;width:56px}.profile-info{display:flex;flex-direction:column;gap:3px;min-width:0}.profile-name{color:var(--color-text);font-size:var(--font-size-md);font-weight:700}.profile-email,.profile-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{color:var(--color-text-muted);font-size:var(--font-size-sm)}.settings-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-group-label{color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;padding:0 var(--spacing-xs);text-transform:uppercase}.settings-list{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.settings-row{align-items:center;background:none;border-bottom:1px solid var(--color-border);display:flex;gap:var(--spacing-md);padding:14px var(--spacing-md);text-align:left;transition:background-color .12s;width:100%}.settings-row:last-child{border-bottom:none}.settings-row:active{background-color:var(--color-bg)}.settings-row--static{cursor:default}.settings-row--static:active{background-color:initial}.settings-row-icon{flex-shrink:0;font-size:20px;text-align:center;width:28px}.settings-row-label{color:var(--color-text);flex:1 1;font-size:var(--font-size-md);font-weight:500}.settings-row--danger .settings-row-label{color:var(--color-danger)}.settings-row-arrow{color:var(--color-text-muted);flex-shrink:0;height:18px;width:18px}.settings-row-value{color:var(--color-text-muted);font-size:var(--font-size-sm)}.settings-toggle{flex-shrink:0}.settings-toggle input[type=checkbox]{display:none}.settings-toggle .toggle-track{align-items:center;background-color:var(--color-border);border-radius:13px;cursor:pointer;display:flex;height:26px;padding:2px;transition:background-color .2s;width:44px}.settings-toggle input:checked+.toggle-track{background-color:var(--color-primary)}.settings-toggle .toggle-thumb{background-color:#fff;border-radius:50%;box-shadow:0 1px 3px #00000026;height:22px;transition:transform .2s;width:22px}.settings-toggle input:checked+.toggle-track .toggle-thumb{transform:translateX(18px)}.settings-group-hint{color:var(--color-text-muted);font-size:12px;line-height:1.5;padding:var(--spacing-xs) var(--spacing-xs) 0}.lang-toggle-btn{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:4px 12px;transition:background-color .15s}.lang-toggle-btn:active{background-color:var(--color-border)}a.settings-row{color:inherit;cursor:pointer;text-decoration:none}.emoji-picker-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(6,1fr);margin-top:var(--spacing-sm)}.emoji-picker-btn{background:var(--color-bg);border:2px solid #0000;border-radius:var(--radius-sm);cursor:pointer;font-size:22px;line-height:1;padding:8px 4px;text-align:center;transition:border-color .1s,background-color .1s}.emoji-picker-btn--active{background-color:#ede9fe;border-color:var(--color-primary)}.add-record-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100dvh}.add-record-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;padding:0 var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.add-record-header h2{flex:1 1;font-size:var(--font-size-lg);font-weight:600;text-align:center}.add-record-body{flex:1 1;gap:var(--spacing-lg);padding:var(--spacing-md)}.add-record-body,.form-section{display:flex;flex-direction:column}.form-section{gap:var(--spacing-sm)}.section-label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600}.section-label-sub{color:var(--color-text-muted);font-weight:400}.form-error{background-color:#fee2e2;border-radius:var(--radius-sm);color:var(--color-danger);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.category-chips{display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:var(--spacing-xs);scrollbar-width:none}.category-chips::-webkit-scrollbar{display:none}.category-chip{align-items:center;background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:20px;color:var(--color-text-muted);display:flex;font-size:var(--font-size-sm);gap:4px;padding:6px 12px;transition:all .15s;white-space:nowrap}.category-chip--active{background-color:#ede9fe;border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.category-chip--custom{border-style:dashed}.chip-emoji{font-size:16px;line-height:1}.custom-category-input{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.custom-name-input{width:100%}.custom-emoji-label{color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500;margin-bottom:-4px}.location-selected{align-items:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;gap:var(--spacing-sm);padding:10px var(--spacing-md)}.location-selected svg{color:var(--color-primary);flex-shrink:0;height:16px;width:16px}.location-selected span{color:var(--color-text);flex:1 1;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-clear{color:var(--color-text-muted);flex-shrink:0;font-size:18px;line-height:1}.location-search-wrap{display:flex;flex-direction:column;gap:var(--spacing-xs)}.location-search-row{display:flex;gap:var(--spacing-sm)}.location-input{flex:1 1}.location-search-btn{background-color:var(--color-primary);border-radius:var(--radius-sm);color:#fff;flex-shrink:0;font-size:var(--font-size-sm);font-weight:600;padding:0 var(--spacing-md);white-space:nowrap}.location-results{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.location-results li{border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:10px var(--spacing-md)}.location-results li:last-child{border-bottom:none}.location-results li:active{background-color:var(--color-bg)}.place-name{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600}.place-addr{color:var(--color-text-muted);font-size:12px}.date-row{align-items:center;display:flex;gap:var(--spacing-sm)}.date-field{display:flex;flex:1 1;flex-direction:column;gap:4px}.date-field-label{color:var(--color-text-muted);font-size:12px}.date-field input{font-size:var(--font-size-sm);padding:10px var(--spacing-sm)}.date-field input:disabled{background-color:var(--color-bg);color:var(--color-text-muted)}.date-divider{color:var(--color-text-muted);font-size:18px;padding-top:20px}.date-toggles{gap:var(--spacing-lg);margin-top:var(--spacing-xs)}.date-toggles,.ongoing-toggle{align-items:center;display:flex}.ongoing-toggle{cursor:pointer;gap:var(--spacing-sm)}.ongoing-toggle input[type=checkbox]{display:none}.toggle-track{align-items:center;background-color:var(--color-border);border-radius:13px;display:flex;flex-shrink:0;height:26px;padding:3px;transition:background-color .2s;width:44px}.ongoing-toggle input:checked+.toggle-track{background-color:var(--color-primary)}.toggle-thumb{background-color:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:20px;transition:transform .2s;width:20px}.ongoing-toggle input:checked+.toggle-track .toggle-thumb{transform:translateX(18px)}.toggle-label{color:var(--color-text);font-size:var(--font-size-sm)}.photo-grid{display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:var(--spacing-xs);scrollbar-width:none}.photo-grid::-webkit-scrollbar{display:none}.photo-item{border-radius:var(--radius-sm);flex-shrink:0;height:80px;overflow:hidden;position:relative;width:80px}.photo-item img{height:100%;object-fit:cover;width:100%}.photo-badge-main{background-color:var(--color-primary);border-radius:4px;font-size:10px;font-weight:700;left:4px;padding:1px 5px;z-index:1}.photo-badge-main,.photo-remove{color:#fff;position:absolute;top:4px}.photo-remove{background-color:#0009;border-radius:50%;font-size:14px;height:20px;line-height:1;right:4px;width:20px}.photo-add,.photo-remove{align-items:center;display:flex;justify-content:center}.photo-add{background-color:var(--color-bg);border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);flex-shrink:0;height:80px;width:80px}.photo-add svg{height:28px;width:28px}.photo-menu-backdrop{align-items:flex-end;background-color:#0006;display:flex;inset:0;position:fixed;z-index:200}.photo-menu-sheet{background-color:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin:0 auto;max-width:430px;overflow:hidden;padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom, 0px));width:100%}.photo-menu-btn{align-items:center;background:none;color:var(--color-text);display:flex;font-size:var(--font-size-md);font-weight:500;gap:var(--spacing-md);padding:18px var(--spacing-lg);text-align:left;width:100%}.photo-menu-btn:active{background-color:var(--color-bg)}.photo-menu-btn svg{color:var(--color-primary);flex-shrink:0;height:22px;width:22px}.photo-menu-divider{background-color:var(--color-border);height:1px;margin:0 var(--spacing-lg)}.photo-menu-cancel{background-color:var(--color-bg);border-radius:var(--radius-md);color:var(--color-text-muted);display:block;font-size:var(--font-size-md);font-weight:600;margin:var(--spacing-md) var(--spacing-lg) 0;padding:14px;text-align:center;width:calc(100% - var(--spacing-lg)*2)}.photo-viewer-backdrop{align-items:center;background-color:#000000eb;display:flex;inset:0;justify-content:center;padding:var(--spacing-md);position:fixed;z-index:300}.photo-viewer-backdrop img{border-radius:var(--radius-sm);max-height:90dvh;max-width:100%;object-fit:contain}.photo-viewer-close{align-items:center;background-color:#fff3;border-radius:50%;color:#fff;display:flex;font-size:20px;height:36px;justify-content:center;position:absolute;right:16px;top:16px;width:36px}.photo-item img{cursor:pointer}textarea{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:var(--font-size-md);line-height:1.6;outline:none;padding:var(--spacing-sm) var(--spacing-md);resize:none;width:100%}textarea:focus{border-color:var(--color-primary)}.kakao-share-section{padding:0 var(--spacing-md) var(--spacing-md)}.btn-kakao-share{align-items:center;background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;display:flex;font-size:var(--font-size-md);font-weight:600;gap:var(--spacing-sm);justify-content:center;padding:14px;transition:opacity .15s;width:100%}.btn-kakao-share svg{flex-shrink:0;height:20px;width:20px}.btn-kakao-share:disabled{opacity:.5}.btn-kakao-share:active{opacity:.85}.add-record-footer{background-color:var(--color-surface);border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + var(--safe-area-bottom))}.btn-save{background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;flex:1 1;font-size:var(--font-size-md);font-weight:600;padding:14px;transition:opacity .15s}.btn-save:disabled{opacity:.5}.btn-save:active{opacity:.85}.btn-delete-record{background-color:#fee2e2;border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-md);font-weight:600;padding:14px 20px;transition:opacity .15s;white-space:nowrap}.btn-delete-record:disabled{opacity:.5}.btn-delete-record:active{opacity:.8}.share-profiles{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.share-profile-row{align-items:center;border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;justify-content:space-between;padding:14px var(--spacing-md)}.share-profile-row:last-child{border-bottom:none}.share-profile-row:active{background-color:var(--color-bg)}.share-profile-info{align-items:center;display:flex;gap:var(--spacing-sm)}.share-profile-emoji{font-size:20px}.share-profile-name{color:var(--color-text);font-size:var(--font-size-md);font-weight:500}.share-profile-tag{background-color:#ede9fe;border-radius:10px;color:var(--color-primary);flex-shrink:0;font-size:11px;font-weight:600;padding:2px 7px}.share-toggle{align-items:center;display:flex;flex-shrink:0}.share-toggle input[type=checkbox]{display:none}.share-toggle input:checked+.toggle-track{background-color:var(--color-primary)}.share-toggle input:checked+.toggle-track .toggle-thumb{transform:translateX(18px)}.cat-manage-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100dvh}.cat-manage-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;padding:0 var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.cat-manage-header h2{flex:1 1;font-size:var(--font-size-lg);font-weight:600;text-align:center}.header-add-btn{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap}.cat-manage-list{border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;margin:var(--spacing-md);overflow:hidden}.cat-manage-item,.cat-manage-list{background-color:var(--color-surface);display:flex}.cat-manage-item{align-items:center;border-bottom:1px solid var(--color-border);gap:var(--spacing-sm);padding:14px var(--spacing-md)}.cat-manage-item:last-child{border-bottom:none}.cat-manage-item--dragging{border-bottom:1px solid var(--color-border)!important;border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001f;opacity:.95}.cat-item-drag{align-items:center;color:var(--color-text-muted);cursor:grab;display:flex;flex-shrink:0;height:28px;justify-content:center;touch-action:none;width:28px}.cat-item-drag:active{cursor:grabbing}.cat-item-drag svg{height:18px;width:18px}.cat-item-emoji{font-size:24px;text-align:center;width:32px}.cat-item-name{color:var(--color-text);flex:1 1;font-size:var(--font-size-md)}.cat-item-actions{display:flex;gap:var(--spacing-sm)}.btn-icon{align-items:center;border-radius:var(--radius-sm);display:flex;height:32px;justify-content:center;width:32px}.btn-icon svg{height:18px;width:18px}.btn-edit{background-color:#ede9fe;color:var(--color-primary)}.btn-delete{background-color:#fee2e2;color:var(--color-danger)}.modal-backdrop{align-items:flex-end;background-color:#0006;display:flex;inset:0;position:fixed;z-index:200}.modal-sheet{background-color:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;gap:var(--spacing-md);margin:0 auto;max-width:430px;padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + var(--safe-area-bottom));width:100%}.modal-title{font-size:var(--font-size-lg);font-weight:700;text-align:center}.modal-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal-field label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:500}.modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.btn-modal-cancel{border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);flex:1 1;font-weight:500}.btn-modal-cancel,.btn-modal-save{font-size:var(--font-size-md);padding:13px}.btn-modal-save{background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;flex:2 1;font-weight:600;transition:opacity .15s}.btn-modal-save:disabled{opacity:.5}.profile-manage-page{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:100dvh}.profile-manage-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;height:56px;padding:0 var(--spacing-md)}.profile-manage-header h2{flex:1 1;font-size:var(--font-size-md);font-weight:700;text-align:center}.header-back{align-items:center;color:var(--color-text);display:flex;height:36px;justify-content:center;width:36px}.header-back svg{height:24px;width:24px}.header-spacer{width:36px}.profile-manage-body{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md)}.profile-section-label{color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:var(--spacing-xs);padding:0 var(--spacing-xs);text-transform:uppercase}.profile-list{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.profile-item{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);padding:12px var(--spacing-md)}.profile-item:last-child{border-bottom:none}.profile-item--active{background-color:#f5f3ff}.profile-item-emoji{flex-shrink:0;font-size:26px}.profile-item-text{align-items:center;display:flex;flex:1 1;gap:var(--spacing-sm);min-width:0}.profile-item-name{color:var(--color-text);font-size:var(--font-size-md);font-weight:500}.profile-item--active .profile-item-name{color:var(--color-primary);font-weight:700}.profile-item-badge{background-color:#ede9fe;border-radius:10px;color:var(--color-primary);flex-shrink:0;font-size:11px;font-weight:600;padding:2px 7px}.profile-item-actions{align-items:center;display:flex;flex-shrink:0;gap:4px}.profile-item-select{background-color:#ede9fe;border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;padding:6px 12px;transition:background-color .12s}.profile-item-select:active{background-color:#ddd6fe}.profile-item--editing{background-color:#faf5ff;border-left:3px solid var(--color-primary)}.profile-item-transfer{background:none;color:var(--color-text-muted);padding:6px 8px}.profile-item-transfer:active{color:var(--color-primary)}.profile-item-transfer:disabled{opacity:.5}.profile-item-transfer svg{display:block;height:18px;width:18px}.profile-item-edit{background:none;color:var(--color-text-muted);padding:6px 8px;transition:color .12s}.profile-item-edit--active,.profile-item-edit:active{color:var(--color-primary)}.profile-item-edit svg{display:block;height:18px;width:18px}.profile-item-delete{background:none;color:var(--color-text-muted);padding:6px 8px}.profile-item-delete:active{color:var(--color-danger)}.profile-item-delete svg{display:block;height:18px;width:18px}.profile-add-btn{align-items:center;background-color:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-primary);display:flex;font-size:var(--font-size-md);font-weight:600;gap:var(--spacing-sm);justify-content:center;padding:14px;transition:background-color .12s;width:100%}.profile-add-btn:active{background-color:#f5f3ff}.profile-add-btn svg{height:20px;width:20px}.profile-add-form{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.profile-add-form-title{color:var(--color-text);font-size:var(--font-size-sm);font-weight:700;margin-bottom:2px}.profile-emoji-preview{align-items:center;background-color:var(--color-bg);border:2px solid var(--color-primary);border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto var(--spacing-xs);width:64px}.profile-emoji-preview span{font-size:36px;line-height:1}.profile-emoji-label{color:var(--color-text-muted);font-size:12px;font-weight:600;margin-bottom:2px;text-align:center}.profile-emoji-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(8,1fr)}.profile-emoji-btn{background:var(--color-bg);border:2px solid #0000;border-radius:var(--radius-sm);font-size:22px;line-height:1;padding:6px 2px;text-align:center;transition:border-color .1s,background-color .1s}.profile-emoji-btn--active{background-color:#ede9fe;border-color:var(--color-primary)}.profile-name-input{margin-top:var(--spacing-xs);width:100%}.profile-add-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.btn-cancel{background:none;border:1px solid var(--color-border);color:var(--color-text-muted);padding:8px 16px}.btn-cancel,.btn-confirm{border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600}.btn-confirm{background-color:var(--color-primary);color:#fff;padding:8px 20px}.btn-confirm:disabled{opacity:.6}.profile-manage-hint{display:flex;flex-direction:column;gap:4px;padding:0 var(--spacing-xs)}.profile-manage-hint p{color:var(--color-text-muted);font-size:12px;line-height:1.5}.onboarding{background:linear-gradient(135deg,#4f46e5,#7c3aed 50%,#6d28d9);display:flex;flex-direction:column;inset:0;overflow:hidden;position:fixed;user-select:none;-webkit-user-select:none;z-index:9999}.ob-top-bar{display:flex;flex-shrink:0;justify-content:flex-end;padding:16px 20px 0;padding:calc(var(--safe-area-top, 0px) + 16px) 20px 0}.ob-skip{background:none;border:none;color:#fff9;cursor:pointer;font-size:14px;font-weight:500;padding:8px 4px}.ob-skip:active{color:#ffffffe6}.ob-slides-viewport{flex:1 1;overflow:hidden;position:relative}.ob-slides-track{display:flex;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform}.ob-slide{align-items:center;display:flex;flex:0 0 100%;flex-direction:column;gap:16px;justify-content:center;padding:0 32px;text-align:center;width:100%}.ob-emoji{animation:obFadeInUp .6s ease both;font-size:64px;line-height:1;margin-bottom:8px}.ob-title{color:#fff;font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1.3}.ob-desc{color:#ffffffd9;font-size:16px;max-width:320px}.ob-desc,.ob-desc-sub{line-height:1.6;white-space:pre-line}.ob-desc-sub{color:#ffffffb3;font-size:14px;max-width:300px}.ob-cat-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}.ob-cat-item{flex-direction:column;gap:4px;width:64px}.ob-cat-icon,.ob-cat-item{align-items:center;display:flex}.ob-cat-icon{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border-radius:14px;font-size:24px;height:48px;justify-content:center;width:48px}.ob-cat-label{color:#fffc;font-size:11px;font-weight:500}.ob-fab-demo{align-items:center;animation:obPulse 2s ease-in-out infinite;background:#fff;border-radius:50%;box-shadow:0 4px 20px #0003;display:flex;height:56px;justify-content:center;margin-top:12px;width:56px}.ob-fab-demo svg{color:#4f46e5;height:28px;width:28px}@keyframes obPulse{0%,to{box-shadow:0 4px 20px #0003;transform:scale(1)}50%{box-shadow:0 6px 28px #4f46e566;transform:scale(1.12)}}.ob-bottom{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:20px;padding:24px 32px 32px;padding:24px 32px calc(var(--safe-area-bottom, 0px) + 32px)}.ob-dots{display:flex;gap:8px}.ob-dot{background:#ffffff4d;border-radius:50%;height:8px;transition:background .3s,transform .3s;width:8px}.ob-dot--active{background:#fff;transform:scale(1.25)}.ob-btn{border:none;border-radius:14px;cursor:pointer;font-size:17px;font-weight:700;max-width:320px;padding:16px;transition:transform .12s,opacity .12s;width:100%}.ob-btn:active{transform:scale(.97)}.ob-btn--next{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;color:#fff}.ob-btn--start{background:#fff;box-shadow:0 4px 16px #00000026;color:#4f46e5}@keyframes obFadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.main-page{display:flex;flex-direction:column;height:100dvh}.main-content{flex:1 1;overflow-y:auto;padding-bottom:calc(56px + var(--safe-area-bottom))}.sp-kakao-banner{align-items:center;background:#fee500;border-radius:12px;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px;padding:14px 16px;width:100%}.sp-kakao-banner p{color:#191919;font-size:13px;font-weight:500;line-height:1.4}.sp-kakao-btn{background:#191919;border:none;border-radius:8px;color:#fee500;flex-shrink:0;font-size:13px;font-weight:600;padding:8px 14px;white-space:nowrap}.sp{background:linear-gradient(160deg,#f5f3ff,#eff6ff 40%,#fdf2f8);flex-direction:column;min-height:100dvh;padding:20px 16px;padding-bottom:calc(40px + var(--safe-area-bottom))}.sp,.sp-loading{align-items:center;display:flex}.sp-loading{color:var(--color-text-muted);flex:1 1;flex-direction:column;font-size:14px;gap:12px;justify-content:center}.sp-loading-spinner{animation:sp-spin .8s linear infinite;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:32px;width:32px}@keyframes sp-spin{to{transform:rotate(1turn)}}.sp-error-card{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px;justify-content:center;text-align:center}.sp-error-icon{font-size:56px;margin-bottom:8px}.sp-error-card h2{color:var(--color-text);font-size:18px}.sp-error-card p{color:var(--color-text-muted);font-size:14px;margin-bottom:16px}.sp-brand{align-items:center;display:flex;gap:6px;margin-bottom:20px}.sp-brand-logo{font-size:22px}.sp-brand-name{color:var(--color-primary);font-size:17px;font-weight:700;letter-spacing:-.3px}.sp-card{background:#fff;border-radius:20px;box-shadow:0 2px 20px #4f46e514,0 0 0 1px #4f46e50a;flex-direction:column;gap:16px;padding:28px 24px;width:100%}.sp-card,.sp-card-emoji{align-items:center;display:flex}.sp-card-emoji{background:linear-gradient(135deg,#ede9fe,#e0e7ff);border-radius:50%;font-size:52px;height:80px;justify-content:center;line-height:1;width:80px}.sp-card-title{color:var(--color-text);font-size:22px;font-weight:700;line-height:1.35;text-align:center;word-break:keep-all}.sp-card-badge{background:#ede9fe;border-radius:20px;color:var(--color-primary);display:inline-block;font-size:13px;font-weight:600;padding:4px 14px}.sp-card-info{background:var(--color-bg);border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:14px 16px;width:100%}.sp-info-row{align-items:center;color:var(--color-text);display:flex;font-size:14px;gap:8px}.sp-info-icon{flex-shrink:0;font-size:15px;text-align:center;width:20px}.sp-photos{width:100%}.sp-photo--single{border-radius:12px;cursor:pointer;max-height:280px;object-fit:cover;width:100%}.sp-photo-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.sp-photo-grid .sp-photo{aspect-ratio:1;border-radius:12px;cursor:pointer;object-fit:cover;width:100%}.sp-memo{background:var(--color-bg);border-radius:12px;padding:14px 16px;width:100%}.sp-memo-label{color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.sp-memo p{color:var(--color-text);font-size:15px;line-height:1.7;white-space:pre-wrap;word-break:break-word}.sp-actions{align-items:center;display:flex;flex-direction:column;gap:10px;margin-top:20px;width:100%}.sp-actions-sub{color:var(--color-text-muted);font-size:13px;text-align:center}.sp-imported{background:#dcfce7;color:#15803d;display:flex;gap:8px;padding:14px;width:100%}.sp-btn,.sp-imported{align-items:center;border-radius:12px;font-size:15px;font-weight:600;justify-content:center}.sp-btn{border:none;cursor:pointer;display:inline-flex;gap:6px;padding:14px 28px;text-decoration:none;transition:opacity .15s,transform .1s}.sp-btn:active{opacity:.85;transform:scale(.98)}.sp-btn:disabled{opacity:.5}.sp-btn--primary{background:var(--color-primary);color:#fff!important}.sp-btn--outline{background:#fff;border:1.5px solid var(--color-primary);color:var(--color-primary)!important}.sp-btn--full{width:100%}.sp-footer{align-items:center;display:flex;flex-direction:column;gap:14px;margin-top:28px;width:100%}.sp-footer-divider{background:var(--color-border);border-radius:2px;height:3px;width:40px}.sp-footer-text{color:var(--color-text-muted);font-size:13px}.sp-viewer{align-items:center;background:#000000eb;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:300}.sp-viewer img{border-radius:8px;max-height:90dvh;max-width:100%;object-fit:contain}.sp-viewer-close{align-items:center;background:#ffffff26;border:none;border-radius:50%;color:#fff;display:flex;font-size:18px;height:36px;justify-content:center;position:absolute;right:16px;top:16px;width:36px}.sp-sheet-backdrop{align-items:flex-end;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.sp-sheet{background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;max-height:75dvh;max-width:430px;padding:24px 20px;padding-bottom:calc(24px + var(--safe-area-bottom));width:100%}.sp-sheet-header{margin-bottom:16px;text-align:center}.sp-sheet-header h3{color:var(--color-text);font-size:17px;font-weight:700}.sp-sheet-sub{color:var(--color-text-muted);font-size:13px;margin-top:4px}.sp-cat-list{display:flex;flex:1 1;flex-direction:column;gap:6px;margin-bottom:16px;overflow-y:auto}.sp-cat-item{align-items:center;background:#fff;border:1.5px solid var(--color-border);border-radius:12px;display:flex;font-size:15px;gap:10px;padding:12px 14px;text-align:left;transition:all .15s;width:100%}.sp-cat-item--active{background:#f5f3ff;border-color:var(--color-primary)}.sp-cat-emoji{flex-shrink:0;font-size:20px;text-align:center;width:28px}.sp-cat-name{color:var(--color-text);flex:1 1;font-weight:500}.sp-cat-tag{background:#ede9fe;border-radius:10px;color:var(--color-primary);flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.sp-sheet-actions{display:flex;flex-direction:column;gap:8px}.sp-sheet-cancel{background:none;border:none;color:var(--color-text-muted);font-size:15px;font-weight:500;padding:12px;text-align:center;width:100%}.legal-page{background-color:var(--color-bg);min-height:100vh}.legal-header{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);height:56px;padding:0 var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.legal-back-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--color-text);cursor:pointer;display:inline-flex;height:36px;justify-content:center;width:36px}.legal-back-btn:active{background-color:var(--color-bg)}.legal-back-btn svg{height:22px;width:22px}.legal-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:700}.legal-body{margin:0 auto;max-width:720px;padding:var(--spacing-lg) var(--spacing-md)}.legal-body h2{color:var(--color-text);font-size:var(--font-size-lg);font-weight:700;margin:var(--spacing-xl) 0 var(--spacing-sm)}.legal-body h2:first-child{margin-top:0}.legal-body h3{color:var(--color-text);font-size:var(--font-size-md);font-weight:600;margin:var(--spacing-lg) 0 var(--spacing-xs)}.legal-body p{color:var(--color-text-muted);font-size:14px;line-height:1.7;margin:var(--spacing-xs) 0}.legal-body ul{margin:var(--spacing-xs) 0;padding-left:20px}.legal-body li{font-size:14px;line-height:1.7;margin:4px 0}.legal-body li,.legal-date{color:var(--color-text-muted)}.legal-date{font-size:13px;margin-bottom:var(--spacing-lg)}
/*# sourceMappingURL=main.df8efa06.css.map*/