*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background-color:#fff;padding:40px;border-radius:20px;box-shadow:0 10px 25px #0000001a;text-align:center;max-width:400px;width:100%;animation:fadeIn .5s ease-out}.welcome-message{margin-bottom:3rem}.welcome-message h2{color:#333;font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.main-message{color:#495057;font-size:1.3rem;font-weight:500;margin-bottom:1rem;line-height:1.4}.sub-message{color:#228be6;font-size:1.1rem;font-weight:600;margin:0;margin-bottom:2.5rem}.join-message{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;margin-bottom:30px;color:#fff;box-shadow:0 4px 15px #0000001a}.join-message p{margin:0;line-height:1.6;font-size:1.1rem;font-weight:500}.join-message p:first-child{margin-bottom:8px}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 24px;background-color:#fff;color:#333;border:1px solid #ddd;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.google-login-btn:hover{background-color:#f8f9fa;box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.google-icon{width:20px;height:20px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-content{background-color:#fff;padding:30px;border-radius:15px;text-align:center;max-width:400px;width:90%;box-shadow:0 10px 25px #0000001a;animation:slideUp .3s ease-out}.modal-content h3{color:#333;font-size:1.5rem;margin-bottom:10px;font-weight:600}.modal-content p{color:#666;margin-bottom:20px}.modal-content input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem;margin-bottom:20px;transition:border-color .3s ease}.modal-content input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.modal-content button{width:100%;padding:12px;background-color:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.modal-content button:hover{background-color:#5a6fd6;transform:translateY(-1px)}.modal-content button:disabled{background-color:#a5b4f3;cursor:not-allowed;transform:none}.error-message{color:#dc3545;font-size:.9rem;margin-top:-15px;margin-bottom:15px}.guest-login{margin-top:2rem;padding-top:2rem;border-top:1px solid #eee;text-align:center}.guest-login p{margin-bottom:1rem;color:#666;font-size:.9rem}.guest-login-btn{color:#6c757d;font-size:1.1rem;text-decoration:none;cursor:pointer;transition:all .3s ease;display:inline-block;padding:.5rem 1rem;border-radius:4px;position:relative}.guest-login-btn:hover{color:#495057;background-color:#6c757d1a}.guest-login-btn:after{content:"";position:absolute;width:100%;height:2px;bottom:0;left:0;background-color:#6c757d;transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease}.guest-login-btn:hover:after{transform:scaleX(1);transform-origin:bottom left}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard-container{display:flex;flex-direction:column;align-items:center;padding:32px 24px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);min-height:100vh}.dashboard-header{display:flex;flex-direction:column;width:100%;max-width:1000px;margin-bottom:32px;padding:28px 36px;background:#fffffff2;border-radius:20px;box-shadow:0 8px 24px #959da51a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:16px}.welcome-message{width:100%;color:#228be6;font-size:.9rem;font-weight:500;letter-spacing:-.3px;margin-bottom:4px}.header-main{display:flex;justify-content:space-between;align-items:center;width:100%}.dashboard-header h1{color:#1a1a1a;font-size:1.6rem;font-weight:600;margin:0;letter-spacing:-.5px;position:relative;padding-left:2px}.user-info{display:flex;align-items:center;gap:28px}.user-info span{color:#495057;font-size:.9rem;font-weight:500;letter-spacing:-.3px}.logout-button{background-color:#fff;color:#495057;border:1.5px solid #e9ecef;padding:8px 20px;border-radius:12px;cursor:pointer;font-size:.85rem;font-weight:500;letter-spacing:-.2px;transition:all .2s ease}.logout-button:hover{background-color:#f8f9fa;border-color:#adb5bd;transform:translateY(-1px)}.attendance-section,.game-section{width:100%;max-width:1000px;margin-bottom:32px}.attendance-section h2,.game-section h2{color:#1a1a1a;margin-bottom:20px;font-size:1.3rem;font-weight:600;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}.attendance-section h2:before,.game-section h2:before{content:"";display:block;width:3px;height:16px;background:#228be6;border-radius:2px}.attendance-card{background:#fffffff2;border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:24px;box-shadow:0 8px 24px #959da51a;transition:all .3s ease;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.attendance-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #959da526}.attendance-card h2{color:#1a1a1a;font-size:1.3rem;font-weight:600;letter-spacing:-.3px;margin:0;align-self:flex-start}.attendance-stats{display:flex;justify-content:center;margin-bottom:8px;padding:16px 32px;background:#f8f9fa;border-radius:16px;border:1px solid #e9ecef}.attendance-stats p{color:#495057;font-size:.95rem;font-weight:400;margin:0;display:flex;align-items:center;gap:6px}.attendance-stats p strong{color:#228be6;font-weight:600;font-size:1.1rem}.check-in-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.check-in-button{background:#228be6;color:#fff;border:none;padding:12px 32px;border-radius:12px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;width:100%;max-width:200px}.check-in-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #228be633}.check-in-button:disabled{background:#e9ecef;color:#495057;cursor:not-allowed;transform:none;box-shadow:none;border:1px solid #dee2e6}.check-in-button.checked{background:#e9ecef;color:#495057;box-shadow:none;border:1px solid #dee2e6}.game-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:16px}.game-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 8px 24px #959da51a;transition:all .3s ease;text-decoration:none;color:inherit;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.game-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #959da533}.game-card h3{font-size:1.3rem;font-weight:600;color:#1a1a1a;margin-bottom:12px}.game-card p{color:#495057;font-size:.95rem;line-height:1.5;margin:0}.toast{position:absolute;top:-40px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:12px;font-size:.9rem;font-weight:500;white-space:nowrap;animation:slideIn .3s ease,fadeOut .3s ease 2.7s;z-index:10;box-shadow:0 4px 12px #0000001a}.toast.success{background-color:#e7f5ff;color:#1864ab;border:1px solid #d0ebff}.toast.info{background-color:#f1f3f5;color:#495057;border:1px solid #e9ecef}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width: 768px){.dashboard-container{padding:20px 16px}.dashboard-header{padding:24px}.welcome-message{font-size:.85rem;text-align:center}.header-main{flex-direction:column;align-items:center;gap:16px}.dashboard-header h1{font-size:1.5rem}.user-info{gap:16px}.user-info span{font-size:.85rem}.attendance-stats{padding:16px 24px;text-align:center}.game-cards{grid-template-columns:1fr;gap:16px}.game-card{padding:20px}}.join-message{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;margin:0 20px 20px;color:#fff;box-shadow:0 4px 15px #0000001a;text-align:center;animation:fadeIn .5s ease-out}.join-message p{margin:0;line-height:1.6;font-size:1.2rem;font-weight:600;letter-spacing:.5px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;background-color:#fff;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:10px;z-index:9999;animation:slideIn .3s ease-out;min-width:300px}.notification.error{border-left:4px solid #dc3545;background-color:#fff5f5}.notification.success{border-left:4px solid #28a745;background-color:#f0fff4}.notification p{margin:0;color:#333;font-size:1rem;font-weight:500}.notification button{background:none;border:none;color:#666;font-size:1.5rem;cursor:pointer;padding:0 5px;line-height:1}.notification button:hover{color:#333}.points-display{background-color:#4a90e2;color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;margin-right:1rem;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:8px}.points-display:before{content:"🎯";font-size:1.2em}.card-game-container{display:flex;flex-direction:column;align-items:center;padding:0;width:100%;max-width:500px;min-height:100vh;background-color:#f0f0f0;margin:0 auto;position:relative}.moves,.time{font-size:1.2rem;font-weight:700;color:#333;min-width:100px;text-align:center}.card-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;width:90%;max-width:450px;padding:5px;margin:0 auto;box-sizing:border-box}.card{aspect-ratio:1/1.4;width:100%;max-width:100%;perspective:1000px;cursor:pointer}.card:hover{transform:scale(1.05)}.card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s}.card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;justify-content:center;align-items:center;border-radius:8px;box-shadow:0 2px 5px #0000001a}.card-front{background-color:#343a40;color:#fff}.card-back{background-color:#fff;transform:rotateY(180deg)}.card.matched{opacity:.5;pointer-events:none}.ranking-section{margin:20px 0 80px;padding:20px;background-color:#ffffffe6;border-radius:8px;box-shadow:0 2px 4px #0000001a}.player-time{font-weight:700;color:#4dabf7;min-width:100px;text-align:right}.final-time{font-size:1.5rem;font-weight:700;margin-bottom:20px;color:#4dabf7}.modal-button{padding:10px 20px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.modal-button:hover{background-color:#5a6268}.notification{position:fixed;top:20px;right:20px;padding:15px 25px;border-radius:8px;color:#fff;font-weight:700;z-index:1000;animation:slideIn .3s ease-out}.notification.success{background-color:transparent}.notification.error{background-color:#f44336}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.card-game-container{padding:0;margin:0;max-width:100vw}.card-grid{grid-template-columns:repeat(5,1fr);gap:2px;padding:2px;width:100vw;max-width:100vw}.card{width:100%;max-width:100%}.game-header{width:100%;padding:5px;margin-top:10px}.top-buttons{width:100%;padding:5px;margin-top:5px}.ranking-section{margin:15px 0 70px;padding:15px}.game-title{font-size:2rem;margin:15px 0}}.attribution{text-align:center;padding:15px;margin:20px 0;font-size:.9rem;color:#333;background-color:#ffffffe6;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;max-width:450px}.attribution a{color:#4dabf7;text-decoration:none;font-weight:500;transition:color .3s ease}.attribution a:hover{color:#228be6;text-decoration:underline}@media (max-width: 768px){.attribution{font-size:.8rem;padding:10px;margin:15px 0;width:90%}}.match-three-container{display:flex;flex-direction:column;align-items:center;padding:20px;min-height:100vh;background-color:#f0f0f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;max-width:600px;margin:0 auto;position:relative}.back-button,.mute-button,.restart-button{background-color:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.back-button:hover,.mute-button:hover,.restart-button:hover{background-color:#5a6268}.game-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:20px;padding:0 10px;margin-top:20px}.score,.moves,.time{font-size:1.2rem;font-weight:700;color:#333;min-width:100px;text-align:center}.header-buttons{display:flex;gap:10px;align-items:center}.game-board{display:flex;flex-direction:column;gap:2px;background-color:#f0f0f0;padding:10px;border-radius:8px;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.board-row{display:flex;gap:2px}.gem{width:50px;height:50px;border-radius:4px;cursor:pointer;position:relative;overflow:hidden;transition:transform .2s;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.gem:hover{transform:scale(1.05)}.gem.selected{transform:scale(1.1);box-shadow:0 0 5px #00000080}.gem-image{width:100%;height:100%;object-fit:contain;transition:all .3s ease}.gem.red{background-color:#ff6b6b}.gem.blue{background-color:#4dabf7}.gem.green{background-color:#51cf66}.gem.yellow{background-color:#ffd43b}.gem.purple{background-color:#cc5de8}.gem.cyan{background-color:#3bc9db}.game-over-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:20px;border-radius:8px;text-align:center;max-width:400px;width:90%}.modal-content h2{margin-bottom:20px;color:#333}.final-score{font-size:1.5rem;font-weight:700;margin-bottom:20px;color:#4dabf7}.modal-buttons{display:flex;gap:20px;justify-content:center;margin-top:20px}.ranking-section{margin-top:20px;width:100%;background-color:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a}.ranking-section h3{text-align:center;color:#333;margin-bottom:15px;font-size:1.2rem}.ranking-list{display:flex;flex-direction:column;gap:10px}.ranking-item{display:flex;align-items:center;padding:12px;background-color:#f8f9fa;border-radius:6px;font-size:.9rem;transition:transform .2s}.ranking-item:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.rank{font-weight:700;color:#4dabf7;width:30px;text-align:center}.player-name{flex:1;margin:0 15px;color:#333;font-weight:500}.ranking-details{display:flex;gap:15px;align-items:center}.player-score{font-weight:700;color:#4dabf7;min-width:80px;text-align:right}.player-moves{color:#666;min-width:70px;text-align:right}.player-time{color:#666;min-width:100px;text-align:right}.no-rankings{text-align:center;color:#666;padding:20px;background-color:#f8f9fa;border-radius:6px}.restart-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#000c;color:#fff;padding:20px 30px;border-radius:10px;font-size:1.2rem;z-index:1000;animation:fadeInOut 2s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9)}}.game-title{font-family:Poppins,sans-serif;font-size:2.5rem;font-weight:700;color:#333;text-align:center;margin:20px 0;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}@media (max-width: 768px){.top-buttons{padding:5px;margin-top:5px}.game-header{margin-top:10px}.game-title{font-size:2rem;margin:15px 0}.match-three-container{padding:15px}}.privacy-footer{position:fixed;bottom:0;left:0;right:0;background-color:#ffffffe6;padding:10px 0;text-align:center;box-shadow:0 -2px 10px #0000001a;z-index:1000}.footer-links{display:flex;justify-content:center;align-items:center;gap:10px}.footer-link{background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:5px 10px;transition:color .3s ease}.footer-link:hover{color:#007bff}.link-separator{color:#ccc;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1001}.modal{background:#fff;border-radius:8px;padding:20px;max-width:800px;width:80%;max-height:90vh;overflow-y:auto;position:relative;margin:0 auto}.close-button{position:absolute;top:10px;right:10px;background:none;border:none;font-size:24px;cursor:pointer;color:#666}.modal-content{padding:20px;text-align:left;width:100%;margin:0 auto}.modal-content h2{color:#333;margin-bottom:20px;font-size:24px;text-align:left;width:100%}.modal-content h3{color:#444;margin:20px 0 10px;font-size:20px;text-align:left;width:100%}.modal-content h4{color:#555;margin:15px 0 10px;font-size:18px;text-align:left;width:100%}.modal-content p{color:#666;line-height:1.6;margin-bottom:15px;text-align:left;width:100%}.modal-content ul{list-style-type:disc;margin:0 0 15px 20px;padding-left:0;text-align:left;display:block;width:100%}.modal-content li{color:#666;margin-bottom:8px;line-height:1.4;text-align:left;width:100%}.contact-info{background-color:#f8f9fa;padding:20px;border-radius:8px;margin:20px 0;max-width:400px;width:100%}.contact-info p{margin:10px 0;text-align:left}.contact-info strong{color:#333;margin-right:10px}@media (max-width: 768px){.modal{width:90%;margin:10px auto}.modal-content h2{font-size:20px}.modal-content h3{font-size:18px}.modal-content h4{font-size:16px}.modal-content p{font-size:14px}.footer-link{font-size:12px;padding:3px 6px}}.community-container{max-width:800px;margin:0 auto;padding:2rem}.community-container h2{color:#333;font-size:2rem;margin-bottom:2rem;text-align:center}.post-form{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.post-form textarea{width:100%;min-height:100px;padding:1rem;border:1px solid #ddd;border-radius:8px;resize:vertical;font-size:1rem;margin-bottom:1rem;transition:border-color .3s ease}.post-form textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.post-form button{background:#667eea;color:#fff;border:none;padding:.8rem 2rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .3s ease}.post-form button:hover{background:#5a6fd6;transform:translateY(-1px)}.post-form button:disabled{background:#a5b4f3;cursor:not-allowed;transform:none}.posts-container{display:flex;flex-direction:column;gap:1.5rem}.post-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000001a}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.post-author{font-weight:600;color:#333}.post-time{color:#666;font-size:.9rem}.post-content{color:#444;line-height:1.6;white-space:pre-wrap}.loading{text-align:center;color:#666;padding:2rem;font-size:1.1rem}.post-actions{display:flex;align-items:center;gap:1rem}.delete-button{background:none;border:none;color:#dc3545;font-size:.9rem;cursor:pointer;padding:.3rem .6rem;border-radius:4px;transition:all .3s ease}.delete-button:hover{background-color:#dc35451a}.community-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;position:relative}.community-header h2{position:absolute;left:50%;transform:translate(-50%);margin:0}.back-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-left:auto}.back-button:hover{background-color:#5a6268}.tiktok-feed-container{padding:20px;min-height:100vh;margin:0 auto;position:relative}.floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center;position:sticky;top:0;z-index:10}.top-button,.back-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;justify-content:center;margin-top:24px;width:100%}@media (min-width: 900px){.tiktok-feed-cards{grid-template-columns:repeat(5,1fr);margin:0 auto}}.tiktok-feed-card{width:220px;height:450px;border:1px solid #eee;border-radius:10px;padding:12px;background:#fff;box-shadow:0 2px 8px #0000000a;display:flex;flex-direction:column;align-items:center;overflow:hidden}.tiktok-feed-card .meta{color:#888;font-size:.95rem;margin-top:4px;text-align:center}display: flex; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center;position:sticky}flex-direction: column; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}align-items: center; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}padding: 20px; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}min-height: 100vh; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}margin-bottom: 6px; } .top-button:hover{background-color:#495057}border-radius: 8px; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}box-shadow: 0 2px 4px rgba(0,0,0,.1); .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}width: 100%; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}max-width: 600px; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}margin: 0 auto; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}position: relative; .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}} .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-title{font-family:Poppins,sans-serif;font-size:2.5rem;font-weight:700;color:#333;text-align:center;margin:20px 0;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.tiktok-feed-title .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-title .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-title .top-button:hover{background-color:#495057}.top-buttons{display:flex;gap:10px;padding:10px;margin-top:10px;justify-content:center;width:100%}.top-buttons .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.top-buttons .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.top-buttons .top-button:hover{background-color:#495057}.back-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease}.back-button .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.back-button .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.back-button .top-button:hover{background-color:#495057}.top-button:hover,.back-button:hover{background-color:#495057}.back-button:hover .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.back-button:hover .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.back-button:hover .top-button:hover{background-color:#495057}.tiktok-feed-cards{display:grid;grid-template-columns:repeat(5,1fr);display:flex;flex-wrap:wrap;gap:24px;justify-content:center;margin-top:24px}.tiktok-feed-cards .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-cards .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-cards .top-button:hover{background-color:#495057}.tiktok-feed-card{width:220px;border:1px solid #eee;border-radius:10px;padding:12px;background:#fff;box-shadow:0 2px 8px #0000000a;display:flex;flex-direction:column;align-items:center}.tiktok-feed-card .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-card .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-card .top-button:hover{background-color:#495057}.tiktok-feed-card img{border-radius:8px;object-fit:cover;background:#f2f2f2;width:180px;height:240px}.tiktok-feed-card img .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-card img .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-card img .top-button:hover{background-color:#495057}.tiktok-feed-card .desc{margin-top:8px;min-height:40px;font-weight:700;text-align:center}.tiktok-feed-card .desc .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-card .desc .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-card .desc .top-button:hover{background-color:#495057}.tiktok-feed-card .meta{color:#888;font-size:13px;text-align:center}.tiktok-feed-card .meta .floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.tiktok-feed-card .meta .top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.tiktok-feed-card .meta .top-button:hover{background-color:#495057}.floating-buttons{display:flex;flex-direction:row;gap:12px;margin-bottom:16px;justify-content:flex-start;align-items:center}.top-button{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;transition:background-color .3s ease;margin-bottom:6px}.top-button:hover{background-color:#495057}.bbs-container{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:60vw;min-width:480px;max-width:900px;margin:48px auto 32px;background:#f9fafb;border-radius:18px;box-shadow:0 4px 24px #28325017;padding:38px 40px 30px;font-family:Segoe UI,Apple SD Gothic Neo,Malgun Gothic,Arial,sans-serif;transition:box-shadow .2s}@media (max-width: 768px){.bbs-container{width:95vw;min-width:unset;padding:16px 6vw}.bbs-date{display:none!important}}.bbs-date{font-size:.98rem;color:#8f8f8f;margin-left:12px;font-family:Menlo,Consolas,monospace}.bbs-list{margin-top:24px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000a;padding:4px 0}.bbs-list-item{padding:18px;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .17s;border-radius:7px;margin:0 8px}.bbs-list-item:hover{background:#f1f5fa}.bbs-list-item:hover{background:#f8f8f8}.bbs-title{font-size:1.18rem;font-weight:600;color:#264653;letter-spacing:-.02em}.bbs-header-actions{display:flex;flex-direction:row;justify-content:right;align-items:center;gap:12px;margin-bottom:18px}.bbs-write-btn,.bbs-back-btn,.bbs-edit-btn,.bbs-form button{background:#b2bec3;color:#fff;border:none;border-radius:4px;font-size:1rem;padding:10px 20px;height:44px;min-width:110px;cursor:pointer;font-weight:500;transition:background-color .3s;box-shadow:none;display:inline-flex;align-items:center;justify-content:center}.bbs-header-actions .bbs-write-btn,.bbs-header-actions .bbs-back-btn{background-color:#b2bec3;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;padding:10px 20px;height:44px;min-width:110px;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transition:background-color .3s;cursor:pointer}.bbs-header-actions .bbs-write-btn:hover,.bbs-header-actions .bbs-back-btn:hover{background-color:#636e72}.bbs-header-actions .bbs-write-btn:disabled,.bbs-header-actions .bbs-back-btn:disabled{background-color:#adb5bd;color:#f1f3f5;cursor:not-allowed}.bbs-write-btn:hover,.bbs-back-btn:hover,.bbs-edit-btn:hover,.bbs-form button:hover{background-color:#5a6268}.bbs-write-btn:disabled,.bbs-back-btn:disabled,.bbs-edit-btn:disabled,.bbs-form button:disabled{background-color:#adb5bd;color:#f1f3f5;cursor:not-allowed}.bbs-detail-actions{display:flex;flex-direction:row;justify-content:flex-end;gap:12px;margin-left:auto;margin-bottom:10px}.bbs-form-modal{font-family:inherit;position:fixed;top:0;left:0;right:0;bottom:0;background:#0000002e;display:flex;align-items:center;justify-content:center;z-index:1000}.bbs-form{background:#f7f8fa;padding:30px 24px 24px;border-radius:13px;box-shadow:0 2px 16px #28325021;width:370px;display:flex;flex-direction:column;gap:14px;font-family:inherit}.bbs-form input,.bbs-form textarea{border:1.5px solid #c9d6df;border-radius:5px;padding:9px 10px;font-size:1.03rem;transition:border .18s;font-family:inherit}.bbs-form input:focus,.bbs-form textarea:focus{border:1.5px solid #264653;outline:none}.bbs-form textarea{resize:vertical;min-height:120px;background:#fff}.bbs-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.bbs-form button{background:linear-gradient(90deg,#264653 70%,#2a9d8f);color:#fff;border:none;border-radius:5px;padding:8px 20px;font-size:1.01rem;cursor:pointer;font-weight:600;transition:background .16s}.bbs-form button[type=button]{background-color:#adb5bd;color:#fff}.bbs-form button[type=button]{background:#888}.bbs-error{color:#e63946;font-size:.98rem;margin-top:2px;margin-bottom:-10px}.bbs-detail{margin-top:32px;background:#fff;border-radius:14px;box-shadow:0 2px 10px #28325014;padding:32px 30px 28px;position:relative;min-height:340px;display:flex;flex-direction:column;align-items:flex-start}.bbs-detail h3{margin-bottom:8px;font-size:1.38rem;font-weight:700;color:#264653;letter-spacing:-.01em}.bbs-back-btn{background:#b2bec3;color:#fff;border:none;border-radius:5px;padding:7px 17px;font-size:1.01rem;cursor:pointer;font-weight:500;transition:background .16s}.bbs-back-btn:hover{background:#636e72}.bbs-edit-btn{background:#b2bec3;color:#fff;border:none;border-radius:5px;padding:7px 17px;font-size:1.01rem;margin-bottom:12px;margin-right:10px;cursor:pointer;font-weight:500;transition:background .16s}.bbs-edit-btn:hover{background:#636e72}.bbs-content{position:relative}.bbs-watermark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-22deg);font-size:2.5rem;color:#b4b4b42e;font-weight:700;letter-spacing:.08em;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2;text-shadow:0 2px 10px rgba(80,80,80,.12)}.bbs-license{margin-top:28px;padding:12px 0;border-top:1px solid #eee;display:flex;align-items:center;gap:8px}.bbs-license img{height:22px;vertical-align:middle}.bbs-license a,.bbs-license span{color:#666;font-size:.98rem}
