.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;min-height:60px;height:calc(60px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background-color:var(--color-bg-card);border-top:1px solid var(--color-border);z-index:900}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:100%;text-decoration:none;color:var(--color-text-muted);transition:color var(--transition);-webkit-tap-highlight-color:transparent}.tab-item:active{background-color:var(--color-bg-hover)}.tab-active{color:var(--color-primary)}.tab-icon{font-size:1.25rem;line-height:1}.tab-label{font-size:var(--font-size-xs);margin-top:2px}@media(max-width:767px){body.modal-open .tab-bar{z-index:1}}.custom-sort-dropdown{position:relative;display:flex;align-items:center;gap:8px}.sort-dropdown-label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:600}.sort-dropdown-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;min-width:110px;transition:all .2s}.sort-dropdown-trigger:hover{background:var(--color-bg-hover)}.sort-dropdown-trigger.active{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 15%,transparent)}.arrow-icon{transition:transform .2s}.sort-dropdown-trigger.active .arrow-icon{transform:rotate(180deg)}.sort-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:1100;min-width:120px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:4px;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sort-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border:none;background:none;color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:500;text-align:left;border-radius:var(--radius-xs);cursor:pointer;gap:8px}.sort-menu-item:hover{background:var(--color-bg-hover);color:var(--color-text)}.sort-menu-item.selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:700}.map-page{position:relative;width:100%;height:calc(100dvh - 60px)}.map-container{width:100%;height:100%}.map-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-bg);color:var(--color-text-secondary);font-size:.9rem;pointer-events:none}.map-loading button{pointer-events:auto}.search-bar{position:absolute;top:12px;right:12px;left:12px;display:flex;gap:8px;z-index:200;transition:left .3s ease}@media(min-width:1024px){.search-bar.desktop-sidebar-open,.search-results.desktop-sidebar-open{left:312px}.map-location-btn.desktop-sidebar-open{left:320px}}.search-input{flex:1;padding:10px 14px;border:none;border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-sm);box-shadow:var(--shadow-md);outline:none}.search-input::placeholder{color:var(--color-text-muted)}.search-btn{padding:10px 16px;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;box-shadow:var(--shadow-md)}.search-btn:disabled{opacity:.6}.search-results{position:absolute;top:56px;left:12px;right:12px;z-index:200;background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:300px;overflow-y:auto}.search-result-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:12px 14px;border:none;border-bottom:1px solid var(--color-border);background:none;color:var(--color-text);cursor:pointer;text-align:left}.search-result-item:last-of-type{border-bottom:none}.search-result-item:active{background:var(--color-bg-hover)}.result-name{font-weight:600;font-size:var(--font-size-sm)}.result-category{font-size:var(--font-size-xs);color:var(--color-primary)}.result-address{font-size:var(--font-size-xs);color:var(--color-text-muted)}.search-result-close{width:100%;padding:10px;border:none;background:var(--color-bg-hover);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;border-radius:0 0 var(--radius-md) var(--radius-md)}.sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sheet-header h3{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);margin:0}.sheet-close{width:28px;height:28px;border:none;border-radius:50%;background:var(--color-bg-hover);color:var(--color-text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.sheet-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:4px 0}.sheet-memo{font-size:var(--font-size-sm);color:var(--color-text);margin:8px 0;padding:8px;background:var(--color-bg-input);border-radius:var(--radius-sm)}.pin-name-editable{cursor:pointer}.pin-name-editable:active{opacity:.7}.pin-edit-name-input{flex:1;font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);border:none;border-bottom:2px solid var(--color-primary);background:none;outline:none;padding:0 0 2px;font-family:inherit}.pin-memo-editable{cursor:pointer}.pin-memo-editable:active{opacity:.7}.pin-memo-empty{color:var(--color-text-muted);font-style:italic}.pin-edit-memo-row{display:flex;flex-direction:column;gap:6px;margin:8px 0}.pin-edit-memo-input{padding:8px 10px;border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit;resize:vertical;min-height:48px;outline:none}.pin-edit-actions{display:flex;gap:6px}.pin-edit-actions .date-edit-save{padding:4px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-xs);font-weight:600;cursor:pointer}.pin-edit-actions .date-edit-cancel{padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer}.sheet-form{display:flex;flex-direction:column;gap:8px;margin-top:12px}.sheet-input{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.sheet-input:focus{border-color:var(--color-border-focus)}.sheet-input::placeholder{color:var(--color-text-muted)}.sheet-select{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.sheet-actions{display:flex;gap:8px;margin-top:12px}.sheet-action{padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.sheet-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:16px}.sheet-action.full-width{grid-column:span 2}.sheet-action:active{background:var(--color-bg-hover)}.sheet-action.primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.sheet-action.primary:disabled{opacity:.5}.sheet-action.danger{color:var(--color-error);border-color:var(--color-error)}.hamburger-btn{width:42px;height:42px;border:none;border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);font-size:18px;cursor:pointer;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.hamburger-btn:active{background:var(--color-bg-hover)}.map-sidebar-overlay{position:fixed;inset:0;z-index:500;background:#0000004d}.map-sidebar{bottom:calc(60px + env(safe-area-inset-bottom));height:auto;max-height:calc(100vh - 60px - env(safe-area-inset-bottom) - env(safe-area-inset-top));width:300px;max-width:80vw;background:var(--color-bg-card);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideInLeft .2s ease-out;z-index:1000}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--color-border)}.sidebar-header h3{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);margin:0}.sidebar-sort{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--color-border)}.sidebar-sort-select{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-xs);outline:none}.sidebar-count{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.sidebar-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar-pin-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;border-bottom:1px solid var(--color-border);background:none;cursor:pointer;text-align:left;color:var(--color-text)}.sidebar-pin-item:active{background:var(--color-bg-hover)}.sidebar-pin-info{display:flex;flex-direction:column;min-width:0}.sidebar-pin-name{font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-pin-cat{font-size:var(--font-size-xs);color:var(--color-text-muted)}.pick-banner{position:absolute;top:0;left:0;right:0;z-index:250;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-sm);font-weight:600}.pick-banner-cancel{border:1px solid var(--color-primary-text);border-radius:var(--radius-sm);background:none;color:var(--color-primary-text);font-size:var(--font-size-xs);font-weight:600;padding:4px 10px;cursor:pointer;flex-shrink:0}.search-bar.with-banner{top:52px}.sheet-visits{margin-top:8px;border-top:1px solid var(--color-border);padding-top:8px}.sheet-visits-label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:600;margin:0 0 6px}.sheet-visit-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);cursor:pointer;margin-bottom:4px}.sheet-visit-item:active{background:var(--color-bg-hover)}.sheet-visit-title{font-size:var(--font-size-sm);font-weight:600}.sheet-visit-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.desktop-sidebar{position:absolute;top:0;left:0;bottom:0;height:100%;width:300px;z-index:150;background:var(--color-bg-card);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transition:width .3s ease,transform .3s ease}.sidebar-toggle-btn{position:absolute;top:50%;right:-28px;transform:translateY(-50%);width:28px;height:56px;border:1px solid var(--color-border);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;background:var(--color-bg-card);color:var(--color-text-secondary);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1}.sidebar-toggle-btn:active{background:var(--color-bg-hover)}.desktop-sidebar.collapsed{width:0;overflow:hidden;box-shadow:none;background:transparent}.desktop-sidebar.collapsed .sidebar-toggle-btn{right:-28px;box-shadow:var(--shadow-md)}.sidebar-cat-filters{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;border-bottom:1px solid var(--color-border)}.sidebar-cat-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--color-border);border-radius:999px;background:none;color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;white-space:nowrap}.sidebar-cat-chip:active{background:var(--color-bg-hover)}.sidebar-cat-chip.active{border-color:var(--chip-color);background:color-mix(in srgb,var(--chip-color) 12%,transparent);color:var(--color-text)}.sidebar-cat-chip.clear{border-color:var(--color-error);color:var(--color-error)}.cat-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cat-chip-count{color:var(--color-text-muted);font-weight:400;font-size:11px}.visit-filter-group{display:flex;gap:4px;padding:8px 16px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.visit-filter-btn{padding:4px 10px;border-radius:12px;border:1px solid var(--color-border);background:none;color:var(--color-text-muted);font-size:12px;cursor:pointer;transition:all .15s}.visit-filter-btn:hover{background:var(--color-bg-hover)}.visit-filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text);font-weight:600}.pin-wishlist-btn{display:block;width:calc(100% - 32px);margin:8px 16px 4px;padding:6px 12px;border-radius:8px;border:1px solid var(--color-border);background:none;color:var(--color-text-muted);font-size:13px;text-align:left;cursor:pointer;transition:all .15s}.pin-wishlist-btn:hover{background:var(--color-bg-hover)}.pin-wishlist-btn.active{border-color:var(--color-error);color:var(--color-error);background:color-mix(in srgb,var(--color-error) 8%,transparent)}.sheet-category-row{display:flex;align-items:center;gap:8px;margin:4px 0}.sheet-category-select{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.sheet-category-select:focus{border-color:var(--color-border-focus)}.sheet-cat-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.sidebar-layers{padding:var(--space-sm);border-top:1px solid var(--color-border);margin-top:var(--space-xs)}.sidebar-layers-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.sidebar-layers-title{font-size:11px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.sidebar-import-btn{font-size:11px;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);font-weight:600}.sidebar-import-btn:hover{background:var(--color-bg-hover)}.sidebar-import-form{padding:var(--space-xs) 0;margin-bottom:var(--space-xs)}.sidebar-import-hint{font-size:11px;color:var(--color-text-muted);margin-bottom:6px}.sidebar-import-input-row{display:flex;gap:4px}.sidebar-import-url{flex:1;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-xs);outline:none;min-width:0}.sidebar-import-url:focus{border-color:var(--color-primary)}.sidebar-import-fetch-btn{padding:6px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:var(--font-size-xs);cursor:pointer;white-space:nowrap;flex-shrink:0}.sidebar-import-fetch-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-import-preview{margin-top:var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.sidebar-import-preview-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--color-bg-hover);font-size:11px;font-weight:600;color:var(--color-text)}.sidebar-import-toggle-all{display:flex;align-items:center;gap:4px;font-size:11px;cursor:pointer;color:var(--color-text-secondary)}.sidebar-import-list{max-height:200px;overflow-y:auto}.sidebar-import-item{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:11px;cursor:pointer;border-bottom:1px solid var(--color-border)}.sidebar-import-item:last-child{border-bottom:none}.sidebar-import-item:hover{background:var(--color-bg-hover)}.sidebar-import-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.sidebar-import-item-cat{font-size:10px;color:var(--color-text-muted);flex-shrink:0}.sidebar-import-actions{display:flex;gap:4px;padding:6px 8px;background:var(--color-bg-hover)}.sidebar-import-label{flex:1;padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:11px;min-width:0}.sidebar-import-execute-btn{padding:5px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.sidebar-import-execute-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-import-empty{font-size:11px;color:var(--color-text-muted);text-align:center;padding:8px 0}.layer-delete-btn{font-size:10px;color:var(--color-text-muted);background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);flex-shrink:0;opacity:0;transition:opacity .15s}.layer-toggle-item:hover .layer-delete-btn{opacity:1}.layer-delete-btn:hover{color:var(--color-danger, #e74c3c);background:#e74c3c1a}.layer-toggle-item{display:flex;align-items:center;gap:6px;padding:6px 4px;font-size:var(--font-size-xs);color:var(--color-text);cursor:pointer;border-radius:var(--radius-sm)}.layer-toggle-item:hover{background:var(--color-bg-hover)}.layer-toggle-item input[type=checkbox]{flex-shrink:0}.layer-toggle-dot{width:10px;height:10px;border-radius:50%;background:#ff9800;flex-shrink:0}.layer-toggle-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-toggle-count{font-size:10px;color:var(--color-text-muted);flex-shrink:0}.layer-pin-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;background:#ff980026;color:#ff9800;margin-left:6px;flex-shrink:0}.layer-promote-row{display:flex;gap:8px;align-items:center;width:100%}.layer-promote-row .sheet-select{flex:1}.map-location-btn{position:absolute;bottom:80px;left:20px;transition:left .3s ease;width:44px;height:44px;border:none;border-radius:50%;background:var(--color-bg-card);box-shadow:var(--shadow-md);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:200;-webkit-tap-highlight-color:transparent}.map-location-btn:active{background:var(--color-bg-hover)}.sheet-form-actions{display:flex;align-items:center;gap:8px;margin-top:4px}.sheet-loc-btn{flex-shrink:0;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;white-space:nowrap}.sheet-loc-btn:active{background:var(--color-bg-hover)}.sheet-save-container{flex:1}.sheet-save-container .sheet-action{width:100%;margin-top:0}.course-panel{border-bottom:1px solid var(--color-border);background:var(--color-bg-card)}.course-panel-header{display:flex;align-items:center;gap:6px;padding:10px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.course-panel-header:hover{background:var(--color-bg-hover)}.course-nav-btn{background:none;border:none;font-size:18px;color:var(--color-text-secondary);cursor:pointer;padding:0 4px;line-height:1}.course-nav-btn:disabled{opacity:.25;cursor:default}.course-nav-btn:not(:disabled):hover{color:var(--color-text)}.course-panel-title{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.course-date-name{font-size:13px;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-date-sub{font-size:11px;color:var(--color-text-muted);display:flex;align-items:center;gap:4px}.course-today-badge{background:var(--color-primary);color:var(--color-primary-text);border-radius:8px;padding:0 6px;font-size:10px;font-weight:700}.course-toggle-icon{font-size:10px;color:var(--color-text-muted);flex-shrink:0}.course-place-list{padding:0 0 8px}.course-empty{font-size:12px;color:var(--color-text-muted);padding:8px 16px;margin:0}.course-place-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 14px;background:none;border:none;cursor:pointer;text-align:left}.course-place-item:hover{background:var(--color-bg-hover)}.course-place-num{width:22px;height:22px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.course-place-info{display:flex;flex-direction:column;gap:1px;min-width:0}.course-place-name{font-size:13px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-place-addr{font-size:11px;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-page{height:calc(100dvh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch}.month-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);position:sticky;top:0;background:var(--color-bg);z-index:10}.month-nav-btn{width:36px;height:36px;border:none;border-radius:50%;background:var(--color-bg-hover);color:var(--color-text);font-size:var(--font-size-lg);display:flex;align-items:center;justify-content:center;cursor:pointer}.month-nav-btn:active{background:var(--color-border)}.today-nav-btn{padding:4px 10px;border:none;border-radius:12px;background:var(--color-primary);color:#fff;font-size:12px;font-weight:600;cursor:pointer;margin-left:4px}.month-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.month-title-btn{border:none;background:none;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm)}.month-title-btn:active{background:var(--color-bg-hover)}.month-picker-overlay{position:fixed;inset:0;z-index:400;background:#0006;display:flex;align-items:center;justify-content:center}.month-picker{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px;width:280px}.month-picker-year{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.month-picker-year-label{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.month-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.month-picker-item{padding:10px 0;border:none;border-radius:var(--radius-sm);background:none;color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;text-align:center}.month-picker-item:active{background:var(--color-bg-hover)}.month-picker-item.active{background:var(--color-primary);color:var(--color-primary-text)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);padding:0 var(--space-sm);margin-bottom:var(--space-xs)}.cal-weekday{text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);padding:6px 0;border-radius:var(--radius-sm)}.cal-weekday:first-child{color:var(--color-error);background:var(--color-error-light, rgba(220, 53, 69, .08))}.cal-weekday:last-child{color:var(--color-primary);background:var(--color-primary-light)}.cal-days{display:grid;grid-template-columns:repeat(7,1fr);padding:0 var(--space-sm);gap:2px}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;padding:2px;position:relative}.cal-day:active{background:var(--color-bg-hover)}.cal-day-num{font-size:var(--font-size-sm);color:var(--color-text);line-height:1}.cal-day.other-month .cal-day-num{color:var(--color-text-muted);opacity:.4}.cal-day.today .cal-day-num{background:var(--color-primary);color:var(--color-primary-text);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center}.cal-day.sunday .cal-day-num{color:var(--color-error)}.cal-day.saturday .cal-day-num{color:var(--color-primary)}.cal-day.today.sunday .cal-day-num,.cal-day.today.saturday .cal-day-num{color:var(--color-primary-text)}.cal-day-dots{display:flex;gap:3px;height:5px;margin-top:2px}.cal-day-dot{width:5px;height:5px;border-radius:50%;background:var(--color-primary)}.cal-day-dot.memo-dot{background:var(--color-warning)}.cal-day.selected{background:var(--color-primary-light)}.date-list{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:52px}.date-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-decoration:none;color:inherit;transition:background var(--transition)}.date-card:active{background:var(--color-bg-hover)}.date-card-cover{width:52px;height:52px;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.date-card-body{flex:1;min-width:0}.date-card-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-card-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:2px}.date-card-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.date-card-score{font-size:var(--font-size-xs);color:var(--color-warning)}.date-card-places{display:flex;align-items:center;gap:2px;margin-top:2px}.date-card-place-icon{font-size:14px;line-height:1}.date-card-place-more{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:2px}.date-card-counts{display:flex;gap:6px;margin-left:auto;font-size:11px;color:var(--color-text-muted)}.date-card-delete{width:28px;height:28px;border:none;border-radius:50%;background:var(--color-bg-hover);color:var(--color-text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.date-card-delete:active{background:var(--color-error);color:var(--color-primary-text)}.date-list-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);padding:var(--space-sm) 0 var(--space-xs)}.memo-section{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border)}.memo-date-header{font-size:var(--font-size-md);font-weight:700;color:var(--color-text);margin-bottom:var(--space-sm)}.memo-item{margin-bottom:var(--space-xs)}.memo-content{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);padding:8px 10px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.memo-body{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.5;flex:1;word-break:break-word}.memo-actions{display:flex;gap:4px;flex-shrink:0}.memo-action-btn{padding:2px 6px;border:none;background:none;font-size:var(--font-size-xs);color:var(--color-text-muted);cursor:pointer}.memo-action-btn:active{color:var(--color-primary)}.memo-action-btn.danger:active{color:var(--color-error)}.memo-add-form{display:flex;gap:6px;margin-top:var(--space-xs)}.memo-input{flex:1;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.memo-input:focus{border-color:var(--color-border-focus)}.memo-input::placeholder{color:var(--color-text-muted)}.memo-add-btn{width:34px;height:34px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-primary-text);font-size:18px;font-weight:600;cursor:pointer;flex-shrink:0}.memo-add-btn:disabled{opacity:.4}.memo-edit-form{display:flex;gap:6px;align-items:center}.memo-save-btn,.memo-cancel-btn{padding:6px 10px;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;flex-shrink:0}.memo-save-btn{background:var(--color-primary);color:var(--color-primary-text)}.memo-cancel-btn{background:var(--color-bg-hover);color:var(--color-text-secondary)}.date-list-header{display:flex;align-items:center;padding:var(--space-sm) 0 var(--space-xs);gap:var(--space-sm)}.badge-clickable{cursor:pointer;transition:opacity var(--transition),transform var(--transition);border:none;padding:inherit;font-size:inherit;font-family:inherit;line-height:inherit}.badge-clickable:hover{opacity:.85;transform:scale(1.04)}.badge-clickable:active{opacity:.6}@media(min-width:768px){.calendar-page{overflow:hidden;height:calc(100vh - 60px)}.cal-desktop-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;height:100%;align-items:stretch}.cal-left-panel{display:flex;flex-direction:column;justify-content:center;height:100%;overflow-y:auto;border-right:1px solid var(--color-border);position:relative;padding:var(--space-md) 0}.cal-right-panel{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding-bottom:80px}}@media(max-width:767px){.calendar-page{overflow-y:auto;height:calc(100vh - 60px)}.cal-desktop-layout,.cal-left-panel,.cal-right-panel{display:block}}.date-card-cover{overflow:hidden}.date-card-thumb{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm)}.date-card-date-btn{border:none;background:none;padding:0;font-size:var(--font-size-xs);color:var(--color-text-muted);cursor:pointer;font-family:inherit;text-align:left}.date-card-date-btn:active{color:var(--color-primary)}.date-card-edit-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:2px}.date-card-date-input{padding:3px 6px;border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:11px;font-family:inherit;outline:none}.cal-trip-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.confirm-overlay{position:fixed;inset:0;z-index:3000;background:#0006;display:flex;align-items:center;justify-content:center}.confirm-dialog{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-lg);width:min(320px,calc(100vw - 48px))}.confirm-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text);margin-bottom:var(--space-sm)}.confirm-body{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg);line-height:1.5}.confirm-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.confirm-cancel{padding:8px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;font-family:inherit}.confirm-danger{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:var(--color-error);color:var(--color-primary-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;font-family:inherit}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);padding:10px 24px;background:var(--color-text);color:var(--color-bg);font-size:var(--font-size-sm);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:9999;animation:toast-in .2s ease;pointer-events:none}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.fab{position:fixed;bottom:80px;right:20px;width:52px;height:52px;border:none;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);font-size:24px;font-weight:300;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);cursor:pointer;z-index:1100;-webkit-tap-highlight-color:transparent}.fab:active{background:var(--color-primary-hover)}.badge{display:inline-block;padding:2px 8px;font-size:var(--font-size-xs);font-weight:600;border-radius:999px;background:var(--color-primary-light);color:var(--color-primary)}.badge.success{background:#10b98126;color:var(--color-success)}.badge.warning{background:#f59e0b26;color:var(--color-warning)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.section-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);transition:background var(--transition)}.card:active{background:var(--color-bg-hover)}.page-scroll{flex:1;overflow-y:auto;padding:var(--space-md);padding-top:calc(var(--space-md) + env(safe-area-inset-top));-webkit-overflow-scrolling:touch}.back-btn{display:flex;align-items:center;gap:4px;padding:6px 0;border:none;background:none;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.satisfaction{display:flex;align-items:center;gap:2px;color:var(--color-warning);font-size:var(--font-size-sm)}.bottom-sheet-overlay{position:fixed;inset:0;bottom:calc(60px + env(safe-area-inset-bottom));z-index:1999;background:#00000073}.bottom-sheet{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom));left:0;right:0;z-index:2000;background:var(--color-bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 20px #00000026;padding:20px;max-height:calc(85vh - 60px - env(safe-area-inset-bottom));overflow-y:auto;animation:slide-up .3s ease-out}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.scrollable-modal-content{overflow-y:auto;flex:1;padding:10px 0;max-height:60vh}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-md);color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;gap:var(--space-sm)}.empty-state-icon{font-size:2rem;opacity:.5}.skeleton{background:linear-gradient(90deg,var(--color-bg-hover) 25%,var(--color-bg-input) 50%,var(--color-bg-hover) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:14px;margin-bottom:8px}.skeleton-line.short{width:40%}.skeleton-line.medium{width:70%}.skeleton-card{height:72px;margin-bottom:8px}.skeleton-thumb{aspect-ratio:1}.main-content{display:flex;flex-direction:column;height:100dvh;animation:page-fade-in .15s ease-out}@keyframes page-fade-in{0%{opacity:0}to{opacity:1}}.ptr-indicator{display:flex;align-items:center;justify-content:center;padding:8px;font-size:var(--font-size-xs);color:var(--color-text-muted);transition:opacity .2s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.tag-section{position:relative}.tag-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:var(--color-primary-light);color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;border-radius:999px}.tag-remove{border:none;background:none;color:var(--color-primary);font-size:11px;cursor:pointer;padding:0;line-height:1;opacity:.6}.tag-remove:active{opacity:1}.tag-input-row{display:flex;gap:6px}.tag-input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-xs);outline:none}.tag-input:focus{border-color:var(--color-border-focus)}.tag-input::placeholder{color:var(--color-text-muted)}.tag-add-btn{padding:6px 12px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:none;color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;flex-shrink:0}.tag-add-btn:active{background:var(--color-primary-light)}.tag-suggestions{position:absolute;left:0;right:0;z-index:2500;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:180px;overflow-y:auto;margin-top:2px}.tag-suggestion{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:none;color:var(--color-text);font-size:var(--font-size-xs);text-align:left;cursor:pointer}.tag-suggest-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tag-suggestion:hover,.tag-suggestion:active{background:var(--color-bg-hover)}.tag-suggestion+.tag-suggestion{border-top:1px solid var(--color-border)}@font-face{font-family:AppFont-Gothic;src:url(/fonts/Dovemayo_gothic.ttf) format("truetype");font-weight:400;font-style:normal;font-display:block}@font-face{font-family:AppFont-Normal;src:url(/fonts/dovemayo.otf) format("opentype");font-weight:400;font-style:normal;font-display:block}.role-selection{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:center}.role-btn{font-size:3rem;flex:1;padding:1rem;border-radius:16px;background:var(--color-bg-input);border:2px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.role-btn.bear.active{border-color:var(--color-primary)}.role-btn.rabbit.active{border-color:var(--color-partner)}.role-btn.inactive{opacity:.5}body{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,button,select,textarea{font-family:inherit!important}@media(min-width:768px){.app-container{display:flex;justify-content:center;background:var(--color-bg);min-height:100vh}.main-content{width:90%;max-width:800px;margin:0 auto;background:var(--color-bg-card);box-shadow:0 0 40px #0000000d;min-height:100vh;position:relative}.tab-bar{width:90%;max-width:800px;left:50%;transform:translate(-50%)}.is-map-view .main-content{width:100%;margin:0;max-width:none;box-shadow:none}.is-map-view .tab-bar{width:100%;max-width:none;left:0;right:0;transform:none}.map-page{flex:1;width:100%;position:relative;height:100%;z-index:10}.bottom-sheet{left:max(0px,calc(50% - 250px));right:max(0px,calc(50% - 250px));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.is-map-view .bottom-sheet{left:0;right:0}.fab{right:max(20px,calc(50% - 230px))}.is-map-view .fab{right:20px}}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--color-bg-input);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 32px 8px 10px;font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;min-height:36px;outline:none}select:focus{border-color:var(--color-border-focus)}select option[value=""]{color:var(--color-text-muted)}.date-detail-page{height:calc(100dvh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch}.date-detail-header{padding:var(--space-md);border-bottom:1px solid var(--color-border)}.date-detail-title{font-size:var(--font-size-xl);font-weight:800;color:var(--color-text);margin:var(--space-sm) 0 var(--space-xs);cursor:pointer}.date-detail-title-input{font-size:var(--font-size-xl);font-weight:800;color:var(--color-text);margin:var(--space-sm) 0 var(--space-xs);width:100%;border:none;border-bottom:2px solid var(--color-primary);background:none;outline:none;padding:0 0 2px}.date-detail-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;position:relative}.date-detail-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.place-timeline{padding:var(--space-md)}.place-item{display:flex;gap:var(--space-md);padding-bottom:var(--space-md);position:relative}.place-item:not(:last-child):before{content:"";position:absolute;left:15px;top:36px;bottom:0;width:2px;background:var(--color-border)}.place-order{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:700;flex-shrink:0;z-index:1}.place-body{flex:1;min-width:0}.place-name{font-size:var(--font-size-md);font-weight:700;color:var(--color-text)}.place-address{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.place-time{display:flex;gap:var(--space-sm);margin-top:4px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.place-time-label{color:var(--color-text-muted)}.total-stay-time{font-size:var(--font-size-xs);font-weight:400;color:var(--color-text-muted);margin-left:8px}.place-score{font-size:var(--font-size-xs);color:var(--color-warning);margin-top:4px}.add-place-btn{padding:4px 12px;border:1px solid var(--color-primary);border-radius:var(--radius-lg);background:none;color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer}.add-place-btn:active{background:var(--color-primary-light)}.place-name-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.place-delete-btn{width:22px;height:22px;border:none;border-radius:50%;background:var(--color-bg-hover);color:var(--color-text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.place-delete-btn:active{background:var(--color-error);color:#fff}.place-actions-row{display:flex;align-items:center;gap:4px;flex-shrink:0}.place-reorder-btns{display:flex;flex-direction:column;gap:1px}.place-reorder-btn{width:20px;height:14px;border:none;border-radius:3px;background:var(--color-bg-hover);color:var(--color-text-muted);font-size:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.place-reorder-btn:disabled{opacity:.3;cursor:default}.place-reorder-btn:not(:disabled):active{background:var(--color-primary-light);color:var(--color-primary)}.add-place-overlay{position:fixed;inset:0;z-index:1999;background:#00000073;display:flex;align-items:flex-end;padding-bottom:calc(60px + env(safe-area-inset-bottom))}.add-place-sheet{width:100%;max-height:70vh;background:var(--color-bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;overflow:hidden}.add-place-sheet .sheet-header{padding:16px 20px 8px;flex-shrink:0}.add-place-search-row{display:flex;gap:6px;padding:8px 16px;flex-shrink:0;border-bottom:1px solid var(--color-border)}.add-place-search-row .sheet-input{flex:1;min-width:0}.add-place-search-btn{flex-shrink:0;padding:8px 14px;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.add-place-search-btn:disabled{opacity:.4;cursor:default}.add-place-map-btn{flex-shrink:0;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-hover);font-size:16px;cursor:pointer}.add-place-tabs{display:flex;border-bottom:1px solid var(--color-border);flex-shrink:0}.add-place-tab{flex:1;padding:10px 4px;border:none;background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.add-place-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.add-place-search-bar{display:flex;gap:6px;padding:8px 16px;flex-shrink:0;border-bottom:1px solid var(--color-border)}.add-place-search-bar .sheet-input{flex:1;min-width:0}.add-place-body{flex:1;overflow-y:auto;padding:8px 16px 4px;-webkit-overflow-scrolling:touch}.add-place-manual-section{flex-shrink:0;border-top:1px solid var(--color-border);padding:0 16px 8px}.add-place-manual-toggle{width:100%;padding:10px 0;border:none;background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;text-align:left}.add-place-manual-section .sheet-form{display:flex;flex-direction:column;gap:8px;padding-bottom:8px}.pin-list{display:flex;flex-direction:column}.pin-list-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 4px;border:none;border-bottom:1px solid var(--color-border);background:none;cursor:pointer;text-align:left;color:var(--color-text)}.pin-list-item:last-child{border-bottom:none}.pin-list-item:active{background:var(--color-bg-hover)}.pin-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pin-list-name{flex:1;font-size:var(--font-size-sm);font-weight:600}.pin-list-cat{font-size:var(--font-size-xs);color:var(--color-text-muted)}.search-result-list{display:flex;flex-direction:column}.search-result-list .search-result-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:12px 4px;border:none;border-bottom:1px solid var(--color-border);background:none;color:var(--color-text);cursor:pointer;text-align:left}.search-result-list .search-result-item:last-child{border-bottom:none}.search-result-list .search-result-item:active{background:var(--color-bg-hover)}.star-rating{display:flex;align-items:center;gap:2px}.star-rating .star{border:none;background:none;padding:0;font-size:18px;cursor:pointer;color:var(--color-border);line-height:1;-webkit-tap-highlight-color:transparent}.star-rating .star.filled{color:var(--color-warning)}.star-label{margin-left:6px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.date-satisfaction{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm)}.satisfaction-label{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.place-score-btn{border:none;background:none;padding:0;margin-top:4px;cursor:pointer;text-align:left}.place-score{font-size:var(--font-size-xs);color:var(--color-warning)}.place-score-empty{font-size:var(--font-size-xs);color:var(--color-text-muted)}.status-badge{cursor:pointer;position:relative}.status-picker{position:absolute;top:100%;z-index:100;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden;margin-top:4px}.status-option{display:block;width:100%;padding:10px 16px;border:none;background:none;color:var(--color-text);font-size:var(--font-size-sm);text-align:left;cursor:pointer}.status-option:active,.status-option.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.status-option+.status-option{border-top:1px solid var(--color-border)}.comment-send-btn:disabled{opacity:.5;cursor:default}.photo-section{padding:0 var(--space-md) var(--space-md)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.photo-thumb{aspect-ratio:1;background:var(--color-bg-input);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;overflow:hidden;position:relative}.photo-thumb:active{opacity:.7}.photo-thumb-img{width:100%;height:100%;object-fit:cover}.photo-thumb-video{font-size:2rem;color:var(--color-text-muted)}.weather-card{display:flex;align-items:center;gap:var(--space-sm);margin:0 var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-primary-light);border-radius:var(--radius-md)}.weather-icon{font-size:1.8rem;line-height:1}.weather-info{display:flex;flex-direction:column;flex:1;min-width:0}.weather-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.weather-temp{font-size:var(--font-size-xs);color:var(--color-text-muted)}.weather-pop{font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);flex-shrink:0}.comments-section{padding:0 var(--space-md) var(--space-md)}.comment-list{display:flex;flex-direction:column;gap:var(--space-sm)}.comment-bubble{max-width:75%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.4}.comment-bubble.me{align-self:flex-end;background:var(--color-msg-me);color:var(--color-text);border-bottom-right-radius:4px}.comment-partner-name{color:var(--color-partner);font-weight:700;margin-bottom:2px}.comment-bubble.partner{align-self:flex-start;background:var(--color-partner);color:#fff;border-bottom-left-radius:4px}.comment-bubble.reply{margin-left:24px;opacity:.85}.comment-meta{display:flex;align-items:center;gap:6px;margin-top:2px}.comment-meta.me{justify-content:flex-end}.comment-time{font-size:10px;color:var(--color-text-muted)}.comment-actions{display:flex;gap:4px}.comment-action-btn{border:none;background:none;color:var(--color-text-muted);font-size:10px;cursor:pointer;padding:0 2px}.comment-action-btn:active{color:var(--color-primary)}.comment-edit-form{display:flex;flex-direction:column;gap:6px}.comment-edit-input{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.comment-edit-actions{display:flex;gap:4px;justify-content:flex-end}.comment-edit-btn{padding:4px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-primary-text);font-size:11px;font-weight:600;cursor:pointer}.comment-edit-btn.cancel{background:var(--color-bg-hover);color:var(--color-text-secondary)}.comment-input-bar{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border);background:var(--color-bg-card)}.comment-input{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.add-place-map-pick{text-align:center;padding:8px 0 12px}.map-pick-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 10px}.map-pick-divider{display:flex;align-items:center;gap:10px;margin:14px 0;font-size:var(--font-size-xs);color:var(--color-text-muted)}.map-pick-divider:before,.map-pick-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.place-photo-btn{width:22px;height:22px;border:none;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.place-photo-btn:active{background:var(--color-primary);color:var(--color-primary-text)}.comment-send-btn{padding:8px 14px;border:none;border-radius:var(--radius-lg);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.media-picker-overlay{position:fixed;inset:0;z-index:1999;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:20px}.media-picker-sheet{width:100%;max-width:500px;max-height:85vh;background:var(--color-bg-card);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl)}.media-picker-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border)}.media-picker-header h3{font-size:1.1rem;font-weight:700}.media-picker-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer}.media-picker-body{flex:1;overflow-y:auto;padding:20px}.media-photo-list{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;margin-bottom:20px}.media-photo-card{flex-shrink:0;width:100px;display:flex;flex-direction:column;gap:8px}.media-photo-img-wrap{width:100px;height:100px;border-radius:var(--radius-md);overflow:hidden;position:relative;cursor:pointer;border:2px solid transparent}.media-photo-card.selected .media-photo-img-wrap{border-color:var(--color-primary)}.media-photo-img-wrap img{width:100%;height:100%;object-fit:cover}.no-gps-badge{position:absolute;bottom:4px;right:4px;background:#0009;color:#fff;font-size:10px;padding:2px 4px;border-radius:4px}.near-place-btn{width:100%;padding:6px;font-size:11px;font-weight:600;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);cursor:pointer}.near-place-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.near-place-btn:disabled{opacity:.4;cursor:not-allowed}.rec-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--color-border);cursor:pointer}.rec-item:active{background:var(--color-bg-hover)}.rec-info{flex:1}.rec-name{font-weight:700;font-size:14px}.rec-addr{font-size:11px;color:var(--color-text-muted)}.date-detail-date-btn{border:none;background:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:0;cursor:pointer;text-align:left}.date-detail-date-btn:active{color:var(--color-primary)}.date-edit-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.date-edit-input{padding:4px 8px;border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit}.date-edit-save{padding:4px 10px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-xs);font-weight:600;cursor:pointer}.date-edit-cancel{padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer}.date-detail-delete-btn{border:none;background:none;color:var(--color-error);font-size:var(--font-size-xs);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;opacity:.7}.date-detail-delete-btn:active{opacity:1;background:#ef44441a}.place-name-btn{border:none;background:none;color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;padding:0;cursor:pointer;text-align:left}.place-name-btn:active{color:var(--color-primary)}.place-edit-form{flex:1;display:flex;flex-direction:column;gap:4px}.place-edit-input{padding:5px 8px;border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit;width:100%}.place-edit-memo{padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit;width:100%;resize:vertical;min-height:48px}.place-edit-memo:focus{border-color:var(--color-border-focus);outline:none}.place-edit-actions{display:flex;gap:6px}.place-category-row{display:flex;align-items:center;gap:6px;margin:2px 0}.place-cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.place-category-select{font-size:11px;color:var(--color-text-secondary);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 6px;outline:none;cursor:pointer}.place-category-select:focus{border-color:var(--color-border-focus)}.new-category-form{display:flex;align-items:center;gap:6px;margin-top:4px}.new-category-form input[type=text]{flex:1;font-size:11px;padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);outline:none}.new-category-form input[type=color]{width:24px;height:24px;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:0;cursor:pointer;background:none}.new-cat-confirm,.new-cat-cancel{font-size:11px;padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text);cursor:pointer}.new-cat-confirm:disabled{opacity:.4;cursor:default}.place-memo{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px;white-space:pre-wrap;line-height:1.4}.full-height-sheet{height:85vh;display:flex;flex-direction:column;overflow:hidden}.picker-place-select{margin:0 16px 8px;padding:8px 10px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:14px;flex-shrink:0;width:calc(100% - 32px)}.picker-controls{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;flex-shrink:0}.sort-toggles{display:flex;gap:4px}.sort-toggle{padding:4px 10px;border-radius:12px;border:1px solid var(--color-border);background:none;color:var(--color-text);font-size:12px;cursor:pointer}.sort-toggle.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.selection-count{font-size:12px;color:var(--color-text-muted)}.picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;overflow-y:auto;flex:1;padding:0 16px 8px}.picker-item{position:relative;aspect-ratio:1;cursor:pointer;border-radius:4px;overflow:hidden}.picker-item.selected{outline:3px solid var(--color-primary);outline-offset:-3px}.picker-img{width:100%;height:100%;object-fit:cover}.picker-check{position:absolute;top:4px;right:4px;background:var(--color-primary);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px}.sheet-actions-footer{padding:12px 16px;border-top:1px solid var(--color-border);flex-shrink:0}.sheet-action.primary{width:100%;padding:12px;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer}.sheet-action.primary:disabled{opacity:.4}.photo-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:8px 0 12px}.photo-action-btn-large{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-hover);color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background var(--transition)}.photo-action-btn-large:active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.photo-action-btn-large .icon{font-size:28px;line-height:1}.photo-action-btn-large .label{font-size:13px}.sheet-cancel-btn{display:block;width:100%;padding:12px;margin-top:8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;text-align:center}.sheet-cancel-btn:active{background:var(--color-bg-hover);color:var(--color-text)}.status-option{width:100%;padding:14px 16px;border:none;border-radius:var(--radius-md);background:none;color:var(--color-text);font-size:15px;font-weight:400;text-align:left;cursor:pointer;margin-bottom:2px;transition:background var(--transition)}.status-option:active{background:var(--color-bg-hover)}.status-option.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:700}.gallery-page{height:calc(100dvh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch}.gallery-tabs{display:flex;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-bg);z-index:10}.gallery-tab{flex:1;padding:var(--space-sm) 0;border:none;background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;position:relative}.gallery-tab.active{color:var(--color-primary)}.gallery-tab.active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--color-primary);border-radius:1px}.gallery-tab:active{background:var(--color-bg-hover)}.gallery-controls{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-bg);border-bottom:1px solid var(--color-border);gap:var(--space-md)}.gallery-control-item{display:flex;align-items:center;gap:var(--space-sm);flex:1}.control-label{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.grid-size-slider{flex:1;height:4px;-webkit-appearance:none;background:var(--color-bg-input);border-radius:2px;outline:none}.grid-size-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0003}.gallery-sort-select:focus{border-color:var(--color-border-focus)}.gallery-filters{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border-bottom:1px solid var(--color-border);overflow-x:auto}.filter-btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.filter-btn.active{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.filter-btn:active{background:var(--color-bg-hover)}.gallery-grid{display:grid;grid-template-columns:repeat(var(--grid-cols, 3),1fr);gap:2px;padding:2px}.gallery-item{aspect-ratio:1;background:var(--color-bg-input);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.8rem;cursor:pointer;position:relative;overflow:hidden}.gallery-item:active{opacity:.7}.gallery-item-caption{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background:#00000080;color:#fff;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-img{width:100%;height:100%;object-fit:cover;background:var(--color-bg)}.gallery-video-thumb{position:relative;width:100%;height:100%}.gallery-video-thumb video{width:100%;height:100%;object-fit:contain;background:#000;display:block}.gallery-video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;color:#ffffffe6;pointer-events:none;text-shadow:0 0 8px rgba(0,0,0,.5)}.gallery-group-header{grid-column:1 / -1;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);background:var(--color-bg);display:flex;align-items:center;justify-content:space-between}.gallery-group-header.clickable{cursor:pointer}.gallery-group-header.clickable:active{background:var(--color-bg-hover)}.gallery-group-arrow{color:var(--color-primary);font-size:var(--font-size-xs)}.gallery-month-divider{border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-md)}.gallery-group-sub-btn{flex-shrink:0;padding:2px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-muted);font-size:11px;cursor:pointer;white-space:nowrap;margin-left:auto}.gallery-group-sub-btn:active{background:var(--color-bg-hover)}.lightbox-overlay{position:fixed;inset:0;z-index:1500;background:#000000e6;display:flex;align-items:center;justify-content:center;overflow:hidden;overscroll-behavior:none}.lightbox-nav-btn{position:fixed;top:50%;transform:translateY(-50%);z-index:1501;width:44px;height:64px;display:flex;align-items:center;justify-content:center;background:#0006;border:none;color:#fff;font-size:32px;cursor:pointer;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;transition:background .15s}.lightbox-nav-btn:active{background:#000000b3}.lightbox-nav-prev{left:4px}.lightbox-nav-next{right:4px}.lightbox-content{position:relative;max-width:95vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.lightbox-close{position:absolute;top:-44px;right:0;width:36px;height:36px;border:1.5px solid rgba(255,255,255,.5);border-radius:50%;background:#00000080;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;font-weight:700;line-height:1}.lightbox-img{width:100%;max-height:55vh;object-fit:contain;border-radius:var(--radius-sm)}.lightbox-video{width:100%;max-height:55vh;border-radius:var(--radius-sm)}.lightbox-caption{color:#fff;font-size:var(--font-size-sm);text-align:center;padding:0 var(--space-md)}.lightbox-delete{padding:8px 20px;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);background:none;color:#ff6b6b;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.lightbox-delete:active{background:#ff6b6b33}.lightbox-detail{position:relative;width:100%;max-width:500px;height:95vh;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;padding-bottom:env(safe-area-inset-bottom)}.lightbox-media{display:flex;align-items:center;justify-content:center;flex-shrink:0}.lightbox-detail .lightbox-img,.lightbox-detail .lightbox-video{width:100%;max-height:55vh}.lightbox-info{background:var(--color-bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:4px}.lightbox-row{display:flex;align-items:center;gap:var(--space-sm)}.lightbox-row-label{font-size:11px;color:var(--color-text-muted);flex-shrink:0;width:44px}.uploader-row{margin-bottom:2px}.uploader-name{font-size:13px;font-weight:700}.lightbox-taken-at{font-size:12px;color:var(--color-text-secondary)}.lightbox-caption-btn{border:none;background:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:6px 0;cursor:pointer;text-align:left;width:100%}.lightbox-caption-btn:active{color:var(--color-primary)}.lightbox-caption-input{width:100%;padding:6px 10px;border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);outline:none}.lightbox-place-select{flex:1;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-xs);outline:none;min-width:0}.lightbox-place-select:focus{border-color:var(--color-border-focus)}.lightbox-comments{border-top:1px solid var(--color-border);padding-top:var(--space-sm)}.lightbox-comment-list{display:flex;flex-direction:column;gap:4px;max-height:120px;overflow-y:auto;margin-bottom:var(--space-sm)}.lb-comment{display:flex;flex-direction:column;gap:2px;max-width:90%;font-size:var(--font-size-xs)}.lb-comment.me{align-self:flex-end}.lb-comment.partner{align-self:flex-start}.lb-comment-author{font-size:10px;font-weight:700;padding:0 4px}.lb-comment.me .lb-comment-author{color:var(--color-me);text-align:right}.lb-comment.partner .lb-comment-author{color:var(--color-partner);text-align:left}.lb-comment-content{display:flex;align-items:flex-end;gap:6px;padding:6px 10px;border-radius:var(--radius-md);position:relative}.lb-comment.me .lb-comment-content{background:var(--color-primary-light);color:var(--color-text);flex-direction:row}[data-theme*=green] .lb-comment.me .lb-comment-content{background:var(--color-primary);color:#fff}[data-theme*=green] .lb-comment.me .lb-comment-time{color:#fffc}.lb-comment.partner .lb-comment-content{background:var(--color-partner);color:#fff}.lb-comment-body{flex:1;word-break:break-word;line-height:1.4}.lb-comment-time{font-size:9px;color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.lb-comment.partner .lb-comment-time{color:#ffffffb3}.lb-comment-delete{background:none;border:none;color:var(--color-text-muted);font-size:12px;padding:0 2px;cursor:pointer;opacity:.5}.lb-comment-delete:hover{opacity:1;color:var(--color-error)}.lb-comment-empty{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);padding:var(--space-sm) 0}.lightbox-comment-bar{display:flex;gap:6px}.lb-comment-input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-xs);outline:none}.lb-comment-input:focus{border-color:var(--color-border-focus)}.lb-comment-send{padding:6px 12px;border:none;border-radius:var(--radius-lg);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;flex-shrink:0}.lb-comment-send:disabled{opacity:.5;cursor:default}.lightbox-bottom-actions{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:var(--space-sm);padding-bottom:15px;border-bottom:1px solid var(--color-border);margin-bottom:150px}.lightbox-share,.lightbox-delete,.lightbox-action-close{padding:8px 18px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.lightbox-share{background:var(--color-bg-hover);color:var(--color-text);border:1px solid var(--color-border)}.lightbox-share:active{opacity:.7}.lightbox-action-close{background:var(--color-bg-input);color:var(--color-text-secondary);border:1px solid var(--color-border)}.lightbox-action-close:active{opacity:.7}.lightbox-date-link{border:none;background:none;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;padding:6px 0;text-align:left}.lightbox-date-link:active{opacity:.7}.lightbox-add-place-btn{flex-shrink:0;padding:5px 10px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:none;color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;white-space:nowrap}.lightbox-add-place-btn:active{background:var(--color-primary-light)}.gallery-select-btn{flex:none;padding:0 var(--space-md);color:var(--color-primary)}.gallery-select-count{display:flex;align-items:center;justify-content:center;flex:1;font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary)}.gallery-item.selected{outline:3px solid var(--color-primary);outline-offset:-3px}.gallery-select-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border:2px solid #fff;border-radius:50%;background:#0000004d;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700}.gallery-select-check.checked{background:var(--color-primary);border-color:var(--color-primary)}.batch-action-bar{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom));left:0;right:0;display:flex;gap:8px;padding:10px 16px;background:var(--color-bg-card);border-top:1px solid var(--color-border);z-index:950}[data-tab-collapsed=true] .batch-action-bar{bottom:28px}.batch-btn{flex:1;padding:10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.batch-btn:active{background:var(--color-bg-hover)}.batch-btn.danger{color:var(--color-error);border-color:var(--color-error)}.batch-assign-sheet{width:90%;max-width:400px;max-height:70vh;background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-md);overflow-y:auto}.batch-assign-section{margin-top:var(--space-md)}.batch-assign-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);margin:0 0 6px}.batch-assign-group{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:8px 0 4px;font-weight:600}.batch-assign-item{display:block;width:100%;padding:10px 12px;border:none;border-bottom:1px solid var(--color-border);background:none;color:var(--color-text);font-size:var(--font-size-sm);text-align:left;cursor:pointer}.batch-assign-item:active{background:var(--color-bg-hover)}.batch-item-sub{font-size:11px;color:var(--color-text-muted);margin-left:5px;font-weight:400}.top-nav-bar{display:flex;align-items:center;justify-content:space-between;padding:12px var(--space-md);padding-top:calc(12px + env(safe-area-inset-top));background-color:var(--color-bg);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:50}.nav-left,.nav-right{display:flex;align-items:center;flex:1}.nav-right{justify-content:flex-end}.nav-center{flex:2;text-align:center;display:flex;justify-content:center;overflow:hidden}.nav-title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.nav-back-btn{display:flex;align-items:center;gap:2px;background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:500;padding:4px 0;margin-left:-8px;cursor:pointer;-webkit-tap-highlight-color:transparent}.nav-back-btn svg{margin-right:-2px}.nav-back-btn:active{opacity:.7}.plan-page{height:calc(100dvh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--space-xl)}.plan-header{padding:var(--space-md);border-bottom:1px solid var(--color-border)}.plan-title{font-size:var(--font-size-xl);font-weight:800;color:var(--color-text);margin:var(--space-sm) 0 0;cursor:pointer}.plan-title:active{color:var(--color-primary)}.plan-title-edit{display:flex;gap:8px;margin:var(--space-sm) 0 0}.plan-title-input{flex:1;padding:8px 12px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-lg);font-weight:700;outline:none}.plan-title-save{padding:8px 14px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-primary-text);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.plan-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.plan-start{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--color-border)}.plan-start-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);flex-shrink:0}.plan-time-input{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-md);font-weight:600;outline:none;width:100px}.plan-time-input:focus{border-color:var(--color-border-focus)}.plan-places{padding:var(--space-md)}.plan-place-card{display:flex;gap:var(--space-md);padding-bottom:var(--space-md);position:relative}.plan-place-card:not(:last-child):before{content:"";position:absolute;left:15px;top:36px;bottom:0;width:2px;background:var(--color-border)}.plan-place-order{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:700;flex-shrink:0;z-index:1}.plan-place-body{flex:1;min-width:0}.plan-place-name-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.plan-place-name{font-size:var(--font-size-md);font-weight:700;color:var(--color-text)}.plan-place-actions{display:flex;gap:4px;flex-shrink:0}.plan-action-btn{width:26px;height:26px;border:none;border-radius:50%;background:var(--color-bg-hover);color:var(--color-text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.plan-action-btn:active{background:var(--color-primary-light);color:var(--color-primary)}.plan-action-btn.danger:active{background:var(--color-error);color:#fff}.plan-time-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:6px;align-items:center}.plan-time-field{display:flex;align-items:center;gap:4px}.plan-time-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.plan-time-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.plan-stay-input{width:56px;padding:4px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;text-align:center;outline:none}.plan-stay-input:focus{border-color:var(--color-border-focus)}.plan-stay-unit{font-size:var(--font-size-xs);color:var(--color-text-muted)}.plan-travel-segment{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;margin-left:15px;padding-left:var(--space-lg);position:relative}.plan-travel-segment:before{content:"";position:absolute;left:15px;top:0;bottom:0;width:2px;background:var(--color-border);opacity:.5}.plan-travel-icon{font-size:var(--font-size-sm);flex-shrink:0}.plan-travel-info{font-size:var(--font-size-xs);color:var(--color-text-secondary);flex:1}.plan-mode-toggle{display:flex;gap:2px;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.plan-mode-btn{padding:3px 8px;border:none;background:none;color:var(--color-text-muted);font-size:11px;cursor:pointer}.plan-mode-btn.active{background:var(--color-primary);color:var(--color-primary-text)}.plan-gap-warning{display:flex;align-items:center;gap:var(--space-sm);padding:6px 12px;margin:var(--space-xs) 0 var(--space-xs) 48px;background:#ffa5001f;border-radius:var(--radius-sm);border-left:3px solid var(--color-warning)}.plan-gap-text{font-size:var(--font-size-xs);color:var(--color-warning);font-weight:600}.plan-add-place{display:flex;justify-content:center;padding:var(--space-md) 0;margin-left:48px}.plan-add-btn{padding:8px 20px;border:1px dashed var(--color-primary);border-radius:var(--radius-lg);background:none;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.plan-add-btn:active{background:var(--color-primary-light)}.plan-end-section{margin:var(--space-md);padding:var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.plan-end-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text);margin-bottom:var(--space-sm)}.plan-end-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.plan-end-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.plan-end-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.plan-end-value.warning{color:var(--color-error)}.plan-end-value.ok{color:var(--color-success)}.plan-end-constraint{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.plan-end-constraint-label{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.plan-summary{margin:var(--space-md);padding:var(--space-md);background:var(--color-primary-light);border-radius:var(--radius-md);text-align:center}.plan-summary-text{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary)}.plan-no-home{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-sm)}.plan-no-home a{color:var(--color-primary);text-decoration:underline}.settings-page{height:calc(100dvh - 60px);overflow-y:auto;padding:var(--space-md);-webkit-overflow-scrolling:touch}.settings-section{margin-bottom:var(--space-lg);max-width:600px;margin-left:auto;margin-right:auto}.settings-input-group{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.settings-input-group .sheet-input{flex:1;min-width:120px}.settings-section-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.dday-hero{text-align:center;padding:var(--space-lg) var(--space-md);background:var(--color-primary-light);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.dday-hero-btn{width:100%;border:none;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.dday-hero-btn:active{opacity:.8}.dday-hint{font-size:10px;color:var(--color-text-muted);margin-top:6px;opacity:.7}.dday-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dday-count{font-size:2.5rem;font-weight:800;color:var(--color-primary);line-height:1.1}.dday-name{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.hero-picker-list{display:flex;flex-direction:column;gap:4px;padding:4px 0 8px}.hero-picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 4px;border:none;border-radius:var(--radius-sm);background:none;cursor:pointer;border-bottom:1px solid var(--color-border);-webkit-tap-highlight-color:transparent}.hero-picker-item:last-child{border-bottom:none}.hero-picker-item:active{background:var(--color-bg-hover)}.hero-picker-item.selected{background:var(--color-primary-light)}.hero-picker-left{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.hero-picker-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.hero-picker-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.hero-picker-right{display:flex;align-items:center;gap:8px}.hero-picker-value{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary)}.hero-picker-check{color:var(--color-primary);font-weight:700;font-size:var(--font-size-sm)}.dplus-checkbox-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text)}.dplus-checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.dplus-badge{display:inline-block;margin-left:6px;padding:1px 5px;font-size:10px;font-weight:700;background:var(--color-primary-light);color:var(--color-primary);border-radius:4px;vertical-align:middle}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm)}.theme-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);cursor:pointer;transition:border-color var(--transition)}.theme-chip.active{border-color:var(--color-primary)}.theme-chip:active{background:var(--color-bg-hover)}.theme-color-dot{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.1)}.theme-chip-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.anniversary-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border)}.anniversary-item:last-child{border-bottom:none}.anniversary-item.editing{background:var(--color-primary-light);margin:0 calc(-1 * var(--space-sm));padding:var(--space-sm);border-radius:var(--radius-sm)}.anniversary-item.auto{opacity:.7}.anniversary-info{display:flex;flex-direction:column;gap:2px;cursor:pointer;flex:1;min-width:0}.anniversary-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.anniversary-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.anniversary-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.anniversary-dday{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary)}.anniversary-delete-btn{width:24px;height:24px;border:none;background:none;color:var(--color-text-muted);font-size:14px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color var(--transition),background var(--transition)}.anniversary-delete-btn:hover,.anniversary-delete-btn:active{color:var(--color-error);background:color-mix(in srgb,var(--color-error) 10%,transparent)}.tag-edit-toggle{padding:4px 12px;border:1px solid var(--color-primary);border-radius:var(--radius-md);background:none;color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:all .2s}.tag-edit-toggle.active{background:var(--color-primary);color:var(--color-primary-text)}.anniversary-form{display:flex;flex-direction:column;gap:8px;padding:var(--space-sm);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.anniversary-form-actions{display:flex;gap:8px;justify-content:flex-end}.ann-submit-btn{background:var(--color-primary)!important;color:var(--color-primary-text)!important;font-weight:600;padding:10px 16px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:opacity .2s}.ann-submit-btn:hover{opacity:.9}.ann-submit-btn:active{opacity:.8}.auto-milestones{margin-top:var(--space-xs)}.profile-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0}.profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:700}.profile-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-text)}.profile-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.logout-btn{width:100%;padding:12px;border:1px solid var(--color-error);border-radius:var(--radius-md);background:none;color:var(--color-error);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.logout-btn:active{background:#ef44441a}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-bottom:var(--space-md)}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-sm);text-align:center}.stat-value{font-size:1.5rem;font-weight:800;color:var(--color-primary);line-height:1.2}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px}.stats-section{margin-top:var(--space-md)}.stats-subtitle{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.top-place-group{border-bottom:1px solid var(--color-border)}.top-place-group:last-child{border-bottom:none}.top-place-item{display:flex;align-items:center;gap:var(--space-sm);padding:6px 0;width:100%;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.top-place-item:hover{background:var(--color-bg-hover)}.top-place-rank{width:20px;height:20px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.top-place-name{flex:1;font-size:var(--font-size-sm);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-place-count{font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);flex-shrink:0}.top-place-expand{font-size:10px;color:var(--color-text-muted);flex-shrink:0}.top-place-records{background:var(--color-bg-card);border-radius:8px;margin:0 0 8px;overflow:hidden}.top-place-record{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-border)}.top-place-record:last-child{border-bottom:none}.top-place-record-link{flex:1;display:flex;flex-direction:column;gap:2px;background:none;border:none;cursor:pointer;text-align:left}.record-title{font-size:13px;color:var(--color-text)}.record-date{font-size:11px;color:var(--color-text-muted)}.record-delete-btn{padding:4px 8px;border-radius:6px;border:1px solid var(--color-error);background:none;color:var(--color-error);font-size:11px;cursor:pointer;flex-shrink:0;transition:all .15s}.record-delete-btn:hover{background:var(--color-error);color:#fff}.monthly-chart{display:flex;align-items:flex-end;gap:4px;height:120px;padding-top:var(--space-sm)}.monthly-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;height:100%}.monthly-bar-track{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.monthly-bar{width:100%;max-width:20px;background:var(--color-primary);border-radius:3px 3px 0 0;min-height:2px;transition:height .3s ease}.monthly-count{font-size:10px;font-weight:600;color:var(--color-primary);height:14px}.monthly-label{font-size:10px;color:var(--color-text-muted);white-space:nowrap}.tag-manage-list{margin-bottom:var(--space-sm)}.tag-manage-item{border-bottom:1px solid var(--color-border)}.tag-manage-item:last-child{border-bottom:none}.tag-manage-row{display:flex;align-items:center;gap:8px;padding:8px 0;cursor:default}.tag-manage-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.tag-manage-name{flex:1;font-size:var(--font-size-sm);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-manage-count{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0;min-width:16px;text-align:right}.tag-manage-delete{width:24px;height:24px;border:none;background:none;color:var(--color-text-muted);font-size:14px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tag-manage-delete:hover,.tag-manage-delete:active{color:var(--color-error);background:var(--color-primary-light)}.tag-edit-form{padding:var(--space-sm) 0;display:flex;flex-direction:column;gap:8px}.tag-edit-name{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input, var(--color-bg));color:var(--color-text);font-size:var(--font-size-sm);outline:none}.tag-edit-name:focus{border-color:var(--color-primary)}.tag-edit-actions{display:flex;gap:8px;justify-content:flex-end}.tag-palette{display:flex;flex-wrap:wrap;gap:6px}.tag-palette.compact{margin-top:6px}.tag-palette-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:border-color .15s,transform .15s}.tag-palette-dot:hover{transform:scale(1.15)}.tag-palette-dot.active{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-bg),0 0 0 4px var(--color-text)}.tag-palette-dot.reset{background:conic-gradient(#e74c3c,#f1c40f,#2ecc71,#3498db,#e74c3c 360deg)!important;position:relative}.tag-palette-dot.reset:after{content:"×";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--color-primary-text);text-shadow:0 1px 2px rgba(0,0,0,.5)}.tag-add-section{padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.tag-add-row{display:flex;align-items:center;gap:8px}.tag-add-input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input, var(--color-bg));color:var(--color-text);font-size:var(--font-size-sm);outline:none;min-width:0}.tag-add-input:focus{border-color:var(--color-primary)}.trash-tabs{display:flex;gap:4px;margin-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.trash-tab{flex:1;padding:10px 0;border:none;background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;border-bottom:2px solid transparent}.trash-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.trash-list{display:flex;flex-direction:column}.trash-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:10px 0;border-bottom:1px solid var(--color-border)}.trash-item:last-child{border-bottom:none}.trash-item-info{display:flex;flex-direction:column;min-width:0}.trash-item-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trash-item-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.trash-restore-btn{padding:6px 14px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:none;color:var(--color-primary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;flex-shrink:0}.trash-restore-btn:active{background:var(--color-primary-light)}.font-toggle{display:flex;gap:8px}.font-toggle-btn{flex:1;padding:10px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-input);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition)}.font-toggle-btn.active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.sw-update-toast{position:fixed;bottom:20px;left:20px;right:20px;padding:12px 16px;border-radius:var(--radius-md);display:flex;align-items:center;gap:12px;z-index:2500;animation:slideUp .3s ease-out;-webkit-user-select:none;user-select:none;touch-action:pan-x;cursor:grab}.sw-update-toast.updating{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #00000026}.sw-update-toast.complete{background:var(--color-success, #2ecc71);color:#fff;box-shadow:0 4px 12px #00000026;justify-content:space-between}.sw-update-toast span{font-size:14px;font-weight:500}.sw-update-toast .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.sw-update-toast .dismiss-btn{background:#fff3;color:#fff;border:none;padding:4px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;transition:background .2s;flex-shrink:0}.sw-update-toast .dismiss-btn:active{background:#ffffff4d}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}:root{--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .15);--transition: .2s ease;--font-family: "AppFont-Gothic", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px}[data-theme=light-blue]{--color-primary: #4A90D9;--color-primary-hover: #3A7BC8;--color-primary-light: #E8F2FC;--color-primary-text: #FFFFFF;--color-bg: #FAFBFC;--color-bg-card: #FFFFFF;--color-bg-input: #F5F7FA;--color-bg-hover: #EDF0F5;--color-text: #1A1D23;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #E5E7EB;--color-border-focus: var(--color-primary);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-msg-partner: #F3F4F6;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #E8729A;--color-partner-text: #FFFFFF}[data-theme=light-pink]{--color-primary: #E8729A;--color-primary-hover: #D4608A;--color-primary-light: #FDF2F6;--color-primary-text: #FFFFFF;--color-bg: #FDFAFB;--color-bg-card: #FFFFFF;--color-bg-input: #FBF5F7;--color-bg-hover: #F8EDF1;--color-text: #1A1D23;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #F0E0E6;--color-border-focus: var(--color-primary);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-msg-partner: #F9F0F3;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #4A90D9;--color-partner-text: #FFFFFF}[data-theme=light-green]{--color-primary: #34B27B;--color-primary-hover: #2A9D6C;--color-primary-light: #ECFDF5;--color-primary-text: #FFFFFF;--color-bg: #FAFDFB;--color-bg-card: #FFFFFF;--color-bg-input: #F5FAF7;--color-bg-hover: #EDF5F0;--color-text: #1A1D23;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #D1E7DD;--color-border-focus: var(--color-primary);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-msg-partner: #F0F9F4;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #9B59B6;--color-partner-text: #FFFFFF}[data-theme=light-purple]{--color-primary: #9B59B6;--color-primary-hover: #8E44AD;--color-primary-light: #F8EDFF;--color-primary-text: #FFFFFF;--color-bg: #FCF9FF;--color-bg-card: #FFFFFF;--color-bg-input: #F8F5FB;--color-bg-hover: #F2EBFA;--color-text: #1A1D23;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #E8E0F0;--color-border-focus: var(--color-primary);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-msg-partner: #F7F3F9;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #34B27B;--color-partner-text: #FFFFFF}[data-theme=dark-blue]{--color-primary: #5B9FE8;--color-primary-hover: #7AB3F0;--color-primary-light: #1A2942;--color-primary-text: #FFFFFF;--color-bg: #0F1117;--color-bg-card: #1A1D27;--color-bg-input: #22252F;--color-bg-hover: #2A2D3A;--color-text: #E8EAF0;--color-text-secondary: #9CA3B0;--color-text-muted: #6B7280;--color-border: #2D3140;--color-border-focus: var(--color-primary);--color-success: #34D399;--color-warning: #FBBF24;--color-error: #F87171;--color-msg-partner: #22252F;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #F08AAE;--color-partner-text: #FFFFFF}[data-theme=dark-pink]{--color-primary: #F08AAE;--color-primary-hover: #F5A3C0;--color-primary-light: #3D1A2A;--color-primary-text: #FFFFFF;--color-bg: #12090E;--color-bg-card: #1F1218;--color-bg-input: #2A1A22;--color-bg-hover: #351F2B;--color-text: #F0E4EA;--color-text-secondary: #B09AA5;--color-text-muted: #7A6670;--color-border: #3D2533;--color-border-focus: var(--color-primary);--color-success: #34D399;--color-warning: #FBBF24;--color-error: #F87171;--color-msg-partner: #2A1A22;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #5B9FE8;--color-partner-text: #FFFFFF}[data-theme=dark-green]{--color-primary: #4ADE80;--color-primary-hover: #6EE7A0;--color-primary-light: #0F2A1D;--color-primary-text: #0F2A1D;--color-bg: #080F0C;--color-bg-card: #121D17;--color-bg-input: #1A2920;--color-bg-hover: #22352A;--color-text: #E4F0E8;--color-text-secondary: #9AB0A0;--color-text-muted: #667A6E;--color-border: #253D2E;--color-border-focus: var(--color-primary);--color-success: #34D399;--color-warning: #FBBF24;--color-error: #F87171;--color-msg-partner: #1A2920;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #A78BFA;--color-partner-text: #FFFFFF}[data-theme=dark-purple]{--color-primary: #d6b3ff;--color-primary-hover: #f1b3ff;--color-primary-light: #3D1C54;--color-primary-text: #FFFFFF;--color-bg: #0D0812;--color-bg-card: #160D1E;--color-bg-input: #21142D;--color-bg-hover: #2D1A3D;--color-text: #F0EAF9;--color-text-secondary: #AFA4BE;--color-text-muted: #7A6F8A;--color-border: #3D3055;--color-border-focus: var(--color-primary);--color-success: #34D399;--color-warning: #FBBF24;--color-error: #F87171;--color-msg-partner: #231B33;--color-msg-me: var(--color-primary-light);--color-me: var(--color-primary);--color-partner: #4ADE80;--color-partner-text: #0F2A1D}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition),color var(--transition)}body{overscroll-behavior:none}#root{min-height:100dvh;display:flex;flex-direction:column}[data-font=normal]{--font-family: "AppFont-Normal", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}.login-container{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-lg)}.login-card{width:100%;max-width:360px;text-align:center}.login-title{font-size:var(--font-size-xl);color:var(--color-primary);margin-bottom:var(--space-xl);font-weight:700}.login-input{width:100%;padding:14px var(--space-md);font-size:var(--font-size-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-input);color:var(--color-text);outline:none;transition:border-color var(--transition)}.login-input:focus{border-color:var(--color-border-focus)}.login-input::placeholder{color:var(--color-text-muted)}.login-error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--space-sm)}.login-button{width:100%;padding:14px;margin-top:var(--space-md);font-size:var(--font-size-md);font-weight:600;color:var(--color-primary-text);background-color:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition)}.login-button:active{background-color:var(--color-primary-hover)}.main-content{flex:1;overflow:hidden}.page{padding:var(--space-lg)}
