:root{--color-primary: #4b614e;--color-primary-light: #5e7a61;--color-primary-dark: #364c39;--color-primary-container: #cfe9d0;--color-primary-fixed: #637a65;--color-accent: #924a34;--color-accent-light: #b5614a;--color-accent-container: #ffdbd1;--color-success: #4b614e;--color-warning: #924a34;--color-danger: #ba1a1a;--color-bg: #f8f5f0;--color-surface: #fffef9;--color-text: #1b1c1c;--color-text-secondary: #5a5d58;--color-border: #d6d4ce;--color-hover: #f0ede6;--color-ink: #2d3d30;--color-ink-light: #748c76;--color-mist: #c3c8c0;--font-family: "Noto Serif SC", "Noto Serif", "Songti SC", "STSong", serif;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-base: 15px;--font-size-lg: 18px;--font-size-xl: 22px;--font-size-headline: 28px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--shadow-sm: 0 1px 3px rgba(77, 100, 80, .06);--shadow-md: 0 4px 16px rgba(77, 100, 80, .08);--shadow-lg: 0 8px 32px rgba(77, 100, 80, .12);--shadow-inner: inset 0 1px 2px rgba(255, 255, 255, .4), 0 4px 12px rgba(75, 97, 78, .1);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-size-base);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);color:var(--color-text);background-color:var(--color-bg);line-height:1.7;min-height:100vh;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right);overflow-x:hidden;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}img{max-width:100%;height:auto}input,textarea,select,button{font-family:inherit;font-size:inherit}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.5}#app{position:relative;z-index:1}.page{max-width:600px;margin:0 auto;padding:var(--spacing-md);min-height:100vh}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center}.page-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.page-header h1{font-size:var(--font-size-lg);font-weight:600;flex:1;letter-spacing:.02em}.page-header .back-btn{font-size:var(--font-size-lg);color:var(--color-ink-light);cursor:pointer;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border:none;background:none;transition:opacity .2s}.page-header .back-btn:active{opacity:.6}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;display:inline-block;vertical-align:middle;-webkit-user-select:none;user-select:none}.pattern-lattice{background-image:radial-gradient(circle at 1px 1px,rgba(115,121,114,.08) 1px,transparent 0);background-size:20px 20px}.pattern-huiwen{position:relative}.pattern-huiwen:before,.pattern-huiwen:after{content:"";position:absolute;width:20px;height:20px;opacity:.12;pointer-events:none}.pattern-huiwen:before{top:8px;right:8px;border:2px solid var(--color-primary);border-radius:2px}.pattern-huiwen:after{bottom:8px;left:8px;border:2px solid var(--color-accent);border-radius:2px}.cloud-accent{position:relative}.cloud-accent:after{content:"";position:absolute;bottom:-8px;right:16px;width:32px;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 16' fill='none'%3E%3Cpath d='M8 12c-3 0-6-1.5-6-4.5S4 3 7 3c1-1.5 3-2.5 5-2.5 3 0 5.5 2 6 4.5 2 .5 4 2 4 4.5 0 3-3 2.5-5 2.5H8z' fill='%23748c76' opacity='0.15'/%3E%3C/svg%3E") no-repeat;pointer-events:none}.jade-gradient{background:linear-gradient(135deg,#4d6450,#2d3d30);box-shadow:inset 0 2px 4px #ffffff1a,0 10px 20px #00000026}.divider{height:1px;background:linear-gradient(to right,transparent,var(--color-border),transparent);margin:var(--spacing-lg) 0;position:relative}.divider:before{content:"";position:absolute;left:50%;top:-3px;width:7px;height:7px;border:1px solid var(--color-border);transform:translate(-50%) rotate(45deg);background:var(--color-bg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}button,a,[role=button],input,select,textarea{min-height:44px}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-weight:500;margin-bottom:var(--spacing-xs);color:var(--color-text);font-size:var(--font-size-sm);letter-spacing:.02em}.form-group input,.form-group textarea,.form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-surface);transition:border-color .3s,box-shadow .3s;min-height:44px;color:var(--color-text)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4b614e1a}.form-group textarea{min-height:120px;resize:vertical;line-height:1.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:500;cursor:pointer;min-height:44px;transition:all .2s;text-decoration:none;letter-spacing:.02em;font-family:var(--font-family)}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:inset 0 1px 2px #ffffff26,0 2px 8px #4b614e33}.btn-primary:hover{background:var(--color-primary-light)}.btn-secondary{background:var(--color-hover);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn-accent{background:var(--color-accent);color:#fff;box-shadow:inset 0 1px 2px #ffffff26,0 2px 8px #924a3433}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);min-height:36px}.btn-block{display:flex;width:100%}.btn-ghost{background:none;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-ghost:hover{background:#4b614e0f}.tab-bar{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(195,200,192,.4)}.tab-bar .tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);text-align:center;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;border:none;background:none;min-height:44px;transition:all .3s;letter-spacing:.04em;position:relative}.tab-bar .tab.active{color:var(--color-primary);background:#4b614e0f}.tab-bar .tab.active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--color-primary);border-radius:2px 2px 0 0}.list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);box-shadow:var(--shadow-sm);cursor:pointer;min-height:44px;transition:background-color .15s;border:1px solid rgba(195,200,192,.3)}.list-item:hover{background:var(--color-hover)}.list-item .item-content{flex:1;min-width:0}.list-item .item-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item .item-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.list-item .item-action{flex-shrink:0}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-md);color:var(--color-text-secondary)}.empty-state .empty-icon{font-size:48px;margin-bottom:var(--spacing-md);color:var(--color-ink-light);opacity:.6}.empty-state .empty-text{font-size:var(--font-size-base);margin-bottom:var(--spacing-md);letter-spacing:.02em}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);color:var(--color-text-secondary)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:var(--spacing-sm)}@keyframes spin{to{transform:rotate(360deg)}}code{background:#4b614e14;padding:1px 6px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-primary-dark);font-family:Menlo,Consolas,monospace}input[type=date]{min-width:0;max-width:100%;-webkit-min-logical-width:0}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-md);border:1px solid rgba(195,200,192,.4);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(115,121,114,.04) 1px,transparent 0);background-size:20px 20px;pointer-events:none}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.card-title{font-weight:600;font-size:var(--font-size-base);letter-spacing:.02em}.card-body{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.8}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:500;letter-spacing:.04em}.badge-primary{background:#4b614e1a;color:var(--color-primary)}.badge-success{background:#4b614e1f;color:#3d5140}.badge-warning{background:#924a341a;color:var(--color-accent)}.badge-danger{background:#ba1a1a14;color:var(--color-danger)}.badge-ongoing{background:#4b614e26;color:var(--color-primary-dark);font-weight:600}.badge-completed{background:#5a5d5814;color:var(--color-text-secondary)}.toast-container{position:fixed;top:var(--safe-top);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);pointer-events:none}.toast{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastIn .3s ease;white-space:nowrap;letter-spacing:.02em}.toast.toast-success{background:var(--color-primary);color:#fff}.toast.toast-error{background:var(--color-danger);color:#fff}.toast.toast-info{background:var(--color-ink);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1e1c73;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-overlay.modal-center{align-items:center}.modal{background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;padding:var(--spacing-lg);animation:slideUp .3s ease}.modal-overlay.modal-center .modal{border-radius:var(--radius-lg);margin:var(--spacing-md)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.modal-header h3{font-size:var(--font-size-lg);font-weight:600;letter-spacing:.02em}.modal-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:none;font-size:20px;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-full);transition:background .2s}.modal-close:hover{background:var(--color-hover)}.modal-footer{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.modal-footer .btn{flex:1}.collapsible-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;cursor:pointer;min-height:44px;font-weight:500;color:var(--color-text)}.collapsible-header:after{content:"";font-family:Material Symbols Outlined;font-size:20px;color:var(--color-ink-light);transition:transform .3s}.collapsible-header.open:after{transform:rotate(90deg)}.collapsible-body{display:none;padding-bottom:var(--spacing-sm);color:var(--color-text-secondary);line-height:1.8}.collapsible-body.open{display:block}.trip-card-wrapper{position:relative;margin-bottom:var(--spacing-sm);overflow:hidden}.trip-card-wrapper .list-item{position:relative;z-index:1;transition:transform .3s ease;background:var(--color-surface);margin-bottom:0}.trip-card-wrapper .trip-delete-btn{position:absolute;right:0;top:0;bottom:0;width:80px;display:flex;align-items:center;justify-content:center;background:var(--color-danger);color:#fff;border:none;cursor:pointer;font-size:24px;opacity:0;transition:opacity .2s;border-radius:0 var(--radius-md) var(--radius-md) 0}.trip-card-wrapper .list-item[data-swiped]+.trip-delete-btn,.trip-card-wrapper .trip-delete-btn.visible{opacity:1}.trip-completed .list-item{opacity:.65}.section-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-ink);letter-spacing:.05em;position:relative;padding-left:var(--spacing-md)}.section-title:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--color-primary);border-radius:2px}.btn-icon-sm{width:36px;height:36px;min-width:36px;min-height:36px;padding:0;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;border:none;background:var(--color-hover);color:var(--color-text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.btn-icon-sm:hover{background:#4b614e1a;color:var(--color-primary)}.btn-icon-sm:active{transform:scale(.92)}.btn-icon-sm.danger{color:var(--color-danger)}.btn-icon-sm.danger:hover{background:#ba1a1a14}.btn-icon-sm .material-symbols-outlined{font-size:18px}.back-to-top{position:fixed;bottom:calc(var(--safe-bottom) + 80px);right:20px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(195,200,192,.3);background:#fffef973;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--color-primary);box-shadow:none;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:90;transition:opacity .3s,transform .3s}.back-to-top.visible{display:flex}.back-to-top:active{transform:scale(.9)}.fontsize-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;background:#fffef9d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(195,200,192,.3);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--spacing-xs) 0;min-width:80px;z-index:110}.fontsize-menu.open{display:block}.fontsize-option{display:block;width:100%;text-align:center;padding:6px var(--spacing-md);border:none;background:none;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text-secondary);font-family:var(--font-family);min-height:32px;transition:all .15s}.fontsize-option:hover,.fontsize-option:active{background:var(--color-hover);color:var(--color-primary)}.fontsize-option.active{background:var(--color-primary);color:#fff;font-weight:500}
