:root{--bg: #FDFBF7;--surface: #FFFFFF;--surface-light: #F5F2ED;--card: #FFFFFF;--text: #3F3D3C;--text-secondary: #7A7571;--text-muted: #A39D98;--primary: #D9734E;--primary-light: #E89374;--primary-dark: #BC5936;--secondary: #739E82;--secondary-dark: #568065;--accent: #D9A0A0;--warning: #E5A93D;--danger: #D95C5C;--success: #739E82;--border: #EBE6E0;--overlay: rgba(63, 61, 60, .4);--grad-primary: linear-gradient(135deg, #E89374, #D9734E);--grad-cta: linear-gradient(90deg, #E89374, #D9734E, #BC5936);--grad-accent: linear-gradient(90deg, #EBC2C2, #D9A0A0);--grad-success: linear-gradient(90deg, #8AB89A, #739E82);--shadow-card: 0 2px 8px rgba(0, 0, 0, .04);--shadow-elevated: 0 4px 12px rgba(0, 0, 0, .08);--shadow-glow: 0 2px 16px rgba(217, 115, 78, .15);--xs: 4px;--sm: 8px;--md: 16px;--lg: 24px;--xl: 32px;--xxl: 48px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-full: 9999px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}input,textarea,button{font-family:inherit;font-size:inherit}.app-shell{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;position:relative}.page{flex:1;overflow-y:auto;padding:var(--md);padding-top:calc(48px + var(--md));padding-bottom:100px}.tab-bar{display:flex;background:var(--surface);box-shadow:0 -4px 16px #0000004d;padding:var(--sm) 0 calc(var(--sm) + env(safe-area-inset-bottom,0px));position:sticky;bottom:0;z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--xs) 0;text-decoration:none;color:var(--text-muted);font-size:11px;font-weight:500;position:relative;transition:color .2s;cursor:pointer;background:none;border:none}.tab-item.active{color:var(--primary)}.tab-icon{font-size:20px;height:24px;display:flex;align-items:center}.tab-item.active:after{content:"";position:absolute;bottom:-2px;width:20px;height:3px;border-radius:2px;background:var(--primary)}.auth-page{flex:1;display:flex;flex-direction:column;justify-content:center;padding:var(--lg);max-width:480px;margin:0 auto;width:100%;min-height:100vh}.auth-header{text-align:center;margin-bottom:var(--xxl)}.logo-wrap{width:80px;height:80px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;margin:0 auto var(--md);box-shadow:var(--shadow-glow);overflow:hidden}.logo-img{width:64px;height:64px;object-fit:contain}.auth-title{font-size:36px;font-weight:800;letter-spacing:-1px}.auth-subtitle{font-size:15px;color:var(--text-secondary);margin-top:var(--xs)}.auth-form{display:flex;flex-direction:column;gap:var(--md)}.input-group{display:flex;flex-direction:column;gap:var(--xs)}.input-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-left:var(--xs)}.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--md);font-size:15px;color:var(--text);outline:none;transition:border-color .2s,background .2s;width:100%}.input:focus{border-color:var(--primary);background:var(--surface-light)}.input.accent-focus:focus{border-color:var(--accent)}.input.warning-focus:focus{border-color:var(--warning)}textarea.input{min-height:80px;resize:vertical}.btn{border:none;border-radius:var(--r-md);padding:var(--md);font-size:17px;font-weight:600;cursor:pointer;text-align:center;transition:opacity .2s,transform .1s;display:inline-flex;align-items:center;justify-content:center;gap:var(--sm)}.btn:hover{opacity:.9}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-gradient{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-elevated)}.btn-gradient-accent{background:var(--grad-accent);color:#fff;box-shadow:var(--shadow-elevated)}.btn-gradient-success{background:var(--grad-success);color:#fff;box-shadow:var(--shadow-elevated)}.btn-secondary{background:var(--surface-light);color:var(--text-secondary)}.btn-outline-danger{background:#ff4f6b14;border:1px solid rgba(255,79,107,.4);color:var(--danger);font-weight:600}.btn-small{padding:var(--xs) var(--md);font-size:13px;border-radius:var(--r-full);font-weight:600}.btn-primary-small{background:var(--primary);color:#fff}.btn-success-small{background:var(--success);color:#fff}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--md);box-shadow:var(--shadow-card);transition:transform .15s}.card.clickable{cursor:pointer}.card.clickable:hover{transform:translateY(-2px)}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--lg);box-shadow:var(--shadow-card)}.balance-card{background:var(--grad-primary);border-radius:var(--r-lg);padding:var(--lg);text-align:center;box-shadow:var(--shadow-elevated);margin-bottom:var(--md)}.balance-label{font-size:13px;color:#ffffffb3;font-weight:500}.balance-value{font-size:36px;font-weight:800;color:#fff;margin-top:var(--xs)}.balance-currency{font-size:17px;color:#fffc;font-weight:500}.badge{display:inline-flex;padding:2px var(--sm);border-radius:var(--r-full);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.card-list{display:flex;flex-direction:column;gap:var(--sm)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--xs)}.card-title{font-size:17px;font-weight:600;flex:1;margin-right:var(--sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-desc{font-size:13px;color:var(--text-secondary);margin-bottom:var(--sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--sm)}.card-meta{display:flex;gap:var(--md);font-size:13px}.meta-value{color:var(--secondary);font-weight:600}.meta-time{color:var(--warning);font-weight:500}.fab{position:fixed;bottom:90px;right:calc(50% - 210px);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;color:#fff;font-weight:700;border:none;cursor:pointer;box-shadow:var(--shadow-elevated);transition:transform .2s;z-index:50}.fab:hover{transform:scale(1.1)}.fab:active{transform:scale(.95)}.fab-primary{background:var(--grad-cta)}.fab-accent{background:var(--grad-accent)}@media(max-width:520px){.fab{right:20px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);display:flex;align-items:flex-end;justify-content:center;z-index:200;animation:fadeIn .2s}.modal-content{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:var(--lg);width:100%;max-width:480px;display:flex;flex-direction:column;gap:var(--md);animation:slideUp .3s;max-height:90vh;overflow-y:auto}.drag-handle{width:40px;height:4px;border-radius:2px;background:var(--text-muted);margin:0 auto var(--sm)}.modal-title{font-size:22px;font-weight:700;text-align:center}.modal-buttons{display:flex;gap:var(--md);margin-top:var(--sm)}.modal-buttons .btn{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.row{display:flex;gap:var(--md)}.row>*{flex:1}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--xs) 0}.info-label{font-size:13px;color:var(--text-secondary)}.info-value{font-size:13px;color:var(--text);font-weight:500}.divider{height:1px;background:var(--border);margin:2px 0}.avatar{width:80px;height:80px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--md);box-shadow:var(--shadow-elevated)}.avatar-text{font-size:36px;font-weight:800;color:#fff}.avatar-sm{width:36px;height:36px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.profile-card{text-align:center;display:flex;flex-direction:column;align-items:center}.display-name{font-size:22px;font-weight:700}.email{font-size:13px;color:var(--text-secondary);margin-top:var(--xs)}.invite-code{font-size:15px;color:var(--warning);font-weight:700;letter-spacing:2px}.member-row{display:flex;align-items:center;gap:var(--sm);padding:var(--xs) 0}.member-name{flex:1;font-size:15px}.member-balance{font-size:13px;color:var(--secondary);font-weight:600}.choice-buttons{display:flex;gap:var(--md);margin-top:var(--sm)}.choice-btn{flex:1;padding:var(--lg);border-radius:var(--r-md);border:1px solid var(--primary);background:none;text-align:center;cursor:pointer;color:var(--primary);font-weight:600;font-size:15px;display:flex;flex-direction:column;align-items:center;gap:var(--xs);transition:background .2s}.choice-btn:hover{background:#7c5cfc14}.choice-btn.secondary{border-color:var(--secondary);color:var(--secondary)}.choice-btn.secondary:hover{background:#00d9a514}.choice-emoji{font-size:28px}.mode-toggle{display:flex;gap:var(--sm);background:var(--bg);border-radius:var(--r-md);padding:4px}.mode-btn{flex:1;padding:var(--sm);border-radius:var(--r-sm);border:none;background:none;color:var(--text-secondary);font-weight:600;font-size:13px;cursor:pointer;transition:background .2s,color .2s}.mode-btn.active{background:var(--accent);color:#fff}.mode-hint{font-size:11px;color:var(--text-muted);text-align:center}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--lg)}.back-btn{background:none;border:none;color:var(--primary);font-size:15px;font-weight:600;cursor:pointer;padding:var(--xs) var(--md) var(--xs) 0}.status-chip{padding:var(--xs) var(--md);border-radius:var(--r-full);font-size:13px;font-weight:700}.detail-title{font-size:28px;font-weight:800;margin-bottom:var(--xs)}.detail-desc{font-size:15px;color:var(--text-secondary);margin-bottom:var(--md);line-height:1.5}.meta-cards{display:flex;gap:var(--md);margin-bottom:var(--lg)}.meta-card{flex:1;background:var(--surface);border-radius:var(--r-md);padding:var(--md);border:1px solid var(--border);box-shadow:var(--shadow-card)}.meta-card-label{font-size:11px;color:var(--text-secondary);margin-bottom:var(--xs)}.meta-card-value{font-size:22px;font-weight:700}.proposal-card{background:var(--surface);border-radius:var(--r-md);padding:var(--md);margin-bottom:var(--sm);border:1px solid var(--border);box-shadow:var(--shadow-card)}.proposal-card.accepted{border-color:#00d9a54d}.proposal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sm)}.proposal-from{font-size:13px;color:var(--text-secondary);font-weight:500}.proposal-values{display:flex;gap:var(--lg);margin-bottom:var(--sm)}.proposal-label{font-size:11px;color:var(--text-muted)}.proposal-amount{font-size:17px;font-weight:700}.proposal-actions{display:flex;gap:var(--sm);margin-top:var(--xs)}.proposal-actions .btn{flex:1}.waiting-text{font-size:13px;color:var(--warning);font-style:italic;margin-top:var(--xs)}.propose-toggle{background:var(--surface);border-radius:var(--r-md);padding:var(--md);text-align:center;border:1px dashed rgba(255,180,67,.3);color:var(--warning);font-weight:600;cursor:pointer;transition:background .2s}.propose-toggle:hover{background:var(--surface-light)}.actions-list{display:flex;flex-direction:column;gap:var(--md);margin-top:var(--md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--xxl);text-align:center;min-height:300px}.empty-icon{font-size:56px;margin-bottom:var(--md)}.empty-title{font-size:22px;font-weight:700}.empty-subtitle{font-size:15px;color:var(--text-secondary);margin-top:var(--sm)}.empty-list{padding:var(--xxl);text-align:center;color:var(--text-muted);font-size:15px}.page-header{margin-bottom:var(--md)}.page-title{font-size:22px;font-weight:700}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:var(--xs)}.auth-footer{display:flex;justify-content:center;gap:var(--xs);margin-top:var(--lg);font-size:15px}.auth-footer span{color:var(--text-secondary)}.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.error-text{color:var(--danger);font-size:13px;text-align:center;padding:var(--sm);background:#ff4f6b1a;border-radius:var(--r-sm)}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:15px;color:var(--text-muted)}.section-title{font-size:17px;font-weight:700;margin-bottom:var(--sm)}.section-desc{font-size:13px;color:var(--text-secondary)}.cost-badge{padding:3px var(--sm);border-radius:var(--r-full);font-size:13px;font-weight:700}.requested-tag{font-size:11px;color:var(--warning);margin-top:2px}.insufficient-text{font-size:11px;color:var(--danger);font-style:italic}.negotiating-text{font-size:11px;color:var(--warning);font-style:italic}.card-redeemed{opacity:.5}.members-title{font-size:15px;font-weight:600;margin-top:var(--md);margin-bottom:var(--xs)}.form-section{display:flex;flex-direction:column;gap:var(--md);margin-top:var(--sm)}.form-buttons{display:flex;gap:var(--md)}.form-buttons .btn{flex:1}.sections-gap{display:flex;flex-direction:column;gap:var(--md)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
