.particle-container{z-index:-1;pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.particle{opacity:.5;background:radial-gradient(circle,#fffc 0%,#fff0 70%);border-radius:50%;animation:linear infinite float;position:absolute}@keyframes float{0%{opacity:0;transform:translateY(0)scale(1)}10%{opacity:.6}50%{transform:translateY(-50vh)scale(1.5)}90%{opacity:.6}to{opacity:0;transform:translateY(-100vh)scale(1)}}.login-container{justify-content:center;align-items:center;min-height:calc(100vh - 40px);display:flex}.login-card{text-align:center;border-radius:20px;width:100%;max-width:400px;padding:40px}.login-card h1{margin-bottom:10px;font-size:2rem}.subtitle{color:var(--text-muted);letter-spacing:2px;margin-bottom:30px;font-size:.9rem}.input-group{margin-bottom:20px}.login-btn{width:100%;margin-top:10px;padding:14px;font-size:1.2rem}.error-text{color:#e53e3e;margin-bottom:15px;font-size:.85rem}.navbar{z-index:100;border-radius:16px;justify-content:center;align-items:center;max-width:300px;margin-bottom:30px;margin-left:auto;margin-right:auto;padding:15px 20px;display:flex;position:sticky;top:20px;background:#fff9!important}.nav-title{color:var(--primary);font-size:1.4rem;font-weight:600;font-family:var(--font-title);letter-spacing:4px;text-align:center}.nav-bookmarks{z-index:200;flex-direction:column;gap:15px;display:flex;position:fixed;top:2%;right:0}.bookmark-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--primary);cursor:pointer;background:#ffffffb3;border:1px solid #ffffff4d;border-right:none;border-radius:30px 0 0 30px;padding:12px 18px 12px 25px;font-size:.95rem;font-weight:500;transition:all .4s cubic-bezier(.175,.885,.32,1.275);transform:translate(10px);box-shadow:-4px 4px 15px #0000000d}.bookmark-btn:hover{background:var(--primary);color:#fff;padding-left:35px;transform:translate(0)}.logout-bookmark{color:#ef4444;margin-top:20px}.logout-bookmark:hover{background:#ef4444}@media (width<=768px){.navbar{max-width:200px;padding:10px;top:10px}.nav-title{letter-spacing:2px;font-size:1.1rem}.bookmark-btn{padding:8px 12px 8px 15px;font-size:.8rem}}.home-container{padding:20px}.welcome-text{text-align:center;margin-bottom:40px}.welcome-text h2{margin-bottom:5px;font-size:1.8rem}.welcome-text p{color:var(--text-muted)}.action-cards{flex-flow:wrap;justify-content:center;gap:20px;display:flex}.action-card{cursor:pointer;text-align:center;border-left:1px solid #fff3;border-radius:20px;flex-direction:column;flex:1;align-items:center;min-width:280px;max-width:400px;padding:35px 25px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #1f268712}.action-card:hover{transition:all .4s;box-shadow:0 12px 40px #7c6ce726}.card-icon{filter:drop-shadow(0 4px 8px #0000001a);margin-bottom:15px;font-size:3rem}.action-card h3{color:var(--text-main);margin-bottom:10px;font-size:1.3rem}.action-card p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.admin-danger-zone{background:#fee2e240;border:1px solid #dc262659;border-radius:16px;max-width:480px;margin:48px auto 24px;padding:20px 24px}.admin-danger-title{color:#991b1b;margin:0 0 8px;font-size:1rem}.admin-danger-desc{color:var(--text-muted);margin:0 0 12px;font-size:.85rem;line-height:1.5}.admin-danger-msg{color:#166534;margin:0 0 12px;font-size:.85rem}.admin-clear-btn{color:#fff;cursor:pointer;background:#dc2626;border:1px solid #b91c1c;border-radius:10px;padding:10px 18px;font-family:inherit;font-size:.9rem}.admin-clear-btn:hover:not(:disabled){background:#b91c1c}.admin-clear-btn:disabled{opacity:.65;cursor:not-allowed}.mini-card{perspective:1000px;cursor:pointer;background:0 0;border:none;border-radius:1rem;width:130px;height:180px;margin:0 auto}.mini-card-inner{width:100%;height:100%;transform-style:preserve-3d;position:relative}.mini-face{backface-visibility:hidden;box-sizing:border-box;border-radius:1rem;flex-direction:column;width:100%;height:100%;transition:box-shadow .3s;display:flex;position:absolute;box-shadow:0 10px 30px #0000001a}.mini-card:hover .mini-face{box-shadow:0 25px 50px -12px #d9770666}.mini-back{background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);justify-content:center;align-items:center;padding:1rem}.mini-front{background:linear-gradient(to bottom right,#ffedd5,#fef3c7,#fed7aa);justify-content:space-between;padding:1rem;position:relative;overflow:hidden;transform:rotateY(180deg)}.mini-author-amber{color:#78350f;letter-spacing:.1em;text-align:center;font-size:1.5rem}.mini-content-wrapper{z-index:10;flex:1;justify-content:center;align-items:center;width:100%;display:flex;position:relative}.mini-content-short{-webkit-line-clamp:5;line-clamp:5;text-overflow:ellipsis;color:#7c2d12;text-align:center;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:.8125rem;line-height:1.5;display:-webkit-box;overflow:hidden}.card-zoom-overlay{-webkit-backdrop-filter:blur(10px);z-index:1000;will-change:opacity;background:#fef3c785;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.zoom-layout-wrapper{perspective:1000px;width:80vw;max-width:320px;height:400px}.zoom-layout-id-root{box-sizing:border-box;flex-direction:column;width:100%;height:100%;min-height:0;display:flex;overflow:hidden}.zoom-layout-id-root>.zoom-desc-editor{flex-shrink:0}.zoom-layout-id-root>.zoomed-card-3d{width:100%;min-height:0;transform-style:preserve-3d;flex:1;position:relative}.zoom-front>*{transform:translateZ(1px)}.zoom-face{backface-visibility:hidden;box-sizing:border-box;border-radius:1rem;flex-direction:column;width:100%;height:100%;transition:box-shadow .3s;display:flex;position:absolute;box-shadow:0 20px 50px #00000026}.zoomed-card-3d:hover .zoom-face{box-shadow:0 25px 50px -12px #d9770666}.zoom-back{background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);justify-content:space-between;align-items:center;padding:2rem}.zoom-back .author-name{color:#78350f;letter-spacing:.1em;z-index:10;flex:1;justify-content:center;align-items:center;font-size:3rem;display:flex}.zoom-front{backface-visibility:hidden;background:linear-gradient(to bottom right,#ffedd5,#fef3c7,#fed7aa);flex-direction:column;justify-content:space-between;padding:2.5rem;display:flex;position:relative;transform:rotateY(180deg)}.zoom-front .deco-ring{pointer-events:none;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.zoom-front .deco-ring-1{border:1px solid #d9770626;width:200px;height:200px}.zoom-front .deco-ring-2{border:1px solid #d9770614;width:160px;height:160px}.click-to-flip-hint{color:#d9770699;text-align:center;z-index:10;font-size:.875rem}.zoom-content-wrapper{z-index:10;flex:1;justify-content:center;align-items:center;padding:1rem;display:flex;position:relative}.zoom-content-full{-webkit-line-clamp:8;line-clamp:8;text-overflow:ellipsis;color:#7c2d12;letter-spacing:.05em;text-align:center;-webkit-box-orient:vertical;margin-bottom:1rem;font-size:1.125rem;line-height:1.8;display:-webkit-box;overflow:hidden}.zoom-footer-author{text-align:right;color:#7c2d12b3;z-index:10;font-size:.875rem;font-style:italic}.deco-ring{pointer-events:none;aspect-ratio:1;z-index:5;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.deco-ring-1{border:1px solid #d9770626;width:65%}.deco-ring-2{border:1px solid #d9770614;width:55%}.card-label{text-align:center;width:100%;color:var(--primary);pointer-events:none;font-size:.85rem;font-weight:500;font-family:var(--font-title);z-index:20;white-space:nowrap;text-overflow:ellipsis;background:0 0;padding:2px 0;position:absolute;top:-28px;left:0;overflow:hidden}.zoom-desc-editor{z-index:200;justify-content:center;width:100%;margin-bottom:20px;display:flex}.zoom-desc-input{-webkit-backdrop-filter:blur(10px);width:100%;color:var(--primary);text-align:center;font-size:1.1rem;font-family:var(--font-title);background:#fff9;border:1px solid #c2a87833;border-radius:8px;padding:12px 15px;transition:all .3s;box-shadow:0 4px 15px #0000000d}.zoom-desc-input:focus{border-color:var(--primary);background:#ffffffe6;outline:none;box-shadow:0 6px 20px #c2a87826}.zoom-label,.label-input,.label-display,.mini-desc-tag{display:none}.font-serif{font-family:var(--font-title), serif}.font-sans{font-family:var(--font-body), sans-serif}.write-container{flex-direction:column;align-items:center;height:calc(100vh - 120px);padding:20px 20px 0;display:flex;position:relative}.write-card{z-index:10;border-radius:20px;flex-direction:column;width:100%;height:45vh;min-height:350px;padding:30px;display:flex;position:relative}.write-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.write-header h3{margin:0;font-size:1.3rem}.char-count{color:var(--text-muted);font-size:.9rem}.write-textarea{resize:none;font-family:var(--font-body);color:var(--text-main);background:0 0;border:none;flex:1;font-size:1.2rem;line-height:1.8}.write-textarea:focus{outline:none}.write-textarea::placeholder{color:#71809680}.write-error{color:#e53e3e;text-align:center;margin-bottom:15px;font-size:.9rem}.write-actions{justify-content:center;margin-top:20px;display:flex}.submit-btn{width:60%;max-width:250px}.continuous-hint{text-align:center;color:var(--text-muted);letter-spacing:1px;margin-top:15px;font-size:.8rem}.written-cards-area{flex-wrap:wrap;justify-content:center;align-items:center;gap:15px;width:100%;max-width:100%;margin-top:20px;padding:20px;display:flex}.written-cards-area::-webkit-scrollbar{display:none}.mini-card-covered{cursor:pointer;color:#78350f;background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:140px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 15px #d977061a}.mini-card-inner{flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.mini-card-author{color:#78350f;font-size:1.5rem;font-weight:400;font-family:var(--font-title), serif;letter-spacing:.1em;text-align:center;text-shadow:none;background:0 0;padding:0 5px}.zoom-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#fff6;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.zoom-card-container{perspective:1000px;cursor:pointer;width:80vw;max-width:320px;height:60vh;max-height:480px}.zoom-card-3d{width:100%;height:100%;transform-style:preserve-3d;position:relative}.zoom-face{backface-visibility:hidden;border-radius:20px;flex-direction:column;width:100%;height:100%;padding:30px;display:flex;position:absolute;box-shadow:0 20px 50px #7c6ce726}.zoom-back{color:#78350f;background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);border:none;justify-content:center;align-items:center;gap:20px;transform:rotateY(0)}.zoom-back .author-name{color:#78350f;font-size:3rem;font-family:var(--font-title), serif;letter-spacing:.1em;text-shadow:none;background:0 0;flex:1;justify-content:center;align-items:center;display:flex}.zoom-front{background:linear-gradient(to bottom right,#ffedd5,#fef3c7,#fed7aa);border:none;justify-content:space-between;padding:2rem;position:relative;transform:rotateY(-180deg)}.zoom-content-full{color:#7c2d12;font-family:var(--font-title), serif;letter-spacing:.05em;text-align:center;z-index:10;flex:1;justify-content:center;align-items:center;font-size:1.125rem;line-height:2;display:flex;overflow-y:auto}.zoom-footer-author{text-align:right;color:#c2410cb3;z-index:10;font-family:serif;font-size:.875rem;font-style:italic}.border-0{border:none!important}.text-center{justify-content:center!important}.draw-container{justify-content:center;align-items:flex-start;min-height:calc(100vh - 120px);padding:10px;display:flex}.selection-view{flex-direction:column;width:100%;max-width:1000px;min-height:calc(100vh - 150px);display:flex}.selection-header{text-align:center;background:0 0;border:none;margin-bottom:20px;padding:10px 25px}.error-text{color:#e53e3e;margin-top:10px;font-size:.9rem}.text-center{text-align:center}.pool-area-large{background:#fef3c733;border:1px solid #d977061a;border-radius:24px;flex:1;justify-content:center;align-items:flex-start;margin-bottom:20px;padding:20px;display:flex;position:relative}.scattered-cards-wide{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;width:100%;padding:30px;display:flex}.pool-loading-hint{text-align:center;color:var(--text-muted);letter-spacing:.05em;padding:3rem 1rem;font-size:1rem}.empty-pool-hint{text-align:center;color:var(--text-muted)}.empty-pool-hint a{color:var(--primary);cursor:pointer;text-decoration:underline}.pool-card-covered{cursor:pointer;color:#78350f;background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);border:none;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:90px;height:120px;display:flex;position:relative;box-shadow:0 4px 10px #d9770626}.pool-card-covered .deco{margin-bottom:8px;font-size:1.2rem}.pool-card-covered .author{color:#78350f;font-size:1.2rem;font-weight:400;font-family:var(--font-title), serif;letter-spacing:.1em;text-align:center;text-shadow:none;background:0 0}.pool-card-covered.selected{border:3px solid #fbbf24;transform:scale(1.05);box-shadow:0 0 20px #fbbf2466}.selected-hint{color:#d97706;font-size:.6rem;font-weight:700;position:absolute;bottom:5px}.selection-actions{justify-content:center;padding:20px 0;display:flex}.complete-btn-large{color:#fff;cursor:pointer;background:linear-gradient(135deg,#fbbf24,#d97706);border:none;border-radius:100px;padding:15px 60px;font-size:1.2rem;font-weight:700;box-shadow:0 10px 25px #d977064d}.complete-btn-large:disabled{cursor:not-allowed;box-shadow:none;background:#ccc}.bag-card-covered{cursor:pointer;color:#78350f;background:linear-gradient(to bottom right,#fef3c7,#fffbeb,#ffedd5);border:none;border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:110px;display:flex;position:relative;box-shadow:0 4px 15px #d9770626}.bag-card-covered .deco{margin-bottom:5px;font-size:1rem}.bag-card-covered .author{color:#78350f;font-size:1rem;font-weight:400;font-family:var(--font-title), serif;letter-spacing:.1em;text-shadow:none;background:0 0}.remove-hint{color:#e53e3e;opacity:0;font-size:.7rem;transition:opacity .3s;position:absolute;bottom:-20px}.bag-card-covered:hover .remove-hint{opacity:1}.practice-view{flex-direction:column;align-items:center;width:100%;padding-top:20px;display:flex}.practice-header-text{text-align:center;color:var(--text-main);letter-spacing:1px;margin-bottom:30px;font-size:1.1rem;font-weight:700}.cards-list{flex-wrap:wrap;justify-content:center;gap:20px;width:100%;padding-bottom:40px;display:flex}.finish-btn{width:100%;max-width:300px}.practice-card-group{flex-direction:column;align-items:center;gap:8px;width:130px;display:flex}.card-description-input-wrap{width:100%}.card-desc-input{width:100%;color:var(--primary);text-align:center;font-size:.85rem;font-family:var(--font-title);background:0 0;border:none;border-bottom:1px solid #c2a87833;padding:6px 0;transition:all .3s}.card-desc-input:focus{border-bottom:1px solid var(--primary);background:#fff3;border-radius:4px 4px 0 0;outline:none}.card-desc-input::placeholder{color:#c2a87866;font-size:.75rem}.history-container{min-height:calc(100vh - 120px);padding:10px}.filter-bar{border-radius:16px;align-items:center;gap:15px;margin-bottom:25px;padding:15px;display:flex}.search-input{flex:1}.sort-btn{border:1px solid var(--primary);color:var(--primary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:12px;padding:10px 15px;transition:all .3s}.sort-btn.active,.sort-btn:hover{background:var(--primary);color:#fff}.practices-list{flex-direction:column;gap:15px;display:flex}.practice-item{border-radius:16px;overflow:hidden}.practice-header-bar{cursor:pointer;justify-content:space-between;align-items:center;padding:20px;transition:background .3s;display:flex}.practice-header-bar:hover{background:#7c6ce70d}.practice-info h4{color:var(--text-main);margin:0 0 5px;font-size:1.1rem}.practice-date{color:var(--text-muted);font-size:.85rem}.practice-stats{color:var(--text-muted);align-items:center;gap:15px;font-size:.9rem;display:flex}.expand-icon{color:var(--primary);font-size:.8rem}.practice-cards-grid{border-top:1px solid #7c6ce71a;overflow:hidden}.grid-inner{background:linear-gradient(#ffffff4d 0%,#fff0 100%);flex-flow:wrap;justify-content:center;gap:30px;padding:30px;display:flex}.my-cards-container{max-width:1200px;min-height:calc(100vh - 120px);margin:0 auto;padding:20px}.my-cards-grid{flex-wrap:wrap;justify-content:center;gap:30px;padding:20px 0;display:flex}.my-card-wrapper{flex-direction:column;align-items:center;width:200px;min-height:280px;display:flex}.my-card-slot{width:130px;position:relative}.my-card-delete-x{--my-card-del:28px;top:calc(-.3 * var(--my-card-del));right:calc(-.3 * var(--my-card-del));z-index:40;width:var(--my-card-del);height:var(--my-card-del);color:#991b1b;cursor:pointer;background:#ffffffbf;border:none;border-radius:50%;place-items:center;margin:0;padding:0;font-family:system-ui,-apple-system,sans-serif;font-size:1.05rem;font-weight:400;line-height:0;transition:background .2s,color .2s,transform .15s;display:grid;position:absolute;transform:translateY(-1px);box-shadow:0 1px 4px #0000001f}.my-card-delete-x:hover:not(:disabled){color:#7f1d1d;background:#fee2e2f2;transform:translateY(-1px)scale(1.06)}.my-card-delete-x:disabled{opacity:.55;cursor:not-allowed;transform:translateY(-1px)}.loading-state,.empty-state{text-align:center;color:var(--text-muted);padding:100px 20px;font-size:1.2rem}.empty-state p{margin-bottom:20px}@media (width<=768px){.my-cards-grid{gap:15px}.my-card-wrapper{width:160px;min-height:240px}}*,:before,:after{box-sizing:border-box}:root{--primary:#c2a878;--secondary:#8ca18b;--accent:#e5d9c5;--bg-start:#f9f6f0;--bg-end:#eae3d2;--text-main:#4a4a4a;--text-muted:#8a8a8a;--card-bg:#ffffffd9;--font-title:"ZCOOL XiaoWei", serif;--font-body:"Noto Sans SC", sans-serif}body{font-family:var(--font-body);color:var(--text-main);background:linear-gradient(135deg, var(--bg-start) 0%, var(--bg-end) 100%);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;margin:0;padding:0;line-height:1.6}h1,h2,h3,h4{font-family:var(--font-title);color:var(--primary);font-weight:400}.glass{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);border:1px solid #ffffff80;box-shadow:0 8px 32px #7c6ce71a}.glass-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1rem;font-family:var(--font-title);color:var(--primary);cursor:pointer;background:#ffffffd9;border:1px solid #c2a8784d;border-radius:20px;padding:12px 24px;transition:all .3s;box-shadow:0 4px 15px #0000000d}.glass-button:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #c2a87833}.glass-button:disabled{opacity:.5;cursor:not-allowed;color:var(--text-muted);background:#ffffff80}.glass-input{width:100%;color:var(--text-main);background:#ffffffe6;border:1px solid #7c6ce733;border-radius:12px;padding:12px 20px;font-size:1rem;transition:all .3s}.glass-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #7c6ce71a}.app-container{max-width:1000px;min-height:100vh;margin:0 auto;padding:20px 20px 80px;position:relative}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#7c6ce733;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7c6ce766}
