.tab-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #f0f0f0;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.tab-bar-inner{display:flex;height:50px}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;color:#999;transition:color .2s;min-width:0}.tab-item.active{color:#1890ff}.tab-icon{width:20px;height:20px;flex-shrink:0}.tab-label{font-size:11px;line-height:1;white-space:nowrap}.login-required-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:24px}.login-required-content{text-align:center;max-width:320px}.login-required-icon{font-size:64px;margin-bottom:16px}.login-required-title{font-size:20px;font-weight:600;color:#333;margin:0 0 12px}.login-required-desc{font-size:14px;color:#666;line-height:1.6;margin:0 0 24px}.login-required-hint{font-size:13px;color:#999;margin:0 0 16px}.login-required-btn{width:100%;padding:12px 24px;border:none;border-radius:24px;background:#07c160;color:#fff;font-size:16px;font-weight:600;cursor:pointer}.login-required-btn:disabled{background:#ccc;cursor:not-allowed}.live-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.live-page-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0 0 20px}.live-group{margin-bottom:24px}.live-group:last-child{margin-bottom:0}.live-group-title{font-size:16px;font-weight:600;color:#333;margin:0 0 12px}.live-group-list{display:flex;flex-direction:column;gap:16px}.live-card{display:block;text-decoration:none;color:inherit;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000d;transition:box-shadow .2s}.live-card:active{box-shadow:0 2px 8px #0000001f}.live-cover-wrap{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;margin:8px 8px 0;width:calc(100% - 16px)}.live-cover{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.live-cover-placeholder{width:100%;height:100%;background:#f0f0f0}.live-status-badge{position:absolute;top:8px;left:8px;padding:3px 10px;border-radius:9999px;font-size:12px;font-weight:500;color:#fff;line-height:1.4}.status-live{background:#ff4d4f}.status-scheduled{background:#fa8c16}.status-playback{background:#8c8c8c}.status-offline{background:#bfbfbf}.live-viewer-count{position:absolute;top:8px;right:8px;padding:3px 10px;border-radius:9999px;font-size:12px;font-weight:500;color:#fff;background:#0009;line-height:1.4}.live-card-body{padding:12px}.live-card-title{font-size:18px;font-weight:600;color:#1a1a1a;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-status-row{display:flex;align-items:center;gap:4px;font-size:14px;color:#8c8c8c;margin-bottom:6px;line-height:1.4}.live-status-row svg{flex-shrink:0}.live-card-desc{font-size:14px;color:#666;margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.live-loading,.live-empty,.live-error{text-align:center;padding:60px 20px;color:#999;font-size:14px}.live-error{color:#ff4d4f}.live-player-container{position:relative;width:100%;background:#000;aspect-ratio:16 / 9}.tcplayer-wrapper{width:100%;height:100%}.live-player-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;z-index:10;display:flex;flex-direction:column;align-items:center;gap:12px}.loading-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.live-player-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ff4d4f;font-size:14px;z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px}.error-icon{font-size:32px}.live-player-network{position:absolute;top:20px;right:20px;background:#0009;color:#fff;font-size:12px;padding:6px 12px;border-radius:4px;z-index:20;display:flex;align-items:center;gap:6px}.network-indicator{width:8px;height:8px;background:#ff4d4f;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.live-badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,#ff4d4f,#ff7875);color:#fff;font-size:12px;padding:4px 10px;border-radius:4px;z-index:20;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #0000004d}.live-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:live-pulse 1.5s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.live-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.live-video.live-mode::-webkit-media-controls-timeline{display:none!important}.live-video.live-mode::-webkit-media-controls-current-time-display{display:none!important}.live-video.live-mode::-webkit-media-controls-time-remaining-display{display:none!important}.live-video.live-mode::-webkit-media-controls-play-button{display:none!important}.live-player-mute-btn{position:absolute;top:10px;right:10px;z-index:20;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer}.live-player-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border:none;background:#0006;color:#fff;cursor:pointer}.play-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.play-hint{font-size:14px;font-weight:500;color:#ffffffe6}.danmaku-container{display:flex;flex-direction:column;gap:10px;background:transparent}.danmaku-list{max-height:176px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding-right:4px;scrollbar-width:none}.danmaku-list::-webkit-scrollbar{display:none}.danmaku-item{width:-moz-fit-content;width:fit-content;max-width:100%;padding:5px 9px;border-radius:12px;background:#00000057;color:#fff;font-size:13px;line-height:18px;word-break:break-all;text-shadow:0 1px 4px rgba(0,0,0,.45);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.danmaku-nickname{color:#fff;font-weight:700}.danmaku-input-bar{display:flex;gap:6px;align-items:center}.danmaku-input-bar input{min-width:0;flex:1;height:38px;border:none;border-radius:19px;padding:0 14px;background:#0000006b;color:#fff;font-size:14px;outline:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.danmaku-input-bar input::-moz-placeholder{color:#ffffffad}.danmaku-input-bar input::placeholder{color:#ffffffad}.danmaku-input-bar button{flex:0 0 auto;height:38px;min-width:58px;padding:0 14px;border:none;border-radius:19px;background:#ff2f4f;color:#fff;font-size:14px;font-weight:700;cursor:pointer}.danmaku-input-bar button:disabled{background:#ffffff3d;color:#ffffffa3;cursor:not-allowed}.watermark-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:100;overflow:hidden}.watermark-item{position:absolute;font-size:14px;color:#ffffffb3;text-shadow:1px 1px 2px rgba(0,0,0,.5);white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.goods-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:flex-end;background:#00000073}.goods-drawer{position:relative;width:100%;max-height:86vh;display:flex;flex-direction:column;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -10px 30px #0f172a2e;overflow:hidden}.goods-drawer-handle{width:42px;height:4px;margin:10px auto 6px;border-radius:999px;background:#d9d9d9}.goods-drawer-close{position:absolute;top:8px;right:12px;width:32px;height:32px;border:none;border-radius:50%;background:#f5f5f5;color:#666;font-size:22px;line-height:30px;cursor:pointer}.goods-drawer-header{display:flex;gap:12px;padding:10px 16px 14px;border-bottom:1px solid #f1f1f1}.goods-drawer-cover{width:96px;height:96px;border-radius:8px;-o-object-fit:cover;object-fit:cover;flex-shrink:0;background:#f5f5f5}.goods-drawer-summary{min-width:0;flex:1;padding-right:28px}.goods-drawer-type{display:inline-flex;align-items:center;height:20px;padding:0 8px;margin-bottom:6px;border-radius:10px;background:#fff1f0;color:#f5222d;font-size:12px}.goods-drawer-title{margin:0 0 8px;color:#222;font-size:18px;line-height:1.35;font-weight:700;word-break:break-word}.goods-drawer-price-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.goods-drawer-price{color:#ff4d4f;font-size:20px;font-weight:700}.goods-drawer-original{color:#999;font-size:13px;text-decoration:line-through}.goods-drawer-content{flex:1;min-height:120px;padding:14px 16px 92px;overflow-y:auto;color:#333;font-size:14px;line-height:1.7}.goods-drawer-description{margin:0;color:#555;white-space:pre-wrap}.goods-drawer-rich :where(p,ul,ol,blockquote,table){margin:0 0 12px}.goods-drawer-rich :where(ul,ol){padding-left:20px}.goods-drawer-rich img{display:block;max-width:100%;height:auto;margin:10px 0;border-radius:8px}.goods-drawer-rich a{color:#1677ff;text-decoration:none;word-break:break-all}.goods-drawer-footer{position:absolute;left:0;right:0;bottom:0;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #f1f1f1}.goods-drawer-buy{width:100%;height:44px;border:none;border-radius:22px;background:#ff4d4f;color:#fff;font-size:16px;font-weight:600;cursor:pointer}.goods-drawer-buy:disabled{background:#d9d9d9;color:#fff;cursor:not-allowed}.live-goods-list-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:flex-end;background:#0000007a}.live-goods-list-drawer{width:100%;max-height:78vh;display:flex;flex-direction:column;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -12px 32px #0f172a33;overflow:hidden}.live-goods-list-handle{width:40px;height:4px;margin:10px auto 4px;border-radius:999px;background:#d9d9d9}.live-goods-list-header{min-height:48px;display:flex;align-items:center;justify-content:center;position:relative;padding:0 56px;border-bottom:1px solid #f1f1f1}.live-goods-list-title{margin:0;color:#222;font-size:17px;line-height:24px;font-weight:700}.live-goods-list-close{position:absolute;right:12px;top:8px;width:32px;height:32px;border:none;border-radius:50%;background:#f5f5f5;color:#666;font-size:22px;line-height:30px;cursor:pointer}.live-goods-list-content{flex:1;min-height:168px;overflow-y:auto;padding:12px 12px calc(12px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}.live-goods-list-empty{min-height:132px;display:flex;align-items:center;justify-content:center;color:#999;font-size:14px}.live-goods-list-items{display:flex;flex-direction:column;gap:10px}.live-goods-list-item{width:100%;min-height:82px;display:flex;align-items:center;gap:10px;padding:10px;border:none;border-radius:8px;background:#f9f9f9;text-align:left;cursor:pointer}.live-goods-list-cover,.live-goods-list-cover-placeholder{width:62px;height:62px;flex:0 0 62px;border-radius:8px;-o-object-fit:cover;object-fit:cover;background:#eee}.live-goods-list-cover-placeholder{position:relative}.live-goods-list-cover-placeholder:after{content:"";position:absolute;top:18px;right:18px;bottom:18px;left:18px;border-radius:6px;border:2px solid #d1d1d1}.live-goods-list-info{min-width:0;flex:1;display:flex;flex-direction:column;gap:8px}.live-goods-list-name-row{min-width:0;display:flex;align-items:center;gap:6px}.live-goods-list-type{flex-shrink:0;height:18px;padding:0 6px;border-radius:9px;background:#fff1f0;color:#f5222d;font-size:11px;line-height:18px}.live-goods-list-name{min-width:0;color:#222;font-size:14px;line-height:20px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-goods-list-price-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.live-goods-list-price{color:#ff4d4f;font-size:17px;line-height:22px;font-weight:700}.live-goods-list-original{color:#999;font-size:12px;line-height:18px;text-decoration:line-through}.live-goods-list-action{flex-shrink:0;min-width:44px;height:28px;padding:0 12px;border-radius:14px;background:#ff4d4f;color:#fff;font-size:13px;line-height:28px;text-align:center}@media (min-width: 768px){.live-goods-list-drawer{max-width:480px;margin:0 auto;border-radius:16px 16px 0 0}}.share-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#0000006b;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;pointer-events:auto;flex-shrink:0}.share-button:active{opacity:.7}.live-room-page{min-height:100vh;background:#000;color:#fff;overflow:hidden}.live-room-page--immersive,.live-room-page--dark{height:100vh;height:100dvh}.live-room-stage,.live-room-offline-screen{position:relative;width:100%;height:100%;min-height:100vh;min-height:100dvh;background:#000;overflow:hidden}.live-room-offline-screen{display:flex;flex-direction:column;align-items:center;position:relative}.live-room-back-btn{position:absolute;top:calc(12px + env(safe-area-inset-top));left:12px;z-index:10;height:36px;padding:0 14px;border:none;border-radius:18px;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:14px;cursor:pointer}.live-room-share-wrap{position:absolute;top:calc(12px + env(safe-area-inset-top));right:12px;z-index:10}.live-room-offline-cover{width:100%;height:45vh;-o-object-fit:cover;object-fit:cover;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.live-room-offline-cover--placeholder{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}.live-room-offline-body{display:flex;flex-direction:column;align-items:center;gap:12px;padding:0 24px 40px;margin-top:-60px;text-align:center}.live-room-offline-badge{height:24px;padding:0 12px;border-radius:12px;font-size:12px;font-weight:600;line-height:24px}.live-room-offline-badge--offline{background:#66666640;color:#999}.live-room-offline-badge--scheduled{background:#ff950033;color:#ff9500}.live-room-offline-badge--playback{background:#007aff33;color:#5cadff}.live-room-offline-title{margin:0;color:#fff;font-size:20px;font-weight:700;line-height:1.4}.live-room-offline-desc{display:-webkit-box;max-width:100%;margin:0;overflow:hidden;color:#ffffff8c;font-size:14px;line-height:1.6;-webkit-box-orient:vertical;-webkit-line-clamp:3}.live-room-offline-mentor{display:flex;align-items:center;gap:10px;margin-top:4px}.live-room-offline-mentor .live-room-avatar{width:44px;height:44px;flex:0 0 44px}.live-room-offline-mentor-name{color:#fff;font-size:15px;font-weight:600;text-align:left}.live-room-offline-mentor-title{color:#ffffff73;font-size:13px;text-align:left}.live-room-offline-schedule{display:flex;align-items:center;gap:6px;margin-top:8px;color:#ff9500;font-size:14px;font-weight:500}.live-room-offline-schedule:before{content:"";width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ff9500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E");background-size:contain}.live-room-player-layer,.live-room-player-layer .live-player-container{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;aspect-ratio:auto}.live-room-player-layer .live-video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.live-room-player-layer .live-badge{display:none}.live-room-signal-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#000;color:#fff}.live-room-signal-title{font-size:17px;font-weight:600}.live-room-pay-button{height:42px;padding:0 28px;border:none;border-radius:21px;background:#ff2f4f;color:#fff;font-size:15px;font-weight:700}.live-room-top-overlay{position:absolute;top:calc(12px + env(safe-area-inset-top));left:12px;right:12px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;pointer-events:none}.live-room-host{min-width:0;max-width:min(72vw,360px);height:44px;display:flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;border-radius:22px;background:#0000006b;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.live-room-avatar{width:34px;height:34px;flex:0 0 34px;border-radius:50%;overflow:hidden;background:#ff2f4f;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700}.live-room-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.live-room-host-text{min-width:0}.live-room-host-name{max-width:100%;overflow:hidden;color:#fff;font-size:13px;line-height:17px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.live-room-host-meta{display:flex;align-items:center;gap:3px;color:#ffffffc7;font-size:11px;line-height:14px;white-space:nowrap}.live-room-live-badge{flex:0 0 auto;height:26px;padding:0 10px;border-radius:13px;background:#ff2f4f;color:#fff;font-size:12px;line-height:26px;font-weight:700}.live-room-right-rail{position:absolute;right:10px;bottom:calc(28px + env(safe-area-inset-bottom));z-index:30;display:flex;flex-direction:column;align-items:center;gap:16px}.live-room-rail-button{position:relative;width:auto;min-width:58px;height:38px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;padding:0 10px;border:none;border-radius:19px;background:#0000006b;color:#fff;font-size:12px;font-weight:700;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.live-room-rail-button em{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ff2f4f;color:#fff;font-size:11px;line-height:18px;font-style:normal}.live-room-danmaku-overlay{position:absolute;left:8px;right:96px;bottom:calc(28px + env(safe-area-inset-bottom));z-index:25;pointer-events:auto}.live-room-bottom-overlay{position:absolute;left:12px;right:104px;bottom:calc(28px + env(safe-area-inset-bottom));z-index:24;pointer-events:none}.live-room-title{margin:0;color:#fff;font-size:16px;line-height:22px;font-weight:800;text-shadow:0 1px 8px rgba(0,0,0,.5)}.live-room-description{display:-webkit-box;max-height:40px;margin:6px 0 0;overflow:hidden;color:#ffffffdb;font-size:13px;line-height:20px;text-shadow:0 1px 8px rgba(0,0,0,.5);-webkit-box-orient:vertical;-webkit-line-clamp:2}.live-room-loading,.live-room-error{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#000;color:#ffffffe0;font-size:16px;text-align:center}@media (min-width: 768px){.live-room-page--immersive,.live-room-page--dark{max-width:480px;margin:0 auto}}.live-room-featuring-card{position:absolute;right:10px;bottom:calc(130px + env(safe-area-inset-bottom));z-index:28;display:flex;align-items:center;gap:8px;padding:6px 10px 6px 6px;border-radius:12px;background:#0000008c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:opacity .3s ease,transform .3s ease;max-width:180px}.live-room-featuring-card:active{transform:scale(.95)}.live-room-featuring-img{width:40px;height:40px;border-radius:6px;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.live-room-featuring-info{display:flex;flex-direction:column;gap:2px;min-width:0}.live-room-featuring-name{font-size:12px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:110px}.live-room-featuring-price{font-size:11px;color:#ff9500;font-weight:700}.live-room-announcement{padding:6px 10px;margin-bottom:6px;border-radius:8px;background:linear-gradient(90deg,#ff9500,#ff6b35);color:#fff;font-size:12px;line-height:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pay-page{min-height:100vh;background:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.pay-card{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:360px;text-align:center}.pay-title{font-size:20px;font-weight:700;margin-bottom:20px}.pay-info{margin-bottom:24px}.pay-title-text{font-size:16px;color:#333;margin-bottom:8px}.pay-amount{font-size:32px;font-weight:700;color:#ff4d4f}.pay-btn{width:100%;height:48px;background:#07c160;color:#fff;border:none;border-radius:24px;font-size:16px;cursor:pointer;margin-bottom:12px}.pay-btn:disabled{background:#ccc}.pay-cancel-btn{width:100%;height:48px;background:#f5f5f5;color:#666;border:none;border-radius:24px;font-size:16px;cursor:pointer}.order-list-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));min-height:100vh;background:#f5f5f5}.page-title{font-size:20px;font-weight:700;margin-bottom:16px}.empty-text{text-align:center;color:#999;padding:40px 0}.order-list{display:flex;flex-direction:column;gap:12px}.order-card{background:#fff;border-radius:12px;padding:12px}.order-header{display:flex;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid #f0f0f0;font-size:13px}.order-status{font-weight:700}.status-unpaid{color:#faad14}.status-paid{color:#07c160}.status-refunded,.status-expired{color:#999}.order-body{padding-top:8px}.order-title{font-size:15px;font-weight:500;margin-bottom:6px}.order-footer{display:flex;justify-content:space-between;font-size:13px;color:#999}.order-amount{color:#333;font-weight:700}.order-time{display:block;font-size:12px;color:#ccc;margin-top:4px}.profile-page{min-height:100vh;background:#f5f5f5;padding-bottom:72px}.profile-empty{padding:60px 20px;text-align:center;color:#999}.profile-header{display:flex;align-items:center;gap:16px;padding:24px 16px;background:linear-gradient(135deg,#1890ff,#096dd9);color:#fff}.profile-avatar{width:56px;height:56px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:28px}.profile-name{margin:0;font-size:18px}.profile-id{margin:4px 0 0;font-size:12px;opacity:.8}.profile-menu{margin:16px;background:#fff;border-radius:8px;overflow:hidden}.menu-item{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid #f5f5f5;cursor:pointer}.menu-item:last-child{border-bottom:none}.menu-item:active{background:#fafafa}.menu-icon{font-size:20px;margin-right:12px}.menu-label{flex:1;font-size:15px}.menu-arrow{color:#ccc;font-size:18px}.logout-btn{margin:24px 16px;padding:12px;background:#fff;border:none;border-radius:8px;color:#ff4d4f;font-size:15px;cursor:pointer;width:calc(100% - 32px)}.course-list-page{padding:16px;min-height:100vh;background:#f5f5f5}.page-title{font-size:20px;font-weight:700;margin-bottom:12px}.course-filters{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto}.filter-btn{padding:6px 16px;border:1px solid #ddd;border-radius:16px;background:#fff;color:#666;font-size:13px;white-space:nowrap;cursor:pointer}.filter-btn.active{background:var(--color-success);color:#fff;border-color:var(--color-success)}.empty-text{text-align:center;color:var(--color-text-secondary);padding:40px 0}.course-list{display:flex;flex-direction:column;gap:16px}.course-card{display:block;background:#fff;border-radius:12px;overflow:hidden;text-decoration:none;color:#333;cursor:pointer}.course-list-cover-wrapper{position:relative;width:100%;height:200px;overflow:hidden;border-top-left-radius:12px;border-top-right-radius:12px;background:#f0f0f0}.course-list-cover{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.course-list-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px}.course-status-tag{position:absolute;top:8px;right:8px;padding:4px 10px;background:#52c41a;color:#fff;font-size:12px;border-radius:12px;font-weight:500}.course-info{padding:12px 16px 16px}.course-title{font-size:18px;font-weight:600;line-height:1.4;color:var(--color-text);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.price{color:#ff4d4f;font-size:18px;font-weight:600}.price.free{display:inline-block;padding:2px 8px;background:var(--color-success);color:#fff;border-radius:4px;font-size:12px;font-weight:500}.original-price{color:#999;font-size:14px;text-decoration:line-through}.course-description{font-size:14px;color:#666;line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.course-action{width:100%;padding:10px 0;background:#f5f5f5;border-radius:8px;text-align:center;font-size:14px;color:#666;font-weight:500}.course-detail-page{padding-bottom:calc(100px + env(safe-area-inset-bottom));min-height:100vh;background:#f5f5f5}.course-hero{width:100%;aspect-ratio:16/9;background:#000}.course-hero img{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover}.hero-placeholder{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:64px}.course-info-section{background:#fff;padding:16px;margin-bottom:8px}.course-title{font-size:20px;font-weight:700;margin-bottom:12px}.course-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--color-text-secondary);margin-bottom:8px}.teacher-info{display:flex;align-items:center;gap:8px}.teacher-avatar{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.teacher-name{font-weight:500;color:var(--color-text)}.teacher-title-text{color:var(--color-text-secondary);margin-left:4px}.course-stats{display:flex;gap:12px}.course-description{font-size:14px;color:#666;line-height:1.6;margin-top:12px}.episodes-section{background:#fff;padding:16px;margin-bottom:8px}.section-title{font-size:16px;font-weight:700;margin-bottom:12px}.episode-item{display:flex;flex-direction:column;padding:10px 0;border-bottom:1px solid #f0f0f0}.episode-item>.episode-row{display:flex;align-items:center;width:100%;gap:10px}.episode-item.playable{cursor:pointer}.episode-item.locked{opacity:.5;cursor:not-allowed}.episode-index{width:24px;height:24px;background:#f0f0f0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#666;flex-shrink:0}.episode-info{flex:1;display:flex;justify-content:space-between;font-size:14px}.episode-title{color:var(--color-text)}.episode-duration{color:var(--color-text-secondary)}.episode-status{font-size:12px;color:var(--color-success);flex-shrink:0}.price-current{color:var(--color-danger);font-weight:700;font-size:20px}.price-original{color:var(--color-text-secondary);text-decoration:line-through;font-size:13px;margin-left:8px}.course-buy-bar{position:fixed;bottom:calc(50px + env(safe-area-inset-bottom));left:0;right:0;display:flex;align-items:center;padding:8px 16px;background:#fff;border-top:1px solid #f0f0f0;z-index:50}.buy-price{display:flex;align-items:center;gap:6px}.buy-btn{margin-left:auto;padding:10px 32px;background:var(--color-primary, #1890ff);color:#fff;border:none;border-radius:20px;font-size:15px;cursor:pointer}.buy-btn:active{opacity:.9}.episode-progress-bar{height:4px;background:#e5e5e5;border-radius:2px;margin-top:4px;overflow:hidden}.episode-progress-fill{height:100%;background:var(--color-primary, #1890ff);border-radius:2px;transition:width .3s ease}.episode-status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;line-height:1}.episode-status-badge.completed{background:#e8f5e9;color:#2e7d32}.episode-status-badge.in-progress{background:#fff3e0;color:#e65100}.episode-progress-inline{display:flex;align-items:center}.course-player-page{min-height:100vh;background:#f5f5f5}.chapter-back-btn{position:absolute;top:12px;left:12px;z-index:10;width:36px;height:36px;border-radius:50%;background:#00000080;border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.player-wrapper{position:relative;width:100%;background:#000}.course-video{width:100%;max-height:70vh;-o-object-fit:contain;object-fit:contain;display:block}.video-info{background:#fff;padding:16px;margin-bottom:8px}.video-title{font-size:18px;font-weight:700;margin-bottom:4px}.video-course-name{font-size:14px;color:var(--color-text-secondary);margin-bottom:8px}.video-desc{font-size:14px;color:#666;line-height:1.5}.chapter-toggle{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 24px;border-radius:20px;cursor:pointer;z-index:140;display:flex;align-items:center;gap:8px;font-size:14px}.chapter-arrow{font-size:10px;transition:transform .2s}.chapter-arrow.up{transform:rotate(180deg)}.chapter-arrow.down{transform:rotate(0)}.chapter-drawer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:12px 12px 0 0;z-index:200;transition:transform .3s ease;max-height:60vh;display:flex;flex-direction:column}.chapter-drawer.collapsed{transform:translateY(calc(100% - 48px))}.chapter-drawer.expanded{transform:translateY(0)}.chapter-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;flex-shrink:0}.chapter-drawer-title{font-size:15px;font-weight:600}.chapter-drawer-toggle{font-size:13px;color:var(--color-primary)}.chapter-drawer-body{max-height:calc(60vh - 48px);overflow-y:auto;padding:8px 0}.chapter-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background .2s;gap:12px;text-decoration:none;color:var(--color-text);font-size:14px}.chapter-item.active{background:#e6f7ff;color:var(--color-primary)}.chapter-item:active{background:#f5f5f5}.chapter-index{width:24px;font-size:13px;color:#999;flex-shrink:0}.chapter-name{flex:1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-duration{font-size:12px;color:#999;flex-shrink:0}.progress-bar-wrapper{display:flex;align-items:center;gap:8px;padding:8px 16px}.progress-bar-track{flex:1;height:4px;background:#0000001a;border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:#1890ff;border-radius:2px;transition:width .3s ease}.progress-text{font-size:12px;color:#00000080;white-space:nowrap}.video-info-header{display:flex;align-items:center;justify-content:space-between}.speed-btn{background:#0000000d;border:1px solid rgba(0,0,0,.1);color:#333;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer}.speed-indicator{position:absolute;top:12px;right:12px;background:#0009;color:#fff;padding:4px 8px;border-radius:4px;font-size:14px;pointer-events:none}.chapter-status{font-size:11px;padding:2px 6px;border-radius:3px}.chapter-status.done{background:#52c41a26;color:#52c41a}.chapter-status.partial{color:#0006}.my-courses-page{min-height:100vh;background:#f5f5f5;padding-bottom:72px}.my-course-card{display:flex;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid #f5f5f5;cursor:pointer}.my-course-card:active{background:#fafafa}.course-cover{width:120px;height:68px;border-radius:4px;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.course-cover-placeholder{width:120px;height:68px;border-radius:4px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.course-info{flex:1;min-width:0}.course-title{margin:0 0 8px;font-size:14px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-meta{display:flex;gap:12px;font-size:12px;color:#999}.my-orders-page{min-height:100vh;background:#f5f5f5;padding-bottom:72px}.page-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid #f0f0f0}.page-header h2{margin:0;font-size:17px}.back-btn{font-size:20px;cursor:pointer;color:#333}.empty-state{padding:60px 20px;text-align:center;color:#999}.order-list{padding:12px 16px}.order-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:12px}.order-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:13px}.order-type{color:#666}.order-status{font-weight:500}.status-paid{color:#52c41a}.status-pending{color:#faad14}.status-refunded{color:#ff4d4f}.status-cancelled{color:#999}.order-body{display:flex;justify-content:space-between;align-items:center}.order-title{font-size:15px;flex:1;margin-right:12px}.order-amount{font-size:16px;font-weight:600;color:#333}.order-time{margin-top:8px;font-size:12px;color:#ccc}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 210 100% 50%;--primary-foreground: 0 0% 100%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 210 100% 50%;--radius: .5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.fixed{position:fixed}.absolute{position:absolute}.inset-0{top:0;right:0;bottom:0;left:0}.left-\[50\%\]{left:50%}.right-4{right:1rem}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-50{z-index:50}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-4{height:1rem}.h-9{height:2.25rem}.w-10{width:2.5rem}.w-4{width:1rem}.w-full{width:100%}.max-w-lg{max-width:32rem}.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.border{border-width:1px}.border-transparent{border-color:transparent}.bg-black\/80{background-color:#000c}.p-6{padding:1.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pt-0{padding-top:0}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.duration-200{animation-duration:.2s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333}#root{min-height:100vh}.tab-content{padding-bottom:56px;min-height:100vh}.loading-page{padding:40px 20px;text-align:center;color:#999}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y: -48%}@media (min-width: 640px){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:.5rem}.sm\:text-left{text-align:left}}@media (min-width: 768px){.md\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}
