:root{--swiper-theme-color:#007aff}:host{z-index:1;margin-left:auto;margin-right:auto;display:block;position:relative}.swiper{z-index:1;margin-left:auto;margin-right:auto;padding:0;list-style:none;display:block;position:relative;overflow:hidden}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{z-index:1;width:100%;height:100%;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function,initial);box-sizing:content-box;display:flex;position:relative}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translate(0,0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;transition-property:transform;display:block;position:relative}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{backface-visibility:hidden;transform:translateZ(0)}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{scrollbar-width:none;-ms-overflow-style:none;overflow:auto}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-slides-offset-before);scroll-margin-inline-start:var(--swiper-slides-offset-before)}.swiper-css-mode.swiper-horizontal>.swiper-wrapper>.swiper-slide:last-child{margin-inline-end:var(--swiper-slides-offset-after)}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-slides-offset-before);scroll-margin-block-start:var(--swiper-slides-offset-before)}.swiper-css-mode.swiper-vertical>.swiper-wrapper>.swiper-slide:last-child{margin-block-end:var(--swiper-slides-offset-after)}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(270deg,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(90deg,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(#0000,#00000080)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(#00000080,#0000)}.swiper-lazy-preloader{z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color,var(--swiper-theme-color));border-top-color:#0000;border-radius:50%;width:42px;height:42px;margin-top:-21px;margin-left:-21px;position:absolute;top:50%;left:50%}:is(.swiper:not(.swiper-watch-progress),.swiper-watch-progress .swiper-slide-visible) .swiper-lazy-preloader{animation:1s linear infinite swiper-preloader-spin}.swiper-lazy-preloader-white{--swiper-preloader-color:#fff}.swiper-lazy-preloader-black{--swiper-preloader-color:#000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--swiper-navigation-size:44px}.swiper-button-prev,.swiper-button-next{width:var(--swiper-navigation-size);height:var(--swiper-navigation-size);z-index:10;cursor:pointer;color:var(--swiper-navigation-color,var(--swiper-theme-color));justify-content:center;align-items:center;display:flex;position:absolute}:is(.swiper-button-prev,.swiper-button-next).swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}:is(.swiper-button-prev,.swiper-button-next).swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled :is(.swiper-button-prev,.swiper-button-next){display:none!important}:is(.swiper-button-prev,.swiper-button-next) ::slotted(svg),:is(.swiper-button-prev,.swiper-button-next) svg{object-fit:contain;transform-origin:50%;fill:currentColor;pointer-events:none;width:100%;height:100%}.swiper-button-lock{display:none}.swiper-button-prev,.swiper-button-next{top:var(--swiper-navigation-top-offset,50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2))}.swiper-button-prev{left:var(--swiper-navigation-sides-offset,4px);right:auto}.swiper-button-prev ::slotted(.swiper-navigation-icon),.swiper-button-prev .swiper-navigation-icon{transform:rotate(180deg)}.swiper-button-next{right:var(--swiper-navigation-sides-offset,4px);left:auto}.swiper-horizontal .swiper-button-prev,.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal~.swiper-button-next{top:var(--swiper-navigation-top-offset,50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2));margin-left:0}.swiper-horizontal .swiper-button-prev,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal.swiper-rtl .swiper-button-next,.swiper-horizontal.swiper-rtl~.swiper-button-next{left:var(--swiper-navigation-sides-offset,4px);right:auto}.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-next,.swiper-horizontal.swiper-rtl .swiper-button-prev,.swiper-horizontal.swiper-rtl~.swiper-button-prev{right:var(--swiper-navigation-sides-offset,4px);left:auto}:is(.swiper-horizontal .swiper-button-prev,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal.swiper-rtl .swiper-button-next,.swiper-horizontal.swiper-rtl~.swiper-button-next) ::slotted(.swiper-navigation-icon),:is(.swiper-horizontal .swiper-button-prev,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal.swiper-rtl .swiper-button-next,.swiper-horizontal.swiper-rtl~.swiper-button-next) .swiper-navigation-icon{transform:rotate(180deg)}:is(.swiper-horizontal.swiper-rtl .swiper-button-prev,.swiper-horizontal.swiper-rtl~.swiper-button-prev) ::slotted(.swiper-navigation-icon),:is(.swiper-horizontal.swiper-rtl .swiper-button-prev,.swiper-horizontal.swiper-rtl~.swiper-button-prev) .swiper-navigation-icon{transform:rotate(0)}.swiper-vertical .swiper-button-prev,.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-prev,.swiper-vertical~.swiper-button-next{left:var(--swiper-navigation-top-offset,50%);margin-left:calc(0px - (var(--swiper-navigation-size) / 2));margin-top:0;right:auto}.swiper-vertical .swiper-button-prev,.swiper-vertical~.swiper-button-prev{top:var(--swiper-navigation-sides-offset,4px);bottom:auto}:is(.swiper-vertical .swiper-button-prev,.swiper-vertical~.swiper-button-prev) ::slotted(.swiper-navigation-icon),:is(.swiper-vertical .swiper-button-prev,.swiper-vertical~.swiper-button-prev) .swiper-navigation-icon{transform:rotate(-90deg)}.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-next{bottom:var(--swiper-navigation-sides-offset,4px);top:auto}:is(.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-next) ::slotted(.swiper-navigation-icon),:is(.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-next) .swiper-navigation-icon{transform:rotate(90deg)}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#121212;--bg-card:#1e1e2e;--bg-card-hover:#2a2a3e;--text:#e0e0e0;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent:#3b82f6;--accent-hover:#2563eb;--border:#2e303a;--error:#ef4444;--success:#22c55e}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.navbar{border-bottom:1px solid var(--border);z-index:100;background:#0d0d0d;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.navbar-brand{color:var(--text);font-size:20px;font-weight:600;text-decoration:none}.navbar-right{align-items:center;display:flex}.login-link{color:var(--accent);font-weight:500;text-decoration:none}.profile-wrapper{position:relative}.profile-btn{cursor:pointer;background:0 0;border:none;padding:0}.profile-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:600;display:flex}.profile-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;min-width:200px;padding:12px;position:absolute;top:48px;right:0;box-shadow:0 8px 32px #0006}.profile-menu-header{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;margin-bottom:8px;padding-bottom:12px;display:flex}.profile-menu-header strong{color:var(--text)}.profile-menu-header span{color:var(--text-muted);font-size:13px}.profile-menu button{text-align:left;width:100%;color:var(--error);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px;font-size:14px}.profile-menu button:hover{background:#ef44441a}.auth-page{justify-content:center;align-items:center;min-height:calc(100vh - 73px);padding:24px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:40px}.auth-card h2{text-align:center;margin-bottom:24px;font-size:28px;font-weight:600}.auth-error{color:var(--error);background:#ef44441a;border-radius:8px;margin-bottom:16px;padding:12px;font-size:14px}.auth-success{color:var(--success);background:#22c55e1a;border-radius:8px;margin-bottom:16px;padding:12px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:14px;display:block}.form-group input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:12px 16px;font-size:16px;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:48px}.password-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.password-toggle:hover{color:var(--text)}.auth-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:600;transition:background .2s}.auth-submit:hover{background:var(--accent-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-forgot{text-align:center;margin-top:12px}.auth-forgot button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:underline}.auth-forgot button:hover{color:var(--accent)}.auth-toggle{text-align:center;color:var(--text-muted);margin-top:20px;font-size:14px}.auth-toggle button{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:14px}.home-page{max-width:800px;margin:0 auto;padding:32px 24px}.home-title{text-align:center;margin-bottom:24px;font-size:32px;font-weight:700}.card-groups-grid{flex-direction:column;gap:20px;display:flex}.card-group{cursor:pointer;text-align:center;border-radius:16px;padding:48px 24px;transition:transform .2s,box-shadow .2s}.card-group:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.card-group-name{color:#1a1a2e;margin-bottom:8px;font-size:26px;font-weight:600}.card-group-count{color:#1a1a2eb3;font-size:18px}.flashcards-page{flex-direction:column;height:calc(100vh - 73px);display:flex;overflow:hidden}.flashcards-header{align-items:center;gap:16px;padding:16px 24px;display:flex}.back-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px}.back-btn:hover{background:var(--bg-card)}.flashcards-header h2{flex:1;font-size:22px;font-weight:600}.card-counter{color:var(--text-muted);font-size:14px}.flashcard-swiper{flex:1;width:100%;padding:20px 0 40px;overflow:hidden}.flashcard-swiper .swiper-slide{width:500px;max-width:85vw;transition:opacity .3s,transform .3s}.flashcard-swiper .swiper-slide:not(.swiper-slide-active){opacity:.4}.flashcard-swiper .swiper-slide:not(.swiper-slide-active) .flashcard-container{pointer-events:none}.flashcard-swiper .swiper-button-next,.flashcard-swiper .swiper-button-prev{color:var(--accent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1e1e2ecc;border-radius:50%;width:44px;height:44px}.flashcard-swiper .swiper-button-next:after,.flashcard-swiper .swiper-button-prev:after{font-size:18px;font-weight:700}.flashcard-container{perspective:1200px;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;height:100%;padding:10px;display:flex}.flashcard{width:100%;max-width:500px;height:420px;transform-style:preserve-3d;transition:transform .6s;position:relative}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.flashcard-back{transform:rotateY(180deg)}.flashcard-content{text-align:center;width:100%;padding:32px}.flashcard-word{color:#fff;margin-bottom:12px;font-size:72px;font-weight:300;line-height:1.2}.flashcard-pinyin{color:var(--text-secondary);margin-bottom:16px;font-size:22px}.flashcard-pos{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-size:13px}.flashcard-translation{color:var(--text);font-size:18px}.audio-btn{border:2px solid var(--border);color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;margin-top:20px;padding:10px;transition:background .2s,border-color .2s;display:inline-flex}.audio-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.audio-btn svg{display:block}.flashcard-label{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:20px;font-size:12px}.flashcard-sentence-zh{color:#fff;margin-bottom:12px;font-size:32px;line-height:1.4}.flashcard-sentence-pinyin{color:var(--text-secondary);margin-bottom:12px;font-size:18px}.flashcard-sentence-en{color:var(--text);margin-bottom:8px;font-size:16px}.flashcard-hint{color:var(--text-muted);margin-top:20px;font-size:12px}.conversation-card{height:460px}.conversation-front{border-left:4px solid #3b82f6}.conversation-back{border-left:4px solid #f59e0b}.conversation-speaker-label{text-transform:uppercase;letter-spacing:2px;border-radius:20px;margin-bottom:24px;padding:6px 16px;font-size:13px;font-weight:700;display:inline-block}.you-label{color:#60a5fa;background:#3b82f626}.coworker-label{color:#fbbf24;background:#f59e0b26}.conversation-chinese{color:#fff;margin-bottom:12px;font-size:36px;font-weight:400;line-height:1.4}.conversation-pinyin{color:var(--text-secondary);margin-bottom:12px;font-size:18px}.conversation-english{color:var(--text);margin-bottom:8px;font-size:16px}@media (width<=640px){.flashcard{max-width:100%;height:380px}.flashcard-word{font-size:56px}.flashcard-sentence-zh{font-size:24px}.flashcard-swiper{padding:12px 0 50px}.flashcard-swiper .swiper-slide{width:85vw}.card-group{padding:36px 20px}.flashcard-swiper .swiper-button-next,.flashcard-swiper .swiper-button-prev{display:none}.conversation-card{height:420px}.conversation-chinese{font-size:26px}}
