*{box-sizing:border-box;margin:0;padding:0;-ms-overflow-style:none;scrollbar-width:none}::-webkit-scrollbar{display:none}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background-color:#f5f5f5;color:#333;max-width:600px;margin:0 auto;height:100vh;overflow:hidden;display:flex;flex-direction:column}#view-detail,#view-hold,#view-watch{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.disclaimer-bar{background-color:#fffbe6;color:#d48806;font-size:12px;height:30px;line-height:30px;overflow:hidden;position:relative;width:100%;border-bottom:1px solid #ffe58f;flex-shrink:0}.disclaimer-content{display:inline-block;white-space:nowrap;animation:20s linear infinite scroll-left;padding-left:100%;will-change:transform;-webkit-transform:translateZ(0);transform:translateZ(0)}@-webkit-keyframes scroll-left{0%{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}100%{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}@keyframes scroll-left{0%{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}100%{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.header{background:linear-gradient(to right,#ffd04b,#ffbd20);padding:12px 16px 10px;color:#333;flex-shrink:0}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.app-title{font-size:16px;font-weight:700}.total-section{display:flex;justify-content:space-between;align-items:flex-end}.total-item{flex:1}.total-label{font-size:12px;opacity:.8;margin-bottom:2px}.total-value{font-size:26px;font-weight:700}.total-profit{text-align:right}.total-profit .total-value{font-size:20px}.group-tabs-wrapper{margin-top:10px;display:flex;align-items:center;gap:0}.group-tabs-label{display:flex;align-items:center;gap:0;background:rgba(255,255,255,.4);border-radius:16px;padding:2px 4px;flex-shrink:0;margin-right:10px;border:1px solid rgba(255,255,255,.3);box-shadow:0 1px 2px rgba(0,0,0,.03)}.group-label-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:0 0;cursor:pointer;border:none;color:#7a6520;font-size:14px;padding:0;-webkit-tap-highlight-color:transparent;transition:background-color .2s}.group-label-btn.text-btn{width:auto;height:24px;border-radius:12px;font-size:13px;font-weight:600;padding:0 8px;background-color:transparent;box-shadow:none;color:#5c4b18}.group-vert-line{width:1px;height:14px;background:rgba(92,75,24,.2);margin:0 4px}.group-label-btn:hover{background:rgba(255,255,255,.3)}.group-label-btn:active{opacity:.6;transform:scale(.96)}.group-label-btn svg{width:16px;height:16px;fill:#5c4b18}.group-tabs-scroll{flex:1;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}.group-tabs-scroll::-webkit-scrollbar{display:none}.group-tabs-scroll.dragging{cursor:grabbing}.group-tabs-inner{display:inline-flex;gap:6px}.group-tab{display:inline-block;padding:4px 14px;border-radius:14px;font-size:12px;cursor:pointer;background:rgba(255,255,255,.35);color:#333;border:none;white-space:nowrap;transition:.2s;-webkit-tap-highlight-color:transparent;user-select:none}.group-tab:active{opacity:.7}.group-tab.active{background:#fff;font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.1)}.group-manage-list{max-height:300px;overflow-y:auto}.group-manage-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5;gap:8px}.group-manage-item:last-child{border-bottom:none}.group-manage-name{flex:1;font-size:14px;color:#333}.group-manage-name.default{color:#999}.group-manage-count{font-size:12px;color:#999;margin-right:8px}.group-manage-btn{padding:4px 10px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;cursor:pointer;color:#666}.group-manage-btn:active{background:#f5f5f5}.group-manage-btn.danger{color:#e74c3c;border-color:#fdd}.group-manage-btn.danger:active{background:#fff5f5}.form-select{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;outline:0;font-size:16px;background:#fff;color:#333;appearance:auto;-webkit-appearance:auto}.form-select:focus{border-color:#ffbd20}.list-header{background:#fff;padding:10px 20px;display:flex;justify-content:space-between;font-size:12px;color:#999;border-bottom:1px solid #eee;align-items:center;flex-shrink:0}.col-action{flex:1.2;display:flex;gap:15px;align-items:center}.icon-btn{cursor:pointer;width:20px;height:20px;fill:#666}.col-val{flex:0.8;text-align:right;display:flex;align-items:center;justify-content:center}.col-val.align-right{justify-content:flex-end}.header-sort-box{display:flex;flex-direction:column;margin-left:4px;justify-content:center;height:14px}.sort-arrow{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;cursor:pointer;opacity:.2;margin:1px 0}.sort-arrow.active{opacity:1;border-color:#333 transparent transparent}.sort-arrow:hover{opacity:.6}.sort-arrow.up{border-bottom:5px solid #333;border-top:none}.sort-arrow.down{border-top:5px solid #333;border-bottom:none}.scroll-container{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:#fff}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:50px;background:#fff;display:flex;justify-content:space-around;align-items:center;border-top:1px solid #eee;z-index:100;max-width:600px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999;text-decoration:none;font-size:10px;flex:1;height:100%;cursor:pointer;-webkit-tap-highlight-color:transparent}.nav-item.active{color:#333;font-weight:700}.nav-item svg{width:24px;height:24px;margin-bottom:2px;fill:currentColor}.edit-actions{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;height:60px;display:flex;justify-content:space-around;align-items:center;box-shadow:0 -2px 10px rgba(0,0,0,.05);z-index:200;max-width:600px;margin:0 auto}.action-btn{display:flex;flex-direction:column;align-items:center;font-size:12px;cursor:pointer;gap:4px;flex:1;text-align:center;padding:5px 0}.action-btn:active{background-color:#f9f9f9}.action-btn svg{width:20px;height:20px;margin-bottom:2px}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:100;align-items:center;justify-content:center}.modal{background:#fff;padding:20px;border-radius:12px;width:85%;max-width:320px;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:.3s cubic-bezier(.18,.89,.32,1.28) modalPop}@keyframes modalPop{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}.modal h3{margin-bottom:15px;font-size:18px;text-align:center}.modal p{margin-bottom:25px;color:#666;font-size:15px;text-align:center}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-size:14px;color:#666}.form-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;outline:0;font-size:16px}.form-input:focus{border-color:#ffbd20}.modal-btns{display:flex;gap:10px;margin-top:20px}.btn-cancel{flex:1;padding:10px;border:none;background:#f5f5f5;border-radius:6px;cursor:pointer;color:#666;font-size:15px}.btn-confirm{flex:1;padding:10px;border:none;background:#ffbd20;border-radius:6px;font-weight:700;cursor:pointer;color:#333;font-size:15px}.btn-danger{background:#ffebee;color:#d32f2f}.btn-danger:hover{background:#ffcdd2}.qr-modal-content{background-color:#fff;margin:20% auto;padding:30px;border-radius:12px;width:80%;max-width:300px;text-align:center;position:relative;box-shadow:0 4px 20px rgba(0,0,0,.2)}.qr-code-box{margin:20px auto;padding:10px;background:#fff;border:1px solid #eee;border-radius:8px;display:inline-block}.qr-url-text{background:#f5f5f5;padding:10px;border-radius:4px;font-family:monospace;margin:15px 0;word-break:break-all;font-size:14px;color:#666;user-select:text}.copy-btn{background:#fcaa00;color:#fff;border:none;padding:8px 20px;border-radius:20px;font-size:14px;cursor:pointer}.copy-btn:active{background:#e59b00}.check-mode .fund-item{padding-left:10px}.check-col{display:none;margin-right:10px;align-items:center}.check-mode .check-col{display:flex;align-items:center}.sort-btns{display:none;flex-direction:column;gap:5px;margin-left:5px}.check-mode .sort-btns{display:flex}.sort-btn{font-size:12px;line-height:1;color:#999;cursor:pointer;width:20px;text-align:center}.pin-btn{cursor:pointer;margin-left:10px;color:#ddd;display:flex;align-items:center;width:24px;height:24px}.pin-btn svg{fill:currentColor;width:20px;height:20px}.pin-btn.pinned{color:#f39c12}.fund-list{background:#fff}.fund-item{padding:15px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.fund-info{flex:1.2}.fund-name{font-size:16px;margin-bottom:5px;color:#333;font-weight:500}.fund-code{font-size:12px;color:#999;display:flex;flex-direction:column;gap:2px}.code-row{font-family:monospace;display:flex;align-items:center;gap:5px}.hold-row{font-size:12px;opacity:.8;color:#222}.tag{border:1px solid #4caf50;background:#4caf50;color:#fff;font-size:10px;padding:0 3px;border-radius:2px;display:inline-block;line-height:1.2;transform:scale(.9);transform-origin:left center}.industry-tag{font-size:10px;padding:1px 4px;border-radius:4px;background:#fffbe6;color:#d46b08;border:1px solid #ffe58f;display:none;line-height:normal;transform:scale(.9);transform-origin:left center;white-space:nowrap;margin-left:2px}.fund-data{flex:0.8;text-align:right}.fund-data-top{font-size:18px;font-weight:700;margin-bottom:2px}.fund-data-bottom{font-size:12px}.c-red{color:#e74c3c}.c-green{color:#2ecc71}.c-gray{color:#999}.c-blue{color:#007bff}@media (max-width:414px){.header{padding:10px 12px 16px}.total-value{font-size:22px}.total-profit .total-value{font-size:17px}.total-label{font-size:11px}.app-title{font-size:14px}.list-header{padding:8px 12px;font-size:11px}.col-action{gap:10px}.fund-item{padding:12px}.fund-name{font-size:14px;margin-bottom:3px}.fund-code,.hold-row{font-size:11px}.fund-data-top{font-size:15px}.fund-data-bottom{font-size:11px}.tag{font-size:9px}.industry-tag{font-size:9px;padding:0 3px;transform:scale(.8)}.fund-info{flex:1.1!important}.fund-data{flex:0.7!important}.modal-card{width:94%}.app-confirm-box{width:85%}.app-confirm-btns button,.app-confirm-msg{font-size:14px}}@media (max-width:360px){.header{padding:8px 10px 12px}.header-top{margin-bottom:8px}.total-value{font-size:20px}.total-profit .total-value{font-size:15px}.total-label{font-size:10px}.app-title{font-size:13px}.list-header{padding:6px 10px;font-size:10px}.col-action{gap:8px}.icon-btn{width:18px;height:18px}.fund-item{padding:10px}.fund-name{font-size:13px;margin-bottom:2px}.fund-code{font-size:10px}.code-row{gap:3px}.hold-row{font-size:10px}.fund-data-top{font-size:14px}.fund-data-bottom{font-size:10px}.tag{font-size:8px;padding:0 2px}.industry-tag{font-size:8px;padding:0 2px;transform:scale(.8)}.fund-info{flex:1!important}.fund-data{flex:0.65!important}.check-col{width:28px;min-width:28px}.pin-btn svg{width:14px;height:14px}.fund-check{width:15px;height:15px}.disclaimer-bar{height:24px;line-height:24px;font-size:10px}.bottom-nav{height:44px}.nav-item{font-size:9px}.nav-item svg{width:20px;height:20px}.modal-card{width:96%;padding:15px}.modal-title{font-size:16px}.form-group{margin-bottom:12px}.form-label{font-size:12px}.form-input{font-size:14px;padding:8px}.app-confirm-box{width:88%}.app-confirm-msg{font-size:13px}.app-confirm-btns button{font-size:13px;padding:9px}}.skeleton{background:linear-gradient(90deg,#f2f2f2 25%,#e6e6e6 50%,#f2f2f2 75%)!important;background-size:200% 100%!important;animation:1.5s ease-in-out infinite skeleton-pulse!important;border-radius:4px!important;color:transparent!important;border-color:transparent!important;pointer-events:none}.skeleton *{color:transparent!important}@keyframes skeleton-pulse{0%{background-position:200% 0}100%{background-position:-200% 0}}.skeleton-title{width:120px;height:22px;display:inline-block}.skeleton-code{width:80px;height:16px;display:inline-block}.skeleton-big{width:160px;height:40px;display:inline-block}.skeleton-tag{width:60px;height:24px;display:inline-block}.skeleton-val{width:90px;height:18px;display:inline-block}.skeleton-small{width:70px;height:14px;display:inline-block}.app-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);background:rgba(0,0,0,.75);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;line-height:1.5;max-width:80%;text-align:center;z-index:99999;pointer-events:none;opacity:0;transition:opacity .25s,transform .25s;word-break:break-word}.app-toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.app-confirm-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:99998;align-items:center;justify-content:center}.app-confirm-overlay.show{display:flex}.app-confirm-box{background:#fff;padding:20px;border-radius:12px;width:80%;max-width:300px;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:.3s cubic-bezier(.18,.89,.32,1.28) modalPop}.app-confirm-msg{font-size:15px;color:#333;text-align:center;margin-bottom:20px;line-height:1.5;word-break:break-word}.app-confirm-btns{display:flex;gap:10px}.app-confirm-btns button{flex:1;padding:10px;border:none;border-radius:6px;font-size:15px;cursor:pointer}.app-confirm-cancel{background:#f5f5f5;color:#666}.app-confirm-ok{background:#ffbd20;color:#333;font-weight:700}.ai-link-btn{display:inline-flex;align-items:center;padding:6px 14px;background:#fff;border:1px solid #d9d9d9;border-radius:16px;color:#7c3aed;font-size:13px;text-decoration:none;cursor:pointer;transition:.2s}.ai-link-btn:hover{background:#7c3aed;color:#fff;border-color:#7c3aed}.ai-icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:0 6px;height:20px;background:linear-gradient(135deg,#6d28d9 0,#7c3aed 45%,#c026d3 100%);color:#fff;font-size:11px;font-weight:900;font-family:'Arial Black',Arial,sans-serif;border-radius:4px;cursor:pointer;letter-spacing:1px;line-height:1;user-select:none;box-shadow:0 1px 4px rgba(124,58,237,.45),inset 0 1px 0 rgba(255,255,255,.15);text-shadow:0 1px 2px rgba(0,0,0,.2)}.ai-icon-btn:active,.ai-icon-btn:hover{background:linear-gradient(135deg,#6d28d9 0,#7c3aed 45%,#c026d3 100%);box-shadow:0 1px 4px rgba(124,58,237,.45),inset 0 1px 0 rgba(255,255,255,.15)}.search-container{padding:10px 20px;background:#fff;position:relative;flex-shrink:0}.search-box{display:flex;align-items:center;background:#f5f5f5;border-radius:8px;padding:8px 12px;border:1px solid #eee}.search-box:focus-within{border-color:#ffd04b;background:#fff}.search-input{border:none;background:0 0;flex:1;margin-left:10px;outline:0;font-size:16px}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;box-shadow:0 4px 10px rgba(0,0,0,.1);z-index:1000;max-height:300px;overflow-y:auto;display:none}.search-suggestions.show{display:block}.suggestion-item{padding:12px 20px;border-bottom:1px solid #eee;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.suggestion-item:hover{background:#f9f9f9}.suggestion-left{display:flex;flex-direction:column}.suggestion-name{font-size:14px;color:#333}.suggestion-code{font-size:12px;color:#999;margin-top:2px}#view-watch .fund-name{white-space:normal;word-break:break-all;line-height:1.4;max-width:100%}#view-watch .fund-info{flex:1.2;margin-right:10px;min-width:0}#view-watch .fund-code{font-size:12px;color:#999;display:flex;flex-direction:column;gap:2px;margin-top:4px}.fund-modal{position:fixed;bottom:0;left:50%;width:100%;max-width:600px;background:#fff;border-top-left-radius:20px;border-top-right-radius:20px;padding:25px 20px 30px;box-shadow:0 -10px 40px rgba(0,0,0,.1);transform:translateX(-50%) translateY(100%);transition:transform .3s cubic-bezier(.25, 1, .5, 1);z-index:1100}.fund-modal.show{transform:translateX(-50%) translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.modal-title-group{flex:1}.modal-fund-name{font-size:16px;font-weight:700;margin-bottom:2px;color:#333}.modal-fund-code{font-size:12px;color:#999;font-family:monospace}.modal-close{padding:5px;cursor:pointer;opacity:.5}.modal-close:hover{opacity:1}.modal-hero{text-align:center;padding:15px 0 25px;border-bottom:1px solid #f5f5f5;margin-bottom:20px}.modal-hero-label{font-size:12px;color:#888;margin-bottom:5px}.modal-hero-value{font-size:36px;font-weight:700;line-height:1.2;letter-spacing:-1px}.modal-hero-time{font-size:12px;color:#ccc;margin-top:5px}.modal-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:25px;text-align:center}.modal-grid-item{background:#f8f9fa;border-radius:12px;padding:12px 5px}.modal-info-label{font-size:11px;color:#999;margin-bottom:4px}.modal-info-value{font-size:15px;font-weight:600;color:#333}.btn-block{display:block;width:100%;padding:14px;background:linear-gradient(to right,#4caf50,#45a049);color:#fff;border:none;border-radius:30px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 15px rgba(76,175,80,.3);transition:transform .1s}.btn-block:active{transform:scale(.98);opacity:.9}.empty-state{padding:40px 20px;text-align:center;color:#999;font-size:14px}@media (max-width:414px){.search-container{padding:8px 12px}.search-input{font-size:14px}.suggestion-item{padding:10px 12px}.suggestion-name{font-size:13px}.suggestion-code{font-size:11px}.modal-hero-value{font-size:28px}.modal-fund-name{font-size:14px}.modal-info-label{font-size:10px}.modal-info-value{font-size:13px}.fund-modal{padding:20px 15px 25px}.btn-block{font-size:14px;padding:12px}}@media (max-width:360px){.search-container{padding:6px 10px}.search-input{font-size:13px;margin-left:6px}.search-box{padding:6px 10px}.suggestion-item{padding:8px 10px}.suggestion-name{font-size:12px}.suggestion-code{font-size:10px}.modal-hero-value{font-size:24px}.modal-hero{padding:10px 0 18px}.modal-fund-name{font-size:13px}.modal-info-label{font-size:9px}.modal-info-value{font-size:12px}.modal-grid{gap:6px;margin-bottom:18px}.modal-grid-item{padding:8px 4px;border-radius:8px}.fund-modal{padding:15px 12px 20px}.btn-block{font-size:13px;padding:10px}}.detail-view{background-color:#f5f5f5}.detail-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:70px}body.page-detail .header{background:#fff;padding:15px;border-bottom:1px solid #eee;display:flex;align-items:center;position:sticky;top:0;z-index:100;flex-shrink:0}.back-btn{font-size:24px;text-decoration:none;color:#333;margin-right:15px;width:30px}.title{font-size:18px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.main-card{background:#fff;padding:20px;margin-bottom:10px}body.page-detail .fund-code{color:#999;font-size:14px;margin-bottom:5px}.val-section{display:flex;align-items:baseline;justify-content:space-between;margin-top:10px}.big-val{font-size:36px;font-weight:700}.val-label{color:#999;font-size:12px}.growth-tag{padding:4px 8px;border-radius:4px;font-size:14px;font-weight:700}.chart-container{background:#fff;padding:15px;margin-top:10px;border-top:1px solid #eee;border-bottom:1px solid #eee}.chart-title{font-size:14px;font-weight:700;margin-bottom:10px;padding-left:5px;border-left:3px solid #fcaa00}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:20px}.info-item{background:#f9f9f9;padding:10px;border-radius:6px}.info-label{color:#999;font-size:12px;margin-bottom:4px}.info-val{font-size:16px;font-weight:500}.bg-red{background:#fde2e2;color:#d9363e}.bg-green{background:#e2fdf0;color:#2ecc71}.footer-note{text-align:center;color:#ccc;font-size:12px;padding:20px}.chart-tab-container{display:flex;justify-content:space-between;padding:0 15px 10px}.chart-tab{font-size:12px;color:#666;padding:6px 14px;cursor:pointer;border-radius:16px;background:#f5f5f5;transition:.2s}.chart-tab:hover{background:#eee}.chart-tab.active{color:#d9363e;background:#fff1f0;font-weight:700}.view-switch{display:flex;background:#f0f0f0;border-radius:16px;padding:2px;margin-left:auto}.view-btn{padding:4px 12px;font-size:12px;border-radius:14px;cursor:pointer;color:#666;transition:.2s}.view-btn.active{background:#fff;color:#333;font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.1)}.history-table-container{width:100%;overflow-x:auto;display:none;overflow-y:auto}.history-table{width:100%;border-collapse:collapse;font-size:13px}.history-table th{text-align:right;padding:10px 5px;color:#999;font-weight:400;position:sticky;top:0;background:#fff;border-bottom:1px solid #eee}.history-table th:first-child{text-align:left}.history-table td{text-align:right;padding:12px 5px;border-bottom:1px solid #f9f9f9;color:#333}.history-table td:first-child{text-align:left;font-weight:700}.history-table td.c-red{color:#e74c3c}.history-table td.c-green{color:#2ecc71}.history-table td.c-gray{color:#999}.holdings-container{display:none;padding:0;overflow-y:auto}.holdings-header{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#999}.holdings-header .quarter-label{font-weight:700;color:#666}.holdings-header .total-pct{color:#f39c12;font-weight:700}.stock-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5}.stock-row:last-child{border-bottom:none}.stock-index{width:22px;font-size:11px;color:#bbb;text-align:center;flex-shrink:0}.stock-index.top3{color:#f39c12;font-weight:700}.stock-info{flex:1;min-width:0;padding:0 8px}.stock-name{font-size:14px;color:#333;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stock-tag{display:inline-block;font-size:10px;color:#fff;background:#a0d2db;padding:0 4px;border-radius:3px;margin-top:2px}.stock-change{width:80px;text-align:right;font-size:14px;font-weight:500;flex-shrink:0}.holdings-col-header{display:flex;align-items:center;padding:8px 0 4px;font-size:11px;color:#bbb}.holdings-col-header .col-name{flex:1;padding-left:30px}.holdings-col-header .col-change{width:80px;text-align:right}.holdings-empty{text-align:center;padding:40px 0;color:#ccc;font-size:14px}.bottom-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;padding:10px 15px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -2px 10px rgba(0,0,0,.05);z-index:1000;max-width:600px;margin:0 auto;height:60px}.bottom-left{display:flex;align-items:center;color:#666;font-size:12px;cursor:pointer;padding:5px;flex-shrink:0;margin-right:10px}.bottom-left svg{width:24px;height:24px;margin-right:5px;fill:#ccc;transition:fill .3s}.bottom-left.active svg{fill:#f39c12;stroke:#f39c12}.bottom-right{display:flex;gap:6px;flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-right:5px}.bottom-right::-webkit-scrollbar{display:none}.bottom-right>:first-child{margin-left:auto}body.page-detail .btn{padding:8px 14px;border-radius:20px;border:none;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0}body.page-detail .btn-primary{background:#ffbd20;color:#333;box-shadow:0 2px 5px rgba(255,189,32,.3);font-weight:700}body.page-detail .btn-outline{background:#fff;border:1px solid #ddd;color:#333}body.page-detail .btn-danger{background:#fff;color:#e74c3c;border:1px solid #fdd}body.page-detail .btn-danger-fill{background:#ffebee;color:#d32f2f}body.page-detail .btn-sip{background:#9b59b6;color:#fff;border:none;font-weight:700;position:relative}body.page-detail .btn-sip.sip-active{background:#8e44ad}body.page-detail .btn-sip .sip-dot{display:inline-block;width:6px;height:6px;background:#e8ff6b;border-radius:50%;margin-left:4px;vertical-align:middle;animation:1.5s ease-in-out infinite sipPulse}@keyframes sipPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}.sip-freq-switch{display:flex;border:1px solid #9b59b6;border-radius:6px;overflow:hidden}.sip-freq-opt{flex:1;text-align:center;padding:8px;font-size:14px;cursor:pointer;color:#9b59b6;background:#fff;transition:.2s}.sip-freq-opt.active{background:#9b59b6;color:#fff}.records-container{background:#fff}.record-item{display:flex;align-items:center;padding:12px 15px;border-bottom:1px solid #f5f5f5;gap:10px}.record-type-tag{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:700;color:#fff;white-space:nowrap;min-width:40px;text-align:center}.record-type-tag.type-init,.record-type-tag.type-rebase{background:#faad14}.record-type-tag.type-buy{background:#3498db}.record-type-tag.type-sell{background:#2ecc71}.record-type-tag.type-dip{background:#9b59b6}.record-date{flex:1;font-size:13px;color:#666;text-align:center}.record-amount{font-size:14px;font-weight:700;min-width:80px;text-align:right}.record-amount.type-init,.record-amount.type-rebase{color:#faad14}.record-amount.type-buy{color:#3498db}.record-amount.type-sell{color:#2ecc71}.record-amount.type-dip{color:#9b59b6}.record-edit-btn{background:0 0;border:1px solid #ddd;border-radius:4px;font-size:12px;color:#666;padding:3px 8px;cursor:pointer;white-space:nowrap}.record-edit-btn:active{background:#f5f5f5}.records-empty{text-align:center;padding:40px 0;color:#ccc;font-size:14px}body.page-detail .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:2000;display:none;align-items:center;justify-content:center}body.page-detail .modal-card{background:#fff;width:85%;max-width:320px;border-radius:12px;padding:20px;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:.3s cubic-bezier(.18,.89,.32,1.28) modalPop}body.page-detail .modal-title{font-size:18px;font-weight:700;margin-bottom:20px;text-align:center}body.page-detail .form-group{margin-bottom:15px}body.page-detail .form-label{display:block;font-size:14px;color:#666;margin-bottom:5px}body.page-detail .form-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:16px;outline:0}body.page-detail .form-input:focus{border-color:#ffbd20}body.page-detail .modal-btns{display:flex;gap:10px;margin-top:20px}body.page-detail .modal-btn{flex:1;padding:10px;border-radius:6px;border:none;font-size:16px;cursor:pointer}body.page-detail .modal-confirm{background:#ffbd20;color:#333;font-weight:700}body.page-detail .modal-cancel{background:#f5f5f5;color:#666}body.page-detail{overflow:hidden}@media (max-width:414px){body.page-detail .header{padding:12px}.back-btn{font-size:20px;margin-right:10px}.title{font-size:16px}.main-card{padding:15px}body.page-detail .fund-code{font-size:12px}.big-val{font-size:30px}.growth-tag{font-size:12px;padding:3px 6px}.info-grid{gap:10px;margin-top:15px}.info-item{padding:8px}.info-label{font-size:11px}.info-val{font-size:14px}.chart-tab{font-size:11px;padding:5px 10px}.history-table{font-size:12px}.history-table td{padding:10px 4px}.history-table th{padding:8px 4px}body.page-detail .btn{font-size:13px;padding:6px 12px}.bottom-bar{padding:8px 10px;height:54px}.stock-name{font-size:13px}.stock-change{font-size:13px;width:70px}.holdings-col-header{font-size:10px}}@media (max-width:360px){body.page-detail .header{padding:10px}.back-btn{font-size:18px;margin-right:8px;width:24px}.title{font-size:14px}.main-card{padding:12px}body.page-detail .fund-code{font-size:11px}.big-val{font-size:26px}.val-label{font-size:10px}.growth-tag{font-size:11px;padding:2px 5px}.info-grid{gap:8px;margin-top:12px}.info-item{padding:6px}.info-label{font-size:10px}.info-val{font-size:13px}.chart-tab-container{padding:0 10px 8px}.chart-tab{font-size:10px;padding:4px 8px}.view-btn{font-size:10px;padding:3px 8px}.history-table{font-size:11px}.history-table td{padding:8px 3px}.history-table th{padding:6px 3px;font-size:10px}body.page-detail .btn{font-size:12px;padding:5px 8px}.bottom-bar{padding:6px;height:48px}.bottom-right{gap:4px}.bottom-left{font-size:11px;margin-right:5px}.bottom-left svg{width:20px;height:20px;margin-right:2px}.stock-name{font-size:12px}.stock-change{font-size:12px;width:65px}.stock-row{padding:8px 0}.holdings-col-header{font-size:9px}.holdings-col-header .col-change{width:65px}body.page-detail .modal-title{font-size:16px}body.page-detail .form-label{font-size:12px}body.page-detail .form-input{font-size:14px;padding:8px}body.page-detail .modal-btn{font-size:14px}}.holdings-container{font-size:13px}.holdings-header{padding:10px 5px;display:flex;align-items:baseline;border-bottom:2px solid #fff;justify-content:space-between}.holdings-subtitle{font-size:12px;color:#888}.holdings-date{font-size:12px;color:#888;text-align:right}.holdings-table-header{display:flex;padding:8px 20px;font-size:12px;color:#888;border-bottom:1px solid #eee;background:#fff}.h-col{flex:1;text-align:right}.h-name-col{flex:1.5;text-align:left}.h-prev-col{flex:1.3}.holdings-stock-list{display:flex;flex-direction:column;padding:12px 10px;gap:12px;background:#fdfdfd}.h-stock-item{display:flex;padding:14px 10px;align-items:center;background:#fff;border-radius:8px;box-shadow:0 4px 10px rgba(0,0,0,.06);border:1px solid #f0f0f0;transition:transform .2s,box-shadow .2s}.h-stock-item.h-bg-up{background-color:#fffaf7;border-color:#fee1d7;box-shadow:0 4px 10px rgba(244,62,63,.08)}.h-stock-item.h-bg-down{background-color:#f7fdf9;border-color:#d1ebd8;box-shadow:0 4px 10px rgba(40,167,69,.08)}.h-stock-name-box{display:flex;flex-direction:column;align-items:flex-start}.h-stock-name{font-size:14px;color:#333;margin-bottom:4px}.h-stock-industry{font-size:10px;color:#888;border:1px solid #ddd;padding:0 3px;border-radius:2px;line-height:1.3}.h-item-change{font-size:14px;font-weight:500}.h-item-ratio{font-size:13px;color:#666}.h-item-prev{font-size:13px}.h-text-up{color:#f43e3f}.h-text-down{color:#28a745}.h-text-gray{color:#888}