*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}#root,.app{display:flex;flex-direction:column;min-height:100vh}.app{background:#fff;width:100%}.main-content{flex:1 1;overflow-y:auto;padding:20px 20px 80px}.page-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;min-height:200px;text-align:center}.loading-spinner{margin-bottom:15px}.container{padding:0 20px;width:100%}.card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:24px}.card h2{color:#2c3e50;font-size:1.5rem;margin-bottom:16px}.card p{color:#666;line-height:1.6;margin-bottom:12px}@media (min-width:320px){.main-content{padding:16px 16px 80px}.container{padding:0 16px}.card{border-radius:8px;padding:16px}.card h2{font-size:1.25rem}}@media (min-width:768px){.main-content{padding:24px 24px 20px}.container{padding:0 24px}.card{border-radius:10px;padding:20px}.card h2{font-size:1.4rem}}@media (min-width:1024px){.main-content{padding:32px}.container{padding:0 32px}.card{border-radius:12px;padding:24px}.card h2{font-size:1.5rem}}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{animation:slideUp .5s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:420px;padding:40px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:32px;text-align:center}.login-title{color:#2c3e50;font-size:28px;font-weight:700;line-height:1.2;margin:0 0 8px}.login-subtitle{color:#7f8c8d;font-size:16px;font-weight:400;margin:0}.login-form{margin-bottom:32px}.form-label{color:#34495e;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{background:#fff;border:2px solid #e1e8ed;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled{background-color:#f8f9fa;cursor:not-allowed}.password-input-container{position:relative}.password-toggle{background:none;border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:background-color .2s ease}.password-toggle:hover:not(:disabled){background-color:#f1f3f4}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.error-message{align-items:center;border:1px solid #fcc;border-radius:8px;color:#c53030;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.error-icon{flex-shrink:0;font-size:16px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;overflow:hidden;padding:14px;position:relative;transition:all .2s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button.loading{background:#95a5a6;cursor:not-allowed}.login-button:disabled{box-shadow:none;cursor:not-allowed;transform:none}.loading-text{align-items:center;display:flex;gap:8px;justify-content:center}.login-actions{margin-bottom:24px;text-align:center}.signup-text{color:#7f8c8d;font-size:14px;margin:0 0 12px}.signup-button{align-items:center;background:#fff;border:2px solid #e1e8ed;border-radius:8px;color:#667eea;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;text-decoration:none;transition:all .2s ease}.signup-button:hover:not(:disabled){background:#f8f9ff;border-color:#667eea;transform:translateY(-1px)}.signup-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.signup-icon{flex-shrink:0;font-size:14px}.login-footer{border-top:1px solid #e1e8ed;padding-top:24px;text-align:center}.footer-text{color:#95a5a6;font-size:13px;margin:0}@media (max-width:480px){.login-page{padding:16px}.login-container{max-width:100%;padding:24px}.login-title{font-size:24px}.signup-button{font-size:13px;padding:10px 16px}}@media (max-width:320px){.login-container{padding:20px}.login-title{font-size:22px}}@media (prefers-color-scheme:dark){.login-page{background:linear-gradient(135deg,#2c3e50,#34495e)}}.top-nav{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 10px #0000001a;padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-container{height:64px;justify-content:space-between;padding:0 20px;width:100%}.brand-text,.nav-container{align-items:center;display:flex}.brand-text{line-height:1.1}.brand-js-planner{color:#2c3e50;font-size:1.8rem;font-weight:700;letter-spacing:-.5px}.brand-capital-j{color:#50c878;font-weight:900}.nav-menu{gap:8px;list-style:none}.nav-item,.nav-link,.nav-menu{display:flex}.nav-link{align-items:center;background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:14px;font-weight:500;gap:8px;padding:12px 16px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#f0f0f0;color:#2c3e50}.nav-link.active{background:#3498db;color:#fff}.nav-icon{font-size:18px}.nav-label{font-weight:500}.bottom-nav{background:#fff;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 10px #0000001a;display:none;left:50%;max-width:100vw;padding:8px 0 calc(8px + env(safe-area-inset-bottom));position:fixed;transform:translateX(-50%);width:100%;z-index:1000}.bottom-nav-item{align-items:center;background:#0000;border:none;color:#666;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;justify-content:center;min-height:56px;padding:8px 4px;transition:all .2s ease}.bottom-nav-item:hover{background:#f0f0f0}.bottom-nav-item.active{color:#3498db}.bottom-nav-icon{font-size:20px;margin-bottom:2px}.bottom-nav-label{font-size:11px;font-weight:500;line-height:1}@media (max-width:800px){.top-nav{display:none}.bottom-nav{display:flex}}@media (min-width:801px){.top-nav{display:block}.bottom-nav{display:none}.nav-container{padding:0 24px}.sub-nav{top:64px}}@media (min-width:1000px){.nav-container{padding:0 32px}}.sub-nav{background:#f8f9fa;border-bottom:1px solid #e0e0e0;position:-webkit-sticky;position:sticky;top:0;z-index:999}.sub-nav-container{display:flex;gap:8px;justify-content:center;padding:8px 16px}.sub-nav-item{background:#fff;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;max-width:120px;padding:12px 16px;text-align:center;transition:all .2s ease}.sub-nav-item:hover{background:#f0f0f0}.sub-nav-item.active{background:#3498db;color:#fff}.auth-menu-container,.login-button-nav{align-items:center;display:flex}.login-button-nav{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s ease}.login-button-nav:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.login-icon{font-size:16px}.login-text{font-weight:600}.user-menu-container{position:relative}.user-menu-button{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#2c3e50;padding:8px 12px}.user-menu-button:hover{background:#f8f9fa;border-color:#3498db}.user-avatar{flex-shrink:0;font-size:16px}.user-name{font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-arrow{color:#7f8c8d;font-size:10px;transition:transform .2s ease}.user-dropdown{animation:dropdownSlide .2s ease-out;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 20px #00000026;margin-top:8px;min-width:220px;position:absolute;right:0;top:100%;z-index:1001}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info{border-bottom:1px solid #f0f0f0;padding:16px}.user-info-name{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:4px}.user-info-role{color:#7f8c8d;font-size:14px;margin-bottom:4px}.user-info-grade{background:#3498db1a;border-radius:4px;color:#3498db;display:inline-block;font-size:13px;font-weight:500;margin-bottom:8px;padding:2px 6px}.user-info-email{color:#95a5a6;font-size:13px;font-style:italic}.user-menu-divider{border:none;border-top:1px solid #f0f0f0;margin:0}.user-menu-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 16px;transition:all .2s ease;width:100%}.user-menu-button .logout-icon,.user-menu-button .menu-icon{font-size:16px}.profile-button{border-radius:8px 8px 0 0;color:#2c3e50}.profile-button:hover{background:#f8f9fa;color:#3498db}.logout-button{border-radius:0 0 8px 8px;color:#e74c3c}.logout-button:hover{background:#fdf2f2;color:#c0392b}.logout-icon{font-size:16px}.auth-loading{align-items:center;background:#f8f9fa;color:#2c3e50;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.auth-loading .loading-spinner{animation:spin 1s linear infinite;border:4px solid #0000;border-radius:50%;border-top-color:#3498db;height:48px;margin-bottom:16px;transform-origin:center center;width:48px}.auth-loading p{color:#7f8c8d;font-size:16px}.access-denied{color:#2c3e50}.access-denied h2{margin-bottom:16px}.access-denied p{color:#7f8c8d;margin-bottom:8px;max-width:400px}.access-denied p:last-of-type{margin-bottom:24px}.login-prompt-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:16px;padding:12px 24px;transition:all .2s ease}.login-prompt-button:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}@media (max-width:800px){.user-name{display:none}.user-menu-button{padding:6px 8px}.user-dropdown{min-width:200px;right:-8px}.sub-nav-item{padding:6px 16px}}@media (max-width:500px){.nav-container{padding:0 12px}.user-dropdown{min-width:180px;right:-12px}.user-info{padding:12px}}.login-modal-overlay{align-items:center;animation:modalFadeIn .3s ease-out;background:#000000b3;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.login-modal-content{animation:modalSlideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.login-modal-close{align-items:center;background:#0000001a;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px;z-index:1}.login-modal-close:hover{background:#0003;color:#333}.login-modal-content .login-page{background:#0000;min-height:auto;padding:0}.login-modal-content .login-container{box-shadow:none;margin:0;max-width:none}.bottom-nav-item.login-mobile.active,.bottom-nav-item.user-menu-mobile.active{background:#3498db1a;color:#3498db}.mobile-user-menu-overlay{align-items:flex-end;animation:mobileMenuFadeIn .3s ease-out;background:#00000080;bottom:0;display:flex;left:0;position:fixed;right:0;top:0;z-index:9999}@keyframes mobileMenuFadeIn{0%{opacity:0}to{opacity:1}}.mobile-user-menu{animation:mobileMenuSlideUp .3s ease-out;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;padding:24px 20px;position:relative;width:100%;z-index:10000}@keyframes mobileMenuSlideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.mobile-user-info{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px}.mobile-user-avatar{align-items:center;background:#f8f9fa;border-radius:50%;display:flex;flex-shrink:0;font-size:32px;height:60px;justify-content:center;width:60px}.mobile-user-details{flex:1 1;min-width:0}.mobile-user-name{color:#2c3e50;font-size:18px;font-weight:600;margin-bottom:4px}.mobile-user-role{color:#7f8c8d;font-size:14px;margin-bottom:4px}.mobile-user-grade{background:#3498db1a;border-radius:4px;color:#3498db;display:inline-block;font-size:13px;font-weight:500;margin-bottom:6px;padding:2px 8px}.mobile-user-email{color:#95a5a6;font-size:13px;font-style:italic}.mobile-user-button{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:12px;box-sizing:border-box;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-bottom:8px;padding:16px;position:relative;text-decoration:none;touch-action:manipulation;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%;z-index:1}.mobile-user-button .logout-icon,.mobile-user-button .menu-icon{font-size:18px}.mobile-profile-button{background:#3498db!important;border:2px solid #2980b9!important;color:#fff!important;min-height:48px!important}.mobile-profile-button:hover{background:#2980b9!important}.mobile-profile-button:active{background:#21618c!important;transform:scale(.98)}.mobile-logout-button{background:#e74c3c;color:#fff;margin-bottom:0}.mobile-logout-button:hover{background:#c0392b}@media (max-width:800px){.login-text{display:none}.login-button-nav{padding:6px 8px}.login-modal-content{margin:10px;max-height:calc(100vh - 20px);width:calc(100% - 20px)}.user-dropdown{display:none}.bottom-nav-item{min-height:52px;padding:6px 2px}.bottom-nav-icon{font-size:18px}.bottom-nav-label{font-size:10px;line-height:1.1;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;word-break:keep-all}}@media (max-width:500px){.login-modal-overlay{padding:10px}.login-modal-content{border-radius:12px}.bottom-nav-item{min-height:48px;padding:4px 1px}.bottom-nav-icon{font-size:16px}.bottom-nav-label{font-size:9px}}@media (max-width:400px){.bottom-nav-label{display:none}.bottom-nav-item{min-height:44px}.bottom-nav-icon{font-size:20px}}@media (min-width:1000px){.mobile-only{display:none!important}}@media (max-width:999px){.user-dropdown{display:none!important}}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}.board-sidebar{background:#fff;border-right:1px solid #e0e0e0;box-shadow:2px 0 10px #0000001a;display:flex;flex-direction:column;height:calc(100vh - 64px);left:0;position:fixed;top:64px;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:999}.board-sidebar.open{transform:translateX(0)}.sidebar-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.sidebar-header h2{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0}.sidebar-close{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:none;font-size:18px;padding:4px}.sidebar-close:hover{background:#e0e0e0}.sidebar-content{flex:1 1;overflow-y:auto;padding:16px 0}.error-message,.loading-message{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.loading-spinner{margin-bottom:12px}.error-message p,.loading-message p{color:#666;font-size:14px;margin:0}.retry-btn{margin-top:12px;padding:8px 16px}.board-category{margin-bottom:24px}.category-title{color:#7f8c8d;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px 20px;text-transform:uppercase}.board-list{list-style:none;margin:0;padding:0}.board-item{margin:0}.board-link{align-items:center;background:#0000;border:none;color:#666;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:12px 20px;text-decoration:none;transition:all .2s ease;width:100%}.board-link:hover{background:#f0f0f0;color:#2c3e50}.board-link.active{background:#3498db;color:#fff}.board-link.active .board-count{background:#fff3;color:#fff}.board-info{align-items:center;display:flex;gap:12px}.board-icon{font-size:16px}.board-name{font-weight:500}.board-count{background:#ecf0f1;border-radius:12px;color:#7f8c8d;font-size:12px;font-weight:600;min-width:24px;padding:2px 8px;text-align:center}.sidebar-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:16px 20px}.create-board-btn{align-items:center;background:#2ecc71;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 16px;transition:background .2s ease;width:100%}.create-board-btn:hover{background:#27ae60}@media (min-width:768px){.board-sidebar{border-right:1px solid #e0e0e0;box-shadow:none;height:auto;min-height:calc(100vh - 64px);position:static;transform:none}.sidebar-overlay{display:none!important}.sidebar-close{display:none}}@media (max-width:767px){.board-sidebar{height:100vh;top:0}.sidebar-close,.sidebar-overlay{display:block}}.board-content{background:#fff;flex:1 1;min-height:100%}.mobile-header{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;display:none;justify-content:space-between;padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.mobile-header h1{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0}.sidebar-toggle{background:none;border:none;color:#666;cursor:pointer;font-size:20px;padding:8px}.board-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:32px}.board-header,.board-title{align-items:center;display:flex}.board-title{gap:16px}.board-icon{font-size:32px}.board-title h1{color:#2c3e50;font-size:1.8rem;font-weight:600;margin:0 0 4px}.board-title p{color:#666;font-size:14px;margin:0}.write-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background .2s ease}.write-btn:hover{background:#2980b9}.write-btn.login-required{background:#95a5a6;font-size:13px;padding:8px 16px}.write-btn.login-required:hover{background:#7f8c8d}.write-btn.permission-denied{background:#e74c3c;cursor:not-allowed;opacity:.7}.write-btn.permission-denied:hover{background:#e74c3c}.retry-btn{background:#3498db;border-radius:6px;margin-top:16px;padding:12px 24px}.retry-btn:hover{background:#2980b9}.close-btn{border-radius:4px;color:#666;font-size:1.5rem;padding:4px;transition:background-color .2s}.close-btn:hover{background:#e9ecef;color:#333}.board-toolbar{background:#fff;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:16px 32px}.board-toolbar,.toolbar-left{align-items:center;display:flex}.toolbar-left{gap:16px}.toolbar-right{align-items:center;display:flex;gap:12px}.toolbar-right .post-count{color:#666;font-size:14px}.solved-filter,.sort-select{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.search-box{align-items:center;border:1px solid #ddd;border-radius:6px;display:flex;overflow:hidden}.search-box input{border:none;outline:none;padding:8px 12px;width:200px}.search-box button{background:#f0f0f0;border:none;cursor:pointer;font-size:14px;padding:8px 12px}.search-box button:hover{background:#e0e0e0}.loading-indicator{color:#3498db;font-size:14px}.post-list{background:#fff}.post-item{border-bottom:1px solid #f0f0f0;transition:background .2s ease}.post-item:hover{background:#f8f9fa}.post-main{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:20px 32px}.post-title-area{flex:1 1}.post-title{align-items:center;color:#2c3e50;display:flex;font-size:11.2px;font-weight:500;gap:8px;line-height:1.4;margin:0 0 8px}.post-meta{color:#7f8c8d;font-size:13px;gap:12px}.post-author{font-weight:500}.post-stats{gap:16px;margin-left:16px}.post-stats,.stat-item{align-items:center;display:flex}.stat-item{color:#7f8c8d;font-size:13px;gap:4px}.stat-icon{font-size:12px}.solve-badge{border-radius:4px;font-size:11px;padding:2px 6px}.solve-badge.solved{background:#2ecc71;color:#fff}.solve-badge.unsolved{background:#e74c3c;color:#fff}.pagination{gap:8px;padding:32px}.page-btn,.pagination{align-items:center;background:#fff;display:flex;justify-content:center}.page-btn{border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:14px;height:32px;min-width:32px;transition:all .2s ease}.page-btn:hover{background:#f0f0f0}.page-btn.active{background:#3498db;border-color:#3498db;color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-btn:disabled:hover{background:#fff}.empty-message,.error-message,.loading-message{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 32px}.empty-message p,.error-message p,.loading-message p{color:#666;font-size:16px;margin:4px 0}.empty-message p:first-child{font-size:18px;margin-bottom:8px}.comments-loading{color:#666;padding:20px}.no-comments,.no-content{color:#999;font-style:italic;padding:20px;text-align:center}.post-detail-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);position:absolute}.modal-content{border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-width:800px;overflow:hidden;position:relative;width:90%}.modal-header{background:#f8f9fa;padding:20px}.post-detail-title{color:#333;flex:1 1;font-size:1.4rem;margin:0 16px 0 0}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.post-detail-meta{background:#f8f9fa;border-left:4px solid #007bff;border-radius:6px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:12px}.post-detail-meta span{color:#666;font-size:.9rem}.post-detail-content{line-height:1.6;margin-bottom:30px}.post-content{background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:16px}.post-content p{color:#333;margin:0 0 8px}.comments-section{border-top:1px solid #eee;padding-top:20px}.comments-title{color:#333;font-size:1.2rem;margin:0 0 16px}.comments-list{gap:12px}.comment-item{border-radius:6px;padding:12px}.comment-header{color:#666;font-size:.85rem;gap:12px;margin-bottom:8px}.comment-content{color:#333;line-height:1.5}.comment-content p{margin:0 0 4px}@media (min-width:801px) and (max-width:1000px){.board-header{padding:24px}.board-toolbar,.post-main{padding:16px 24px}.search-box input{width:150px}}@media (max-width:800px){.mobile-header{display:flex}.board-header{display:none}.board-toolbar{padding:16px}.board-toolbar,.toolbar-left{align-items:stretch;flex-direction:column;gap:12px}.search-box input{width:100%}.post-main{align-items:flex-start;flex-direction:column;gap:12px;padding:16px}.post-stats{align-self:flex-end;margin-left:0}.pagination{padding:20px 16px}.modal-content{margin:20px;max-height:95vh;width:95%}.modal-body,.modal-header{padding:16px}.post-detail-title{font-size:1.2rem}.post-detail-meta{font-size:.85rem;gap:8px}.comment-header{flex-wrap:wrap;gap:8px}}@media (max-width:500px){.board-toolbar,.post-main{padding:12px}.pagination{padding:16px 12px}.page-btn{font-size:12px;height:28px;min-width:28px}.empty-message,.error-message,.loading-message{padding:40px 16px}.modal-body,.modal-header{padding:12px}.post-detail-title{font-size:1.1rem}}.rich-text-editor{background:#fff;border:1px solid #d0d7de;border-radius:8px;overflow:hidden;position:relative}.rich-text-editor.disabled{opacity:.6;pointer-events:none}.editor-toolbar{background:#f6f8fa;border-bottom:1px solid #d0d7de;flex-wrap:wrap;gap:4px;min-height:46px;padding:8px 12px}.editor-toolbar,.toolbar-group{align-items:center;display:flex}.toolbar-group{gap:2px}.toolbar-divider{background:#d0d7de;height:24px;margin:0 8px;width:1px}.toolbar-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:4px;color:#24292f;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;min-height:28px;padding:6px 10px;transition:all .15s ease}.toolbar-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d0d7de}.toolbar-btn:active:not(:disabled){background:#e5e7ea;border-color:#afb8c1}.toolbar-btn:disabled{cursor:not-allowed;opacity:.5}.toolbar-select{background:#fff;border:1px solid #d0d7de;border-radius:4px;color:#24292f;cursor:pointer;font-size:12px;min-width:80px;padding:4px 8px}.toolbar-select:hover:not(:disabled){border-color:#8c959f}.toolbar-select:focus:not(:disabled){border-color:#0969da;box-shadow:0 0 0 3px #0969da1a;outline:none}.editor-content{word-wrap:break-word;color:#24292f;direction:ltr;font-size:14px;line-height:1.6;outline:none;overflow-y:auto;padding:16px;position:relative;text-align:left;unicode-bidi:normal}.editor-content:focus{box-shadow:inset 0 0 0 2px #0969da}.editor-content[data-placeholder]:empty:before{color:#8c959f;content:attr(data-placeholder);pointer-events:none}.editor-content.dragging{background:#0969da0d;border:2px dashed #0969da}.drag-overlay{align-items:center;background:#0969da1a;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:46px;z-index:10}.drag-message{color:#0969da;text-align:center}.drag-icon{font-size:48px;margin-bottom:12px}.editor-content h1{font-size:28px;margin:24px 0 16px;padding-bottom:8px}.editor-content h1,.editor-content h2{border-bottom:1px solid #d0d7de;font-weight:600}.editor-content h2{font-size:24px;margin:20px 0 12px;padding-bottom:4px}.editor-content h3{font-size:20px;font-weight:600;margin:16px 0 8px}.editor-content h4,.editor-content h5,.editor-content h6{font-size:16px;font-weight:600;margin:12px 0 8px}.editor-content p{margin:8px 0}.editor-content blockquote{border-left:4px solid #d0d7de;color:#656d76;font-style:italic;margin:16px 0;padding:0 16px}.editor-content ol,.editor-content ul{margin:12px 0;padding-left:24px}.editor-content li{margin:4px 0}.editor-content a{color:#0969da;text-decoration:underline}.editor-content a:hover{text-decoration:none}.editor-content img{border-radius:6px;box-shadow:0 1px 3px #0000001a;height:auto;margin:12px 0;max-width:100%}.editor-content code{background:#f6f8fa;border:1px solid #d0d7de;border-radius:3px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;margin:0 2px;padding:2px 4px}.editor-content pre{background:#f6f8fa;border:1px solid #d0d7de;border-radius:6px;margin:16px 0;overflow-x:auto;padding:16px}.editor-content pre code{background:none;border:none;border-radius:0;font-size:13px;line-height:1.45;margin:0;padding:0}.editor-content input[type=checkbox]{margin-right:8px;transform:scale(1.1)}.editor-content table{border-collapse:collapse;margin:16px 0;width:100%}.editor-content td,.editor-content th{border:1px solid #d0d7de;padding:8px 12px;text-align:left}.editor-content th{background:#f6f8fa;font-weight:600}@media (max-width:768px){.editor-toolbar{gap:2px;padding:6px 8px}.toolbar-divider{display:none}.toolbar-btn{font-size:11px;min-height:24px;padding:4px 6px}.toolbar-select{font-size:11px;min-width:70px;padding:2px 6px}.editor-content{font-size:13px;padding:12px}}@media (max-width:480px){.toolbar-group{gap:1px}.toolbar-btn{font-size:10px;min-height:22px;padding:3px 5px}.toolbar-select{font-size:10px;min-width:60px}.editor-content{font-size:12px;padding:10px}}.post-detail-page{background:#f8f9fa;min-height:100%;overflow-y:auto}.post-detail-content{background:#fff;margin:0;min-height:auto;padding-bottom:40px;width:100%}.post-detail-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:16px 20px}.back-button{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.back-button:hover{background:#0056b3;transform:translateY(-1px)}.header-actions{display:flex;gap:8px}.action-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:8px 16px;transition:background .2s ease}.action-btn:hover{background:#545b62}.action-btn.danger{background:#dc3545}.action-btn.danger:hover{background:#c82333}.post-title-section{border-bottom:2px solid #e9ecef;padding:30px 30px 20px}.post-title{color:#212529;font-size:28px;font-weight:700;line-height:1.3;margin:0 0 16px;word-break:keep-all}.post-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.meta-left,.meta-right{align-items:center;display:flex;gap:12px}.post-author,.post-date{align-items:center;color:#6c757d;display:flex;font-size:14px;gap:4px}.post-comments,.post-views{align-items:center;color:#868e96;display:flex;font-size:13px;gap:4px}.solve-status{margin-top:8px}.solve-badge{align-items:center;border-radius:16px;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 12px}.solve-badge.solved{background:#d4edda;color:#155724}.solve-badge.unsolved{background:#fff3cd;color:#856404}.post-like-btn{align-items:center;background:#f8f9fa;border:1px solid #0000;border-radius:16px;color:#868e96;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;padding:4px 8px;transition:all .2s ease}.post-like-btn:hover{background:#e9ecef;border-color:#dee2e6;transform:translateY(-1px)}.post-like-btn.liked{background:#fff5f5;border-color:#f8d7da;color:#dc3545}.post-like-btn.liked:hover{background:#f8d7da}.post-like-btn.loading{animation:pulse 1.5s ease-in-out infinite;cursor:wait;opacity:.7}.post-like-btn:disabled{cursor:not-allowed;opacity:.6}.like-icon{font-size:14px}.like-count{font-weight:600}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.post-content-section{border-bottom:2px solid #e9ecef;padding:30px}.post-content{color:#212529;font-size:16px;line-height:1.8;white-space:pre-wrap;word-break:break-word}.post-content p{margin:0 0 12px;min-height:1.8em}.post-content p:last-child{margin-bottom:0}.no-content{color:#6c757d;font-style:italic;padding:40px 0;text-align:center}.comments-section{padding:30px}.comments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.comments-title{align-items:center;color:#212529;display:flex;font-size:20px;font-weight:600;gap:8px;margin:0}.comment-write-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:background .2s ease}.comment-write-btn:hover{background:#218838}.comments-list{display:flex;flex-direction:column;gap:20px}.comment-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;transition:all .2s ease}.comment-item:hover{background:#f1f3f4;border-color:#dee2e6}.comment-item.first-comment{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-color:#90caf9}.comment-item.reply-comment{background:#fafafa;border-left:3px solid #2196f3}.comment-level-0{background:#fff}.comment-level-1{background:#f8f9ff;border-left:3px solid #2196f3}.comment-level-2{background:#f0f8f0;border-left:3px solid #4caf50}.comment-level-3{background:#fff8f0;border-left:3px solid #ff9800}.comment-level-4{background:#fff0f8;border-left:3px solid #e91e63}.comment-level-5{background:#f8f0ff;border-left:3px solid #9c27b0}.comment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.comment-header-left{gap:12px}.comment-header-left,.comment-header-right{align-items:center;display:flex}.comment-author,.comment-date{align-items:center;color:#6c757d;display:flex;font-size:13px;gap:4px}.comment-likes{align-items:center;color:#868e96;display:flex;font-size:12px;gap:4px}.comment-content{color:#212529;font-size:15px;line-height:1.6;margin-bottom:12px;white-space:pre-wrap;word-break:break-word}.comment-content p{margin:0 0 8px;min-height:1.6em}.comment-content p:last-child{margin-bottom:0}.comment-actions{display:flex;gap:8px;margin-top:12px}.comment-action-btn{background:#e9ecef;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:12px;padding:4px 12px;transition:all .2s ease}.comment-action-btn:hover{background:#dee2e6;color:#495057}.comment-action-btn.disabled{color:#999;cursor:not-allowed;opacity:.5}.comment-action-btn.disabled:hover{background:#e9ecef;color:#999}.reply-indicator{align-items:center;display:flex;margin-right:8px}.reply-icon{color:#2196f3;font-size:14px;font-weight:700;margin-right:2px}.comment-level{background:#2196f3;border-radius:10px;color:#fff;font-size:10px;font-weight:600;padding:2px 6px}.has-reply-indicator{background:#d4edda;border-radius:4px;color:#28a745;font-size:10px;margin-left:auto;padding:2px 6px}.comment-menu-container{position:relative}.comment-menu-btn{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:16px;padding:4px 8px;transition:all .2s ease}.comment-menu-btn:hover{background:#f8f9fa;color:#495057}.comment-menu-dropdown{background:#fff;border:1px solid #e9ecef;border-radius:4px;box-shadow:0 2px 8px #00000026;min-width:120px;position:absolute;right:0;top:100%;z-index:1000}.menu-item{align-items:center;background:none;border:none;color:#495057;display:flex;font-size:13px;justify-content:space-between;padding:8px 12px;text-align:left;transition:background .2s ease;width:100%}.menu-item:hover{background:#f8f9fa}.menu-item.delete{color:#dc3545}.menu-item.delete:hover{background:#f8f9fa;color:#c82333}.form-inputs{gap:16px;margin-bottom:20px}.input-group{gap:6px}.input-group label{font-size:14px;font-weight:500}.input-group input,.input-group textarea{border:1px solid #ced4da;border-radius:4px;padding:10px 12px;resize:vertical}.input-group input:focus,.input-group textarea:focus{box-shadow:0 0 0 2px #007bff40}.cancel-btn,.submit-btn{border-radius:4px;font-size:12px;font-weight:500;padding:6px 14px}.submit-btn{background:#28a745}.submit-btn:hover:not(:disabled){background:#218838}.comment-form{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:24px;padding:20px}.comment-form .form-header{margin-bottom:16px}.comment-form .form-header h3{color:#212529;font-size:16px;font-weight:600;margin:0}.post-edit-form{background:#e8f4fd;border:1px solid #b3d9f7;border-radius:8px;margin:20px;padding:30px}.post-edit-form .form-header{margin-bottom:24px;text-align:center}.post-edit-form .form-header h2{color:#0056b3;font-size:20px;font-weight:600;margin:0}.post-edit-form .form-inputs{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.post-edit-form .input-group{display:flex;flex-direction:column;gap:8px}.post-edit-form .input-group label{color:#0056b3;font-size:15px;font-weight:600}.post-edit-form .input-group input,.post-edit-form .input-group textarea{background:#fff;border:2px solid #b3d9f7;border-radius:6px;font-size:14px;padding:12px 16px;transition:border-color .2s ease}.post-edit-form .input-group input:focus,.post-edit-form .input-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.post-edit-form .input-group textarea{min-height:200px;resize:vertical}.post-edit-form .form-actions{display:flex;gap:16px;justify-content:center}.post-edit-form .cancel-btn,.post-edit-form .submit-btn{font-size:15px;font-weight:600;min-width:120px;padding:12px 24px}.reply-form{background:#f0f8ff;border:1px solid #b3d9f7;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-top:16px;padding:16px}.reply-form .form-header{margin-bottom:12px}.reply-form .form-header h4{color:#007bff;font-size:14px;font-weight:600;margin:0}.reply-form .form-inputs{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.reply-form .input-group{display:flex;flex-direction:column;gap:6px}.reply-form .input-group label{color:#495057;font-size:13px;font-weight:500}.reply-form .input-group input,.reply-form .input-group textarea{border:1px solid #ced4da;border-radius:4px;font-size:13px;padding:8px 12px;transition:border-color .2s ease}.reply-form .input-group input:focus,.reply-form .input-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.reply-form .form-actions{display:flex;gap:8px;justify-content:flex-end}.reply-form .cancel-btn,.reply-form .submit-btn{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 16px;transition:all .2s ease}.reply-form .cancel-btn{background:#6c757d;color:#fff}.reply-form .cancel-btn:hover:not(:disabled){background:#545b62}.reply-form .submit-btn{background:#007bff;color:#fff}.reply-form .submit-btn:hover:not(:disabled){background:#0056b3}.reply-form .cancel-btn:disabled,.reply-form .submit-btn:disabled{cursor:not-allowed;opacity:.6}.reply-form .submit-btn:disabled{background:#6c757d}.comment-edit-form{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:16px}.comment-edit-form .form-inputs{margin-bottom:16px}.comment-edit-form .input-group{margin-bottom:12px}.comment-edit-form .input-group:last-child{margin-bottom:0}.empty-message,.error-message,.loading-message{background:#fff;box-shadow:0 2px 4px #0000001a;margin:20px;padding:60px 20px}.loading-spinner{border:4px solid #0000;border-top-color:#3498db;height:48px;margin-bottom:16px;transform-origin:center center;width:48px}.comments-loading{color:#6c757d;padding:40px 0;text-align:center}.comments-loading .loading-spinner{border:3px solid #0000;border-top-color:#3498db;height:40px;margin-bottom:12px;width:40px}.no-comments{color:#6c757d;font-style:italic;padding:40px 0;text-align:center}.error-message p{color:#dc3545;font-weight:500;margin-bottom:16px}.retry-btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 20px;transition:background .2s ease}.retry-btn:hover{background:#0056b3}.empty-message p{color:#6c757d;font-size:16px}.admin-notice{align-items:center;color:#ffc107;display:inline-flex;font-size:16px;margin-left:8px}.admin-badge{color:#ffc107;font-size:12px;margin-left:4px;opacity:.8}.login-required{background:#95a5a6;border-radius:8px;color:#fff;display:inline-block;font-size:13px;font-weight:600;padding:8px 16px;text-align:center}@media (max-width:800px){.post-detail-header{padding:12px 16px}.back-button{font-size:13px;padding:6px 12px}.header-actions{gap:6px}.action-btn{font-size:12px;padding:6px 12px}.post-detail-content{margin:0}.post-title-section{padding:20px 16px 16px}.post-title{font-size:22px}.post-meta{align-items:flex-start;flex-direction:column;gap:8px}.meta-left,.meta-right{gap:8px}.post-content-section{padding:20px 16px}.post-content{font-size:15px}.comments-section{padding:20px 16px}.comments-header{align-items:flex-start;flex-direction:column;gap:12px}.comments-title{font-size:18px}.comment-item{padding:16px}}@media (max-width:500px){.post-title{font-size:20px}.post-content{font-size:14px}.comments-title{font-size:16px}.comment-content{font-size:14px}.comment-form{padding:16px}.form-actions{flex-direction:column;gap:8px}.cancel-btn,.submit-btn{padding:10px;width:100%}.comment-header{flex-wrap:wrap;gap:8px}.comment-header-left{flex:1 1;min-width:0}.comment-menu-dropdown{left:auto;min-width:100px;right:0}.reply-form{padding:12px}.reply-form .form-actions{flex-direction:column;gap:6px}.reply-form .cancel-btn,.reply-form .submit-btn{padding:8px;width:100%}.comment-level-1,.comment-level-2,.comment-level-3,.comment-level-4,.comment-level-5{margin-left:16px!important}.reply-indicator{margin-right:4px}.reply-icon{font-size:12px}.comment-level{font-size:9px;padding:1px 4px}}@media (max-width:400px){.comment-level-1,.comment-level-2,.comment-level-3,.comment-level-4,.comment-level-5{margin-left:8px!important}.comment-author,.comment-date,.comment-likes{font-size:11px}}.post-write-page{background:#f8f9fa;min-height:100%;overflow-y:auto}.post-write-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:16px 20px}.post-write-header .back-button{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.post-write-header .back-button:hover{background:#0056b3;transform:translateY(-1px)}.post-write-header .page-title{color:#212529;font-size:18px;font-weight:600;margin:0}.permission-error{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;margin:20px;padding:60px 20px;text-align:center}.permission-error .error-icon{font-size:48px;margin-bottom:16px;opacity:.7}.permission-error .error-message h3{color:#e74c3c;font-size:20px;font-weight:600;margin:0 0 12px}.permission-error .error-message p{color:#666;font-size:14px;line-height:1.5;margin:0 0 24px;white-space:pre-line}.permission-error .back-to-list-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:background .2s ease}.permission-error .back-to-list-btn:hover{background:#2980b9}.post-write-content{padding:20px 20px 40px;width:100%}.post-write-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0;padding:30px;width:100%}.form-inputs{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.input-group{gap:8px}.input-group label{color:#495057;font-size:15px;font-weight:600}.input-group input,.input-group textarea{border:2px solid #ced4da;border-radius:6px;font-family:inherit;font-size:14px;padding:12px 16px;transition:border-color .2s ease}.input-group input:focus,.input-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff40;outline:none}.input-group input:disabled,.input-group textarea:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.input-group textarea{line-height:1.6;min-height:300px;resize:vertical}.form-actions{gap:16px;justify-content:center}.cancel-btn,.submit-btn{border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:600;min-width:120px;padding:12px 32px;transition:all .2s ease}.cancel-btn{background:#6c757d}.cancel-btn:hover:not(:disabled){background:#545b62}.submit-btn{background:#007bff;color:#fff}.submit-btn:hover:not(:disabled){background:#0056b3}.cancel-btn:disabled,.submit-btn:disabled{cursor:not-allowed;opacity:.6}.submit-btn:disabled{background:#6c757d}.author-info{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#495057;display:flex;font-size:14px;gap:8px;padding:12px 16px}.user-role{color:#6c757d;font-size:12px;font-weight:500}@media (max-width:768px){.post-write-header{flex-wrap:wrap;gap:12px;padding:12px 16px}.post-write-header .back-button{font-size:13px;padding:6px 12px}.post-write-header .page-title{font-size:16px;order:-1;text-align:center;width:100%}.post-write-content{padding:16px}.post-write-form{padding:20px}.form-inputs{gap:20px;margin-bottom:24px}.input-group textarea{min-height:250px}.form-actions{flex-direction:column;gap:12px}.cancel-btn,.submit-btn{padding:14px;width:100%}}@media (max-width:480px){.post-write-header .page-title{font-size:14px}.post-write-form{padding:16px}.input-group label{font-size:14px}.input-group input,.input-group textarea{font-size:13px;padding:10px 12px}.input-group textarea{min-height:200px}}.board-page{display:flex;min-height:calc(100vh - 64px);position:relative}.board-main{display:flex;flex:1 1;flex-direction:column;margin-left:0;overflow-y:auto}@media (max-width:800px){.board-page{min-height:calc(100vh - 80px)}.board-main{width:100%}}.settings-container{margin:0 auto;max-width:800px}.settings-header{margin-bottom:32px;text-align:center}.settings-header h2{color:#2c3e50;font-size:1.8rem;margin-bottom:8px}.settings-header p{color:#666;font-size:14px;margin-bottom:16px}.config-file-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.btn-export,.btn-import{align-items:center;background:#34495e;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:background .2s ease}.btn-export:hover{background:#2c3e50}.btn-import{background:#16a085}.btn-import:hover{background:#138d75}.config-file-info{background:#e8f4fd;border:1px solid #b8d4f0;border-radius:8px;margin:20px 0;padding:20px;text-align:left}.config-file-info h4{color:#06c;font-size:16px;margin:0 0 15px}.config-file-info .info-content{color:#333;line-height:1.6}.config-file-info p{margin:0 0 12px}.config-file-info ol{margin:12px 0;padding-left:20px}.config-file-info li{margin:8px 0}.config-file-info code{background:#f1f3f4;border-radius:3px;font-family:Monaco,Consolas,monospace;font-size:13px;padding:2px 6px}.config-file-info .info-note{background:#fff3cd;border:1px solid #ffeaa7;border-radius:5px;color:#856404;font-size:14px;margin:15px 0 0;padding:12px}.settings-form{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:24px}.setting-group,.settings-form{margin-bottom:24px}.setting-group:last-child{margin-bottom:0}.setting-group label{color:#2c3e50;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.setting-input{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.setting-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.setting-help{color:#666;display:block;font-size:12px;line-height:1.4;margin-top:4px}.settings-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:32px}.btn-reset,.btn-save,.btn-test{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;min-width:100px;padding:12px 24px;transition:all .2s ease}.btn-test{background:#f39c12;color:#fff}.btn-test:hover{background:#e67e22}.btn-reset{background:#95a5a6;color:#fff}.btn-reset:hover{background:#7f8c8d}.btn-save{background:#3498db;color:#fff}.btn-save:hover{background:#2980b9}.save-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:24px;padding:12px 16px;text-align:center}.save-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.save-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.save-message.auto-save{animation:slideInRight .3s ease-out;min-width:250px;position:fixed;right:20px;top:20px;z-index:9999}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.current-config{background:#f8f9fa;border-radius:12px;padding:20px}.current-config h3{color:#2c3e50;font-size:1.2rem;margin-bottom:16px}.config-display{display:flex;flex-direction:column;gap:12px}.config-item{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 0}.config-item:last-child{border-bottom:none}.config-label{color:#666;font-size:14px;font-weight:500}.config-value{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#2c3e50;font-family:monospace;font-size:14px;font-weight:600;padding:4px 8px}.servers-section{margin-bottom:32px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h3{color:#2c3e50;font-size:1.3rem;margin:0}.btn-add-server{background:#27ae60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:background .2s ease}.btn-add-server:hover{background:#219a52}.btn-cancel{background:#95a5a6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px}.btn-cancel:hover{background:#7f8c8d}.servers-list{display:flex;flex-direction:column;gap:12px}.server-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px;transition:all .2s ease}.server-card.active{border-color:#27ae60;box-shadow:0 2px 8px #27ae601a}.server-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.server-info h4{color:#2c3e50;font-size:1.1rem;margin:0 0 4px}.server-url{color:#666;font-family:monospace;font-size:13px}.server-actions{display:flex;gap:6px}.btn-toggle{background:#fff;border:1px solid #95a5a6;border-radius:4px;color:#666;cursor:pointer;font-size:11px;padding:4px 8px;transition:all .2s ease}.btn-toggle.active{background:#27ae60;border-color:#27ae60;color:#fff}.btn-delete,.btn-edit,.btn-test-small{border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;padding:4px 8px}.btn-test-small{background:#f39c12}.btn-edit{background:#3498db}.btn-delete{background:#e74c3c}.server-details{color:#666;display:flex;font-size:12px;gap:16px}.server-form-section{background:#f8f9fa;border-radius:12px;margin-bottom:24px;padding:20px}.form-row{margin-bottom:20px}.form-row .setting-group{flex:1 1}.checkbox-group{display:flex;flex-direction:column;justify-content:center}.checkbox-label{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px}.setting-checkbox{cursor:pointer;height:16px;width:16px}.settings-tabs{border-bottom:1px solid #e0e0e0;display:flex;gap:4px;margin-top:16px}.tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.tab-btn.active{border-bottom-color:#3498db}.tab-btn.active,.tab-btn:hover{background:#3498db0d;color:#3498db}.table-settings-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:24px;padding:24px}.toggle-switch{display:inline-block;height:24px;position:relative;width:50px}.toggle-switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;border-radius:24px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.3s}.slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;width:18px}input:checked+.slider{background-color:#3498db}input:checked+.slider:before{transform:translateX(26px)}.filter-settings{background:#f8f9fa;border-radius:8px;margin-top:16px;padding:16px}.filter-mode{margin-bottom:16px}.filter-mode label{color:#2c3e50;display:block;font-weight:600;margin-bottom:8px}.mode-select{background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;padding:8px 12px;width:100%}.case-sensitive{margin-bottom:16px}.case-sensitive label{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;gap:8px}.input-with-button{display:flex;gap:8px}.keyword-input-field{border:1px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:14px;padding:10px 12px}.add-keyword-btn{background:#27ae60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px}.add-keyword-btn:hover{background:#219a52}.keywords-list{margin-top:16px}.keywords-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.keywords-header span{color:#2c3e50;font-size:14px;font-weight:600}.clear-all-btn{background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:4px 8px}.clear-all-btn:hover{background:#c0392b}.keywords-tags{display:flex;flex-wrap:wrap;gap:8px}.keyword-tag{align-items:center;background:#3498db;border-radius:16px;color:#fff;display:inline-flex;font-size:13px;gap:6px;padding:6px 10px}.remove-keyword-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:16px;line-height:1;margin-left:4px;padding:0}.remove-keyword-btn:hover{background:#fff3;border-radius:50%}.columns-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:16px}.column-checkbox{align-items:center;background:#f8f9fa;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background .2s ease}.column-checkbox:hover{background:#e9ecef}.column-checkbox span{color:#2c3e50;font-size:14px}.theme-settings{margin-top:16px}.theme-settings label{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:12px}.max-themes{align-items:center;display:flex;gap:12px;margin-top:12px}.max-themes label{font-size:14px;font-weight:600;margin:0}.number-input{border:1px solid #e0e0e0;border-radius:4px;font-size:14px;padding:6px 8px;width:80px}.color-settings{display:flex;flex-wrap:wrap;gap:3px;margin-top:16px}.color-item{align-items:center;display:flex;gap:12px}.color-item label{color:#2c3e50;font-size:14px;font-weight:600;min-width:50px}.color-input{border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;height:22px;padding:2px;width:50px}@media (max-width:800px){.settings-container{margin:0;max-width:none}.settings-header h2{font-size:1.5rem}.section-header{align-items:stretch;flex-direction:column;gap:12px}.server-header{flex-direction:column;gap:8px}.server-actions{justify-content:flex-start}.server-details{flex-direction:column;gap:4px}.form-row{flex-direction:column;gap:16px}.settings-form{padding:16px}.settings-actions{align-items:stretch;flex-direction:column}.btn-reset,.btn-save,.btn-test{min-width:auto}.settings-tabs{flex-direction:column;gap:8px}.tab-btn{padding:10px 16px;text-align:left}.columns-grid{grid-template-columns:1fr}.color-settings{flex-direction:column;gap:12px}.input-with-button{flex-direction:column;gap:8px}.add-keyword-btn{align-self:stretch}}.board-management-page{margin:0 auto;max-width:1200px;padding:20px}.order-input{border:1px solid #ddd;border-radius:4px;font-size:14px;font-weight:500;padding:4px 8px;text-align:center;transition:border-color .2s ease;width:60px}.order-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.order-input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.board-order{text-align:center}.add-board-button{align-items:center;background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:12px 20px;transition:background .2s ease}.add-board-button:hover:not(:disabled){background:#2980b9}.add-board-button:disabled{background:#95a5a6;cursor:not-allowed}.board-form-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:24px}.board-form h3{border-bottom:1px solid #e9ecef;color:#2c3e50;font-size:20px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.form-group label{color:#2c3e50;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db1a;outline:none}.form-group input:disabled{background:#f8f9fa;color:#666;cursor:not-allowed}.form-group textarea{min-height:80px;resize:vertical}.form-group small{color:#666;display:block;font-size:12px;margin-top:4px}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1 1}.form-actions{border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.cancel-button,.submit-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.cancel-button{background:#f8f9fa;border:1px solid #ddd;color:#666}.cancel-button:hover{background:#e9ecef;color:#495057}.submit-button{background:#27ae60;color:#fff}.submit-button:hover{background:#219a52}.boards-table-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.boards-table{border-collapse:collapse;width:100%}.boards-table td,.boards-table th{border-bottom:1px solid #e9ecef;padding:16px 12px;text-align:left}.boards-table th{color:#2c3e50;font-size:14px;font-weight:600}.boards-table tbody tr:hover,.boards-table th{background:#f8f9fa}.boards-table tbody tr:last-child td{border-bottom:none}.board-id{color:#7f8c8d;font-family:Courier New,monospace;font-size:13px;font-weight:500}.board-name{color:#2c3e50;font-weight:600}.board-description{word-wrap:break-word;color:#666;font-size:14px;max-width:200px}.permission-grade{text-align:center}.grade-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.grade-bronze{background:#f39c12}.actions{text-align:center;white-space:nowrap}.delete-button,.edit-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:12px;gap:4px;margin:0 4px;padding:8px 12px;transition:all .2s ease}.edit-button{background:#3498db;color:#fff}.edit-button:hover:not(:disabled){background:#2980b9}.delete-button{background:#e74c3c;color:#fff}.delete-button:hover:not(:disabled){background:#c0392b}.delete-button:disabled,.edit-button:disabled{background:#bdc3c7;color:#7f8c8d;cursor:not-allowed}@media (max-width:768px){.board-management-page{padding:16px}.page-header{align-items:flex-start;flex-direction:column;gap:12px}.page-header h2{font-size:20px}.board-form-container{padding:20px}.form-row{flex-direction:column;gap:12px}.form-actions{flex-direction:column;gap:8px}.cancel-button,.submit-button{justify-content:center;width:100%}.boards-table-container{background:#0000;border:none;box-shadow:none}.boards-table{display:none}.mobile-board-cards{display:block}}@media (max-width:480px){.board-management-page{padding:12px}.page-header h2{font-size:18px}.add-board-button{font-size:13px;padding:10px 16px}.board-form-container{padding:16px}.board-form h3{font-size:18px}}.mobile-board-cards{display:none}@media (max-width:768px){.mobile-board-cards{display:block}.board-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:12px;padding:16px}.board-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.board-card-title{color:#2c3e50;font-weight:600;margin-bottom:4px}.board-card-id{color:#7f8c8d;font-family:Courier New,monospace;font-size:12px}.board-card-description{color:#666;font-size:14px;margin:8px 0}.board-card-permissions{display:flex;gap:12px;margin:12px 0}.permission-item{flex:1 1}.permission-label{color:#666;font-size:12px;margin-bottom:4px}.board-card-actions{display:flex;gap:8px;justify-content:flex-end}}.user-management-page{margin:0 auto;max-width:1400px;padding:20px}.page-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.page-header h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0}.user-stats{display:flex;gap:16px}.stat-item{background:#f8f9fa;border-radius:20px;color:#495057;font-size:14px;font-weight:500;padding:8px 16px}.empty-message,.error-message,.loading-message{border-radius:8px;margin:20px 0;padding:40px 20px;text-align:center}.loading-message{background:#f8f9fa;color:#666;font-size:16px}.error-message{background:#fee;border:1px solid #fadbd8;color:#e74c3c;font-size:15px}.empty-message{background:#f8f9fa;color:#666;font-size:16px}.filters-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;gap:20px;margin-bottom:20px;padding:20px}.search-box{flex:1 1}.search-box input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:border-color .2s ease;width:100%}.search-box input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db1a;outline:none}.filter-selects{display:flex;gap:12px}.filter-selects select{background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;min-width:140px;padding:12px 16px}.filter-selects select:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db1a;outline:none}.users-table-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;overflow:hidden}.users-table{border-collapse:collapse;font-size:14px;width:100%}.users-table td,.users-table th{border-bottom:1px solid #e9ecef;padding:16px 12px;text-align:left;vertical-align:middle}.users-table th{color:#2c3e50;font-size:14px;font-weight:600;position:-webkit-sticky;position:sticky;top:0}.users-table tbody tr:hover,.users-table th{background:#f8f9fa}.users-table tbody tr:last-child td{border-bottom:none}.users-table .inactive-user{opacity:.6}.user-id{color:#2c3e50;font-family:Courier New,monospace;font-weight:500;position:relative}.current-user-badge{background:#3498db;border-radius:12px;color:#fff;display:inline-block;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:10px;font-weight:500;margin-left:8px;padding:2px 8px}.nickname{color:#2c3e50;font-weight:500}.email{color:#666;font-size:13px}.grade-cell,.role-cell,.status-cell{text-align:center}.grade-badge,.role-badge,.status-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;padding:4px 12px;text-align:center}.role-user{background:#ecf0f1;color:#2c3e50}.role-moderator{background:#f39c12;color:#fff}.role-admin{background:#e74c3c;color:#fff}.grade-newbie{background:#ecf0f1;color:#2c3e50}.grade-bronze{background:#d35400;color:#fff}.grade-silver{background:#95a5a6;color:#fff}.grade-gold{background:#f1c40f;color:#2c3e50}.grade-platinum{background:#1abc9c;color:#fff}.grade-diamond{background:#9b59b6;color:#fff}.status-badge.active{background:#d5f4e6;color:#27ae60}.status-badge.inactive{background:#fadbd8;color:#e74c3c}.created-date{color:#666;font-size:13px}.actions{min-width:280px;width:280px}.action-buttons{gap:8px}.grade-select,.role-select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:11px;min-width:80px;padding:6px 10px}.role-select:disabled{background:#f8f9fa;color:#999;cursor:not-allowed}.toggle-button{border:none;border-radius:4px;cursor:pointer;font-size:10px;font-weight:500;min-width:60px;padding:6px 10px;transition:all .2s ease}.toggle-button.activate{background:#27ae60;color:#fff}.toggle-button.deactivate{background:#e74c3c;color:#fff}.toggle-button:hover:not(:disabled){opacity:.8}.toggle-button:disabled{background:#bdc3c7;color:#7f8c8d;cursor:not-allowed}.help-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;margin-top:30px;padding:24px}.help-section h3{color:#2c3e50;font-size:18px;margin:0 0 16px}.help-section ul{color:#495057;margin:0;padding-left:20px}.help-section li{line-height:1.5;margin-bottom:8px}.help-section strong{color:#2c3e50}@media (max-width:1200px){.users-table{font-size:13px}.users-table td,.users-table th{padding:12px 8px}.actions{min-width:240px;width:240px}.action-buttons{gap:6px}.grade-select,.role-select{font-size:10px;min-width:70px}}@media (max-width:768px){.user-management-page{padding:16px}.page-header{align-items:flex-start;flex-direction:column;gap:12px}.page-header h2{font-size:20px}.user-stats{gap:12px}.filters-container{flex-direction:column;gap:12px;padding:16px}.filter-selects{flex-direction:column;gap:8px}.filter-selects select{min-width:0;min-width:auto}.users-table-container{overflow-x:auto}.users-table{font-size:12px;min-width:800px}.users-table td,.users-table th{padding:10px 6px}.help-section{padding:16px}.help-section h3{font-size:16px}}@media (max-width:480px){.user-management-page{padding:12px}.page-header h2{font-size:18px}.stat-item{font-size:12px;padding:6px 12px}.filters-container{padding:12px}.users-table{font-size:11px;min-width:700px}.users-table td,.users-table th{padding:8px 4px}.actions{min-width:200px;width:200px}.action-buttons{flex-direction:column;gap:4px}.grade-select,.role-select,.toggle-button{font-size:9px;width:100%}.help-section{padding:12px}.delete-user-button{font-size:9px}}.delete-user-button{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s ease}.delete-user-button:hover{background:#c82333;box-shadow:0 2px 4px #dc35454d;transform:translateY(-1px)}.delete-user-button:active{transform:translateY(0)}.action-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.menu-management{background-color:#f5f5f5;min-height:100vh;padding:20px}.menu-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.menu-title{color:#2c3e50;font-size:2rem;font-weight:700}.menu-subtitle{color:#666;margin-top:5px}.save-btn{align-items:center;background-color:#28a745;border:none;border-radius:6px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 24px;transition:background-color .3s}.save-btn:hover{background-color:#218838}.save-btn:disabled{background-color:#6c757d;cursor:not-allowed}.grade-sections{display:flex;flex-direction:column;gap:24px}.grade-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.grade-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.grade-header.guest{background:linear-gradient(135deg,#6c757d,#495057)}.grade-header.bronze{background:linear-gradient(135deg,#cd7f32,#8b4513)}.grade-header.silver{background:linear-gradient(135deg,silver,grey)}.grade-header.gold{background:linear-gradient(135deg,gold,#b8860b);color:#333}.grade-header.platinum{background:linear-gradient(135deg,#e5e4e2,#71706e)}.grade-header.diamond{background:linear-gradient(135deg,#b9f2ff,#0891b2)}.grade-info{align-items:center;display:flex;gap:12px}.grade-icon{font-size:1.5rem}.grade-name{font-size:1.25rem;font-weight:600}.grade-level,.menu-count{font-size:.9rem;opacity:.9}.menu-content{padding:24px}.menu-list{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.menu-item{background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;padding:16px;transition:all .3s;-webkit-user-select:none;user-select:none}.menu-item:hover{background-color:#e3f2fd;border-color:#80bdff}.menu-item.enabled{background-color:#d4edda;border-color:#28a745}.menu-item.enabled:hover{background-color:#c3e6cb;border-color:#218838}.menu-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.menu-item-info{align-items:center;display:flex;gap:8px}.menu-item-icon{font-size:1.2rem}.menu-item-name{color:#2c3e50;font-weight:600}.menu-toggle{background-color:#ccc;border:none;border-radius:12px;cursor:pointer;height:24px;position:relative;transition:background-color .3s;width:44px}.menu-toggle.enabled{background-color:#28a745}.menu-toggle-slider{background-color:#fff;border-radius:50%;height:20px;left:2px;position:absolute;top:2px;transition:transform .3s;width:20px}.menu-toggle.enabled .menu-toggle-slider{transform:translateX(20px)}.menu-item-description{color:#666;font-size:.9rem;line-height:1.4;margin-bottom:12px}.menu-item-path{background-color:#f1f3f4;border-radius:4px;color:#6c757d;font-family:Courier New,monospace;font-size:.8rem;padding:4px 8px}.permission-panel{background-color:#e8f4fd;border-radius:8px;margin-bottom:24px;padding:20px}.permission-title{align-items:center;color:#1976d2;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin-bottom:16px}.permission-actions{display:flex;gap:12px;margin-bottom:16px}.permission-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:background-color .3s}.enable-all-btn{background-color:#28a745;color:#fff}.enable-all-btn:hover{background-color:#218838}.disable-all-btn{background-color:#dc3545;color:#fff}.disable-all-btn:hover{background-color:#c82333}.reset-btn{background-color:#6c757d;color:#fff}.reset-btn:hover{background-color:#5a6268}.status-message{align-items:center;border-radius:6px;display:flex;gap:8px;margin-bottom:20px;padding:12px 16px}.status-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}@media (min-width:1200px){.menu-list{gap:20px;grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.menu-management{padding:16px}.menu-header{align-items:flex-start;flex-direction:column;gap:16px}.menu-title{font-size:1.5rem}.menu-list{gap:12px;grid-template-columns:1fr}.permission-actions{flex-direction:column}.permission-btn{width:100%}.grade-header{padding:16px 20px}.grade-info{align-items:flex-start;flex-direction:column;gap:4px}}@media (max-width:480px){.menu-content,.permission-panel{padding:16px}.menu-item{padding:12px}.menu-item-header{align-items:flex-start;flex-direction:column;gap:8px}}.admin-page{background:#f8f9fa;min-height:100vh;padding:0}.access-denied{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:40px;text-align:center}.access-denied-icon{font-size:64px;margin-bottom:20px;opacity:.7}.access-denied h2{color:#e74c3c;font-size:24px;font-weight:600;margin:0 0 12px}.access-denied p{color:#666;font-size:16px;margin:0}.admin-header{background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;justify-content:space-between;padding:20px 30px}.admin-header,.admin-title{align-items:center;display:flex}.admin-title{gap:12px}.admin-icon{font-size:28px}.admin-title h1{color:#2c3e50;font-size:24px;font-weight:600;margin:0}.admin-info{align-items:center;display:flex}.admin-role{background:#e3f2fd;border-radius:20px;color:#1976d2;font-size:14px;font-weight:500;padding:8px 16px}.admin-tabs{background:#fff;border-bottom:1px solid #e9ecef;display:flex;gap:2px;padding:0 30px}.admin-tab{align-items:center;background:#0000;border:none;border-radius:8px 8px 0 0;color:#666;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;padding:16px 20px;position:relative;transition:all .2s ease}.admin-tab:hover{background:#f8f9fa;color:#2c3e50}.admin-tab.active{background:#f8f9fa;border-bottom:3px solid #3498db;color:#3498db}.tab-icon{font-size:16px}.tab-label{white-space:nowrap}.admin-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0 30px 30px;min-height:calc(100vh - 140px);overflow:hidden}@media (max-width:768px){.admin-header{align-items:flex-start;flex-direction:column;gap:12px;padding:16px 20px}.admin-title h1{font-size:20px}.admin-tabs{flex-wrap:nowrap;overflow-x:auto;padding:0 20px}.admin-tab{flex-shrink:0;padding:12px 16px}.admin-content{margin:0 20px 20px}}@media (max-width:480px){.admin-header{padding:12px 16px}.admin-title{gap:8px}.admin-icon{font-size:24px}.admin-title h1{font-size:18px}.admin-tabs{padding:0 16px}.admin-tab{padding:10px 12px}.admin-tab,.tab-icon{font-size:14px}.admin-content{border-radius:6px;margin:0 16px 16px}}.signup-page{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.signup-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.signup-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:24px 28px 16px}.signup-header h2{color:#212529;font-size:24px;font-weight:700;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.close-btn:hover{background:#f8f9fa;color:#495057}.signup-form{padding:24px 28px 28px}.form-group label{color:#495057;margin-bottom:6px}.form-group input{background:#fff;border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input.valid{background:#f8fff9;border-color:#28a745}.form-group input.invalid{background:#fff8f8;border-color:#dc3545}.form-group input::placeholder{color:#adb5bd}.nickname-input-group{align-items:stretch;display:flex;gap:8px}.nickname-input-group input{flex:1 1}.nickname-check-btn{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;min-width:80px;padding:12px 16px;transition:all .2s ease;white-space:nowrap}.nickname-check-btn:hover:not(:disabled){background:#545b62}.nickname-check-btn:disabled{background:#adb5bd;cursor:not-allowed}.validation-message{display:block;font-size:12px;font-weight:500;margin-top:6px}.validation-message.success{color:#28a745}.validation-message.error{color:#dc3545}.submit-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:20px;padding:12px 16px;text-align:center}.submit-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.submit-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.signup-submit-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:20px;padding:14px 24px;transition:all .2s ease;width:100%}.signup-submit-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.signup-submit-btn:disabled{background:#adb5bd;cursor:not-allowed;transform:none}.switch-auth{color:#6c757d;font-size:14px;text-align:center}.switch-link{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;font-weight:600;margin-left:4px;padding:0;text-decoration:underline}.switch-link:hover{color:#0056b3}@media (max-width:768px){.signup-page{padding:10px}.signup-container{border-radius:8px;max-width:none}.signup-header{padding:20px 24px 14px}.signup-header h2{font-size:22px}.signup-form{padding:20px 24px 24px}.form-group{margin-bottom:18px}.form-group input{font-size:16px;padding:10px 14px}.nickname-input-group{gap:6px}.nickname-check-btn{font-size:12px;min-width:70px;padding:10px 12px}.signup-submit-btn{font-size:15px;padding:12px 20px}}@media (max-width:480px){.signup-page{padding:8px}.signup-container{border-radius:6px;max-height:95vh}.signup-header{padding:16px 20px 12px}.signup-header h2{font-size:20px}.close-btn{font-size:24px;height:28px;width:28px}.signup-form{padding:16px 20px 20px}.form-group{margin-bottom:16px}.form-group input{padding:10px 12px}.nickname-input-group{flex-direction:column;gap:8px}.nickname-check-btn{min-width:none;padding:10px;width:100%}.signup-submit-btn{padding:12px}.validation-message{font-size:11px}}.travel-plan-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:0}.travel-plan-container{margin:0 auto;max-width:1200px;padding:20px}.travel-plan-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.travel-plan-header h1{color:#fff;font-size:2.2rem;font-weight:700;margin:0}.create-plan-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.create-plan-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.empty-plans{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;color:#fff;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem}.empty-plans h3{font-size:1.8rem;font-weight:600;margin:0 0 10px}.empty-plans p{font-size:1.1rem;margin:0 0 30px;opacity:.8}.create-first-plan-btn{background:linear-gradient(45deg,#ff6b6b,#ee5a24);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 30px;transition:all .3s ease}.create-first-plan-btn:hover{box-shadow:0 10px 20px #0003;transform:translateY(-3px)}.travel-plans-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.travel-plan-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.travel-plan-card:before{background:linear-gradient(45deg,#0000,#ffffff1a,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s ease}.travel-plan-card:hover:before{transform:translateX(100%)}.travel-plan-card:hover{background:#ffffff26;border-color:#ffffff4d;box-shadow:0 20px 40px #0000004d;transform:translateY(-8px)}.plan-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.plan-title{color:#fff;flex:1 1;font-size:1.4rem;font-weight:600;margin:0 10px 0 0}.plan-actions{display:flex;gap:8px}.delete-btn{background:#fff3;border:none;border-radius:8px;cursor:pointer;font-size:14px;padding:8px;position:relative;transition:all .3s ease;z-index:10}.delete-btn:hover{background:#f4433666;transform:scale(1.1)}.plan-card-content{color:#fff}.plan-info{margin-bottom:15px}.info-item{align-items:center;display:flex;margin-bottom:8px}.info-icon{font-size:16px;margin-right:8px;width:20px}.info-text{font-size:14px;opacity:.9}.plan-description{background:#ffffff1a;border-radius:8px;margin-top:10px;padding:12px}.plan-description p{font-size:14px;line-height:1.4;margin:0;opacity:.8}.modal-content{max-width:500px}.form-group{margin-bottom:20px}.form-group input,.form-group textarea{padding:12px}.cancel-btn,.create-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.create-btn{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff}.create-btn:hover{background:linear-gradient(45deg,#5a6fd8,#6a4190)}@media (max-width:900px){.travel-plan-container{padding:15px}.travel-plan-header{flex-direction:column;gap:15px;text-align:center}.travel-plan-header h1{font-size:1.8rem}.travel-plans-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:600px){.travel-plan-container{padding:10px}.travel-plan-header h1{font-size:1.6rem}.travel-plans-grid{grid-template-columns:1fr}.modal-content{margin:10px;max-height:95vh}.form-row{gap:0;grid-template-columns:1fr}.empty-plans{padding:40px 15px}.empty-icon{font-size:3rem}.empty-plans h3{font-size:1.5rem}}.participants-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.add-participant-btn{background:linear-gradient(45deg,#4caf50,#45a049);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.add-participant-btn:hover{background:linear-gradient(45deg,#45a049,#3d8b40);transform:translateY(-1px)}.participants-list{background:#f8f9fa;border-radius:8px;margin-bottom:10px;max-height:200px;overflow-y:auto;padding:10px}.participant-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 12px}.participant-item:last-child{margin-bottom:0}.remove-participant-btn{background:#f443361a;border:1px solid #f443364d;border-radius:4px;color:#f44336;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .3s ease}.remove-participant-btn:hover{background:#f4433633;transform:scale(1.1)}.no-participants{background:#f8f9fa;border-radius:8px;color:#999;font-style:italic;margin-bottom:10px;padding:20px;text-align:center}.add-participant-form{background:#f0f7ff;border:1px solid #cce7ff;border-radius:8px;margin-top:10px;padding:15px}.participant-form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:10px}.participant-contact-input,.participant-name-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:8px 12px}.participant-contact-input:focus,.participant-name-input:focus{border-color:#667eea;outline:none}.participant-form-actions{display:flex;gap:8px;justify-content:flex-end}.participant-cancel-btn,.participant-save-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.participant-save-btn{background:linear-gradient(45deg,#4caf50,#45a049);color:#fff}.participant-save-btn:hover{background:linear-gradient(45deg,#45a049,#3d8b40)}.participant-cancel-btn{background:#f5f5f5;color:#666}.participant-cancel-btn:hover{background:#e0e0e0}@media (max-width:600px){.participants-header{align-items:stretch;flex-direction:column;gap:10px}.participant-form-row{gap:8px;grid-template-columns:1fr}.participant-item{align-items:stretch;flex-direction:column;gap:8px}.participant-form-actions{justify-content:stretch}.participant-cancel-btn,.participant-save-btn{flex:1 1}}@media (max-width:400px){.travel-plan-card,.travel-plan-header{padding:15px}.plan-title{font-size:1.2rem}.modal-body,.modal-footer,.modal-header{padding:15px}}.react-time-picker{display:inline-flex}.react-time-picker__wrapper{border:thin solid gray}.react-time-picker__inputGroup{min-width:calc(12px + 3.674em);padding:0 2px}.react-time-picker__inputGroup__divider,.react-time-picker__inputGroup__leadingZero{display:inline-block;font:inherit}.react-time-picker__inputGroup__input{color:currentColor;height:100%;padding:0 1px}.react-time-picker__inputGroup__input::-webkit-inner-spin-button,.react-time-picker__inputGroup__input::-webkit-outer-spin-button{appearance:none}.react-time-picker__inputGroup__amPm{-webkit-appearance:menulist;appearance:menulist;font:inherit}.react-time-picker__button:enabled:focus .react-time-picker__button__icon,.react-time-picker__button:enabled:hover .react-time-picker__button__icon{stroke:#0078d7}.react-time-picker__clock{background-color:#fff;border:thin solid #a0a096;height:200px;max-width:100vw;padding:25px;width:200px}.react-time-picker__clock--closed{display:none}.react-clock{display:block;position:relative}.react-clock,.react-clock *,.react-clock :after,.react-clock :before{box-sizing:border-box}.react-clock__face{border:1px solid #000;border-radius:50%;bottom:0;left:0;position:absolute;right:0;top:0}.react-clock__hand{bottom:0;left:50%;position:absolute;right:50%;top:0}.react-clock__hand__body{background-color:#000;position:absolute;transform:translateX(-50%)}.react-clock__mark{bottom:0;left:50%;position:absolute;right:50%;top:0}.react-clock__mark__body{background-color:#000;position:absolute;transform:translateX(-50%)}.react-clock__mark__number{left:-40px;position:absolute;text-align:center;width:80px}.react-clock__second-hand__body{background-color:red}.travel-detail-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:0}.travel-detail-container{margin:0 auto;max-width:1200px;padding:20px}.travel-detail-loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;margin-bottom:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.travel-detail-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;color:#fff;margin-bottom:20px;padding:20px}.back-btn{background:#fff3;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:14px;margin-bottom:15px;padding:8px 16px;transition:all .3s ease}.back-btn:hover{background:#ffffff4d}.travel-info h1{font-size:2rem;font-weight:700;margin:0 0 10px}.travel-meta{display:flex;flex-wrap:wrap;font-size:14px;gap:20px;opacity:.9}.day-tabs{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;padding:5px 0}.day-tab{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:12px;color:#fff;cursor:pointer;min-width:120px;padding:15px 20px;text-align:center;transition:all .3s ease}.day-tab:hover{background:#ffffff26}.day-tab.active{background:#ffffff40;transform:translateY(-2px)}.day-number{font-size:16px;font-weight:600;margin-bottom:5px}.day-date{font-size:12px;margin-bottom:5px;opacity:.8}.day-budget{font-size:11px;opacity:.7}.day-activities{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:20px}.start-time-section{align-items:center;display:flex;gap:10px}.set-start-time-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(45deg,#667eea,#764ba2);border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.set-start-time-btn:hover{background:linear-gradient(45deg,#764ba2,#667eea);box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.start-time-edit{align-items:center;display:flex;gap:10px}.start-time-input{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;font-size:14px;padding:8px 12px}.start-time-input:focus{background:#ffffff4d;border-color:#ffffff80;outline:none}.cancel-start-time-btn,.save-start-time-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;padding:6px 8px;transition:all .3s ease}.save-start-time-btn:hover{background:#4caf5066;border-color:#4caf5099}.cancel-start-time-btn:hover{background:#f4433666;border-color:#f4433699}.day-header{align-items:center;color:#fff;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.day-header h2{flex:1 1;font-size:1.5rem;font-weight:600;margin:0;min-width:250px}.add-activity-btn{background:linear-gradient(45deg,#ff6b6b,#ee5a24);border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.add-activity-btn:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.add-activity-btn-bottom{background:linear-gradient(45deg,#4facfe,#00f2fe);border:none;border-radius:25px;box-shadow:0 4px 15px #4facfe4d;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;margin:20px auto 0;padding:15px 25px;transition:all .3s ease;width:-webkit-fit-content;width:fit-content}.add-activity-btn-bottom:hover{background:linear-gradient(45deg,#00f2fe,#4facfe);box-shadow:0 8px 25px #4facfe66;transform:translateY(-3px)}.add-activity-btn-bottom:active{transform:translateY(-1px)}.empty-activities{color:#fff;padding:60px 20px;text-align:center}.empty-icon{font-size:3rem;margin-bottom:20px}.empty-activities p{font-size:1.1rem;margin:0 0 20px;opacity:.8}.add-first-activity-btn{background:linear-gradient(45deg,#4facfe,#00f2fe);border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 25px;transition:all .3s ease}.add-first-activity-btn:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.activities-timeline{display:flex;flex-direction:column;gap:15px}.activity-item{background:#ffffff1a;border-radius:12px;display:flex;gap:20px;margin-bottom:8px;padding:20px;transition:all .3s ease}.activity-item:hover{background:#ffffff26;margin-bottom:20px;transform:translateX(5px)}.activity-item[draggable=true]:hover:not(.dragging):not(.drag-over){box-shadow:0 8px 25px #0000004d;cursor:grab;transform:translateY(-2px)}.activity-item[draggable=true]:active{cursor:grabbing}.activity-item.dragging{box-shadow:0 15px 35px #0006;cursor:grabbing;opacity:.6;transform:rotate(2deg) scale(1.02);transition:none!important;z-index:1000}.activity-item.drag-over{background:#fff3!important;border:2px dashed #fff9!important;margin-bottom:25px!important;transform:translateY(10px)!important}.activity-item[draggable=true]{position:relative;transition:all .3s ease}.activity-item[draggable=true]:before{color:#fff6;content:"⋮⋮";font-size:16px;left:8px;letter-spacing:-2px;line-height:.8;position:absolute;top:50%;transform:translateY(-50%)}.activities-timeline{position:relative}.activity-item:not(.dragging):not(.drag-over){transition:transform .2s ease,margin .2s ease,background .2s ease,border .2s ease}.activity-item:not(.dragging):not(.drag-over):not(:hover){background:#ffffff1a!important;border:1px solid #fff3!important;margin-bottom:8px!important;transform:none!important}.activity-item.add-form:hover,.activity-item.editing:hover{background:#ffffff1a;transform:none!important}.activity-item.add-form,.activity-item.editing{cursor:default}.activity-time{color:#fff;display:flex;flex-direction:column;flex-shrink:0;min-width:80px;text-align:center}.end-time,.start-time{font-size:18px;font-weight:600;margin-bottom:5px}.end-time.desktop-only{display:block}.end-time.mobile-only{display:none}.activity-content{align-items:center;color:#fff;display:flex;flex:1 1;flex-direction:row;gap:20px}.activity-item.editing .activity-content{align-items:stretch;flex-direction:column;gap:15px}.activity-item.editing .activity-header{flex:none}.activity-item.editing .activity-details{flex:none;justify-content:flex-start}.activity-item.editing .activity-actions-right{display:none}.activity-header{display:flex;flex:8 1;flex-direction:column;justify-content:center;min-width:0}.activity-header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.activity-header h3{flex:1 1;font-size:1.2rem;font-weight:600;margin:0}.activity-actions{align-items:center;display:flex;gap:8px}.delete-btn,.edit-btn{background:#fff3;border:none;border-radius:6px;cursor:pointer;font-size:12px;padding:6px;transition:all .3s ease}.edit-btn:hover{background:#4caf504d}.delete-btn:hover{background:#f443364d}.activity-details{align-items:center;display:flex;flex:2 1;flex-wrap:wrap;gap:15px;justify-content:flex-end}.activity-actions-right{align-items:center;display:flex;margin-left:auto}.duration-actions-row{justify-content:space-between;margin-top:10px}.duration-actions-row,.editing-header-row{align-items:flex-end;display:flex;gap:15px}.detail-item{align-items:center;display:flex;font-size:14px;gap:5px;opacity:.9}.detail-icon{font-size:12px}.activity-description{background:#ffffff1a;border-radius:8px;margin-top:10px;padding:10px}.activity-description p{font-size:14px;line-height:1.4;margin:0;opacity:.8}.activity-item.editing{background:#fff3;border:2px solid #fff6}.activity-edit-details{margin-top:15px}.edit-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.input-group{display:flex;flex:1 1;flex-direction:column;min-width:120px}.input-label{color:#ffffffe6;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.title-group{flex:2 1;min-width:200px}.duration-header-group{align-items:center;display:flex;flex-direction:column;min-width:120px}.duration-header-group .input-label{margin-bottom:8px;text-align:center}.duration-header-group .duration-input-group{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;box-sizing:border-box;display:flex;gap:5px;height:38px;padding:8px 12px}.duration-header-group .duration-input{-webkit-appearance:none;-moz-appearance:textfield;background:#0000;border:none;color:#fff;font-size:14px;font-weight:600;text-align:center;width:50px}.duration-header-group .duration-input::-webkit-inner-spin-button,.duration-header-group .duration-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.duration-header-group .duration-input:focus{outline:none}.duration-header-group .duration-input::placeholder{color:#ffffffb3}.duration-header-group span{color:#ffffffe6;font-size:12px;font-weight:600}.budget-input,.description-input,.location-input,.people-input,.title-input{background:#ffffff4d;border:1px solid #fff6;border-radius:8px;box-sizing:border-box;color:#fff;font-size:14px;height:38px;padding:8px 12px;width:100%}.people-input.disabled{border:1px solid #fff3!important;border-radius:8px!important;box-sizing:border-box!important;color:#fff9!important;font-size:14px!important;height:38px!important;padding:8px 12px!important;pointer-events:none!important;width:100%!important}.people-input.disabled,.people-input.disabled:hover{background:#ffffff1a!important;cursor:not-allowed!important}.people-input.disabled:focus,.people-input.disabled:hover{border:1px solid #fff3!important}.people-input.disabled:focus{background:#ffffff1a!important;outline:none!important}.budget-input,.people-input{-webkit-appearance:none;-moz-appearance:textfield}.budget-input::-webkit-inner-spin-button,.budget-input::-webkit-outer-spin-button,.people-input::-webkit-inner-spin-button,.people-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.title-input{font-size:16px;font-weight:600}.description-input{height:auto;min-height:38px}.input-group .rich-text-editor{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:8px}.input-group .rich-text-editor .editor-toolbar{background:#ffffff0d;border-bottom:1px solid #fff3;border-radius:8px 8px 0 0;padding:8px}.input-group .rich-text-editor .toolbar-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:4px;color:#fff;font-size:12px;padding:4px 8px}.input-group .rich-text-editor .toolbar-btn:hover{background:#fff3}.input-group .rich-text-editor .toolbar-select{background:#ffffff1a;border:1px solid #fff3;border-radius:4px;color:#fff;font-size:12px;padding:4px 8px}.input-group .rich-text-editor .editor-content{background:#ffffff0d;border-radius:0 0 8px 8px;color:#fff;padding:12px}.input-group .rich-text-editor .editor-content[data-placeholder]:empty:before{color:#ffffff80}.travel-participants{border-top:1px solid #fff3;margin-top:15px;padding-top:15px}.participants-header-detail{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.participants-info{align-items:center;display:flex;gap:8px}.participants-label{color:#fff;font-size:14px;font-weight:600}.participants-count{border-radius:12px;padding:2px 8px}.manage-participants-btn,.participants-count{background:#fff3;color:#fff;font-size:12px;font-weight:600}.manage-participants-btn{border:none;border-radius:6px;cursor:pointer;padding:6px 12px;transition:all .3s ease}.manage-participants-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.participants-preview{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.participant-chip{background:#ffffff26;border:1px solid #fff3;border-radius:12px;color:#fff;font-size:11px;font-weight:500;padding:4px 8px}.more-participants{background:#ffffff1a;border-radius:12px;color:#fffc;font-size:11px;font-style:italic;padding:4px 8px}.participant-management-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;margin-top:10px;padding:15px}.panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.panel-header h3{color:#fff;font-size:16px;font-weight:600;margin:0}.add-participant-btn-detail{background:linear-gradient(45deg,#4caf50,#45a049);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.add-participant-btn-detail:hover{background:linear-gradient(45deg,#45a049,#3d8b40);transform:translateY(-1px)}.participants-list-detail{margin-bottom:10px;max-height:200px;overflow-y:auto}.participant-item-detail{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 12px}.participant-item-detail:last-child{margin-bottom:0}.participant-info-detail{flex:1 1}.participant-name-detail{color:#fff;font-weight:600;margin-bottom:2px}.participant-contact-detail{color:#ffffffb3;font-size:12px}.remove-participant-btn-detail{background:#f4433633;border:1px solid #f4433666;border-radius:4px;color:#ff6b6b;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .3s ease}.remove-participant-btn-detail:hover{background:#f443364d;transform:scale(1.1)}.no-participants-detail{color:#fff9;font-style:italic;margin-bottom:10px;padding:15px;text-align:center}.add-participant-form-detail{background:#ffffff0d;border:1px solid #fff3;border-radius:6px;margin-top:10px;padding:12px}.participant-form-row-detail{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:10px}.participant-contact-input-detail,.participant-name-input-detail{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;color:#fff;font-size:12px;padding:8px 12px}.participant-contact-input-detail:focus,.participant-name-input-detail:focus{background:#ffffff26;border-color:#ffffff80;outline:none}.participant-contact-input-detail::placeholder,.participant-name-input-detail::placeholder{color:#ffffff80}.participant-form-actions-detail{display:flex;gap:8px;justify-content:flex-end}.participant-cancel-btn-detail,.participant-save-btn-detail{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.participant-save-btn-detail{background:linear-gradient(45deg,#4caf50,#45a049);color:#fff}.participant-save-btn-detail:hover{background:linear-gradient(45deg,#45a049,#3d8b40)}.participant-cancel-btn-detail{background:#fff3;color:#fff}.participant-cancel-btn-detail:hover{background:#ffffff4d}.location-budget-people-row{align-items:flex-start;display:flex;flex-wrap:nowrap;gap:15px;margin-bottom:15px}.location-group{flex:4 1;min-width:0}.budget-group,.participants-group,.people-group{flex:3 1;min-width:0}.description-input{min-height:40px;resize:vertical}.budget-input:focus,.description-input:focus,.location-input:focus,.people-input:focus,.title-input:focus{background:#fff6;border-color:#fff9;outline:none}.budget-input::placeholder,.description-input::placeholder,.location-input::placeholder,.people-input::placeholder,.title-input::placeholder{color:#ffffffb3}.time-inputs{display:flex;flex-direction:column;gap:5px;min-width:200px}.time-label{color:#fff;font-size:12px;opacity:.9}.duration-input-group{align-items:center;display:flex;gap:8px}.duration-label{color:#ffffffe6;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.duration-input{background:#ffffff4d;border:1px solid #fff6;border-radius:6px;color:#fff;font-size:14px;padding:6px 10px;text-align:center;width:60px}.duration-input:focus{background:#fff6;border-color:#fff9;outline:none}.cancel-btn,.save-btn{align-items:center;display:flex;font-size:13px;height:38px;justify-content:center;min-width:50px;padding:10px 16px}.save-btn{background:linear-gradient(45deg,#4caf50,#45a049);box-shadow:0 2px 4px #0003}.save-btn:hover{background:linear-gradient(45deg,#45a049,#3d8b40);box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.cancel-btn{background:linear-gradient(45deg,#f44336,#d32f2f);box-shadow:0 2px 4px #0003;color:#fff}.cancel-btn:hover{background:linear-gradient(45deg,#d32f2f,#b71c1c);box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:15px;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 20px 0}.modal-header h2{color:#333;font-size:1.5rem;font-weight:600;margin:0}.modal-close-btn{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.modal-close-btn:hover{color:#333}.modal-body{padding:0 20px 20px}.activity-section,.time-section{margin-bottom:25px}.activity-section h3,.time-section h3{border-bottom:2px solid #f0f0f0;color:#333;font-size:1.1rem;font-weight:600;margin:0 0 15px;padding-bottom:8px}.form-group{margin-bottom:15px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:5px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.time-preview{background:#f8f9fa;border-radius:6px;color:#666;font-size:14px;font-weight:500;margin-top:10px;padding:10px;text-align:center}.modal-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:20px}.cancel-btn,.save-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.cancel-btn{background:#f5f5f5;color:#666}.cancel-btn:hover{background:#e0e0e0}.save-btn{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff}.save-btn:hover{background:linear-gradient(45deg,#5a6fd8,#6a4190)}@media (max-width:900px){.travel-detail-container{padding:15px}.travel-meta{flex-direction:column;gap:5px}.day-header{align-items:stretch;flex-direction:column;gap:15px}.day-header h2{text-align:center}.activity-item{flex-direction:column;gap:10px}.activity-time{align-items:center;display:flex;flex-direction:row;justify-content:space-between;min-width:auto}.end-time.desktop-only{display:none}.end-time.mobile-only{display:block;text-align:right}.activity-details{flex-direction:column;gap:8px}.edit-row,.location-budget-people-row{align-items:stretch;flex-direction:column;gap:10px}.budget-group,.location-group,.people-group{flex:1 1;min-width:auto}.activity-content{align-items:stretch;flex-direction:column;gap:10px}.activity-header{flex:none}.activity-details{flex:none;justify-content:flex-start}.activity-header-top{align-items:stretch;flex-direction:column;gap:10px}.activity-actions-right{justify-content:flex-end;margin-left:0;margin-top:10px}.duration-actions-row,.editing-header-row{align-items:stretch;flex-direction:column;gap:10px}.duration-header-group{min-width:auto}.participants-header-detail{align-items:stretch;flex-direction:column;gap:10px}.participant-form-row-detail{gap:8px;grid-template-columns:1fr}.participant-item-detail{align-items:stretch;flex-direction:column;gap:8px}.participant-form-actions-detail{justify-content:stretch}.participant-cancel-btn-detail,.participant-save-btn-detail{flex:1 1}.participants-preview{justify-content:center}.time-inputs{min-width:auto;width:100%}.duration-input-group{justify-content:space-between}}@media (max-width:600px){.travel-detail-container{padding:10px}.travel-detail-header{padding:15px}.travel-info h1{font-size:1.5rem}.day-activities{padding:15px}.day-tabs{gap:5px}.day-tab{min-width:100px;padding:12px 15px}.modal-content{margin:10px;max-height:95vh}.form-row{gap:0;grid-template-columns:1fr}.modal-body,.modal-footer,.modal-header{padding:15px}}@media (max-width:400px){.day-tab{min-width:80px;padding:10px 12px}.day-number{font-size:14px}.day-date{font-size:11px}.day-budget{font-size:10px}.activity-item{padding:15px}.activity-header h3{font-size:1.1rem}}.react-time-picker{color:#333!important;display:inline-block;position:relative}.react-time-picker,.react-time-picker *,.react-time-picker :after,.react-time-picker :before{box-sizing:border-box;color:#333!important}.react-time-picker--disabled{background-color:#f0f0f0;color:#6d6d6d}.react-time-picker__wrapper{align-items:center;background:#fff;border:1px solid #767676;border-radius:8px;display:flex;flex-grow:1;flex-shrink:0;height:38px}.react-time-picker__inputGroup{box-sizing:initial;flex-grow:1;min-width:calc(12px + 4.754em);padding:0 8px}.react-time-picker__inputGroup__divider{color:#333!important;padding:1px 0;white-space:pre}.react-time-picker__inputGroup__input{-webkit-appearance:textfield;appearance:textfield;background:none;border:0;box-sizing:initial;color:#333!important;font:inherit;height:calc(100% - 2px);min-width:.54em;padding:1px;position:relative}.react-time-picker__inputGroup__input::-webkit-inner-spin-button,.react-time-picker__inputGroup__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-time-picker__inputGroup__input:invalid{background:#ff00001a}.react-time-picker__inputGroup__input--hasLeadingZero{margin-left:-.54em;padding-left:calc(1px + .54em)}.react-time-picker__button{background:#0000;border:0;padding:4px 6px}.react-time-picker__button:enabled{cursor:pointer}.react-time-picker__button:enabled:focus .react-time-picker__button__icon,.react-time-picker__button:enabled:hover .react-time-picker__button__icon{stroke:#0078d4}.react-time-picker__button:disabled .react-time-picker__button__icon{stroke:#6d6d6d}.react-time-picker__button svg{display:inherit}.react-time-picker__clock{background:#fff;border:1px solid #a0a096;border-radius:4px;left:0;position:absolute;top:100%;transform:scale(0);transform-origin:top left;transition:transform .1s cubic-bezier(.26,.21,.31,.85);z-index:1}.react-time-picker__clock--open{transform:scale(1)}.start-time-edit .react-time-picker__wrapper{border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.start-time-edit .react-time-picker{margin-right:8px}.react-clock,.react-clock__face,.react-time-picker__clock,.react-time-picker__clock *{color:#333!important}.react-clock__mark,.react-clock__mark__body{background-color:#333!important}.react-clock__hand,.react-clock__hand__body{background-color:#0078d4!important}.participants-group{width:100%}.participants-selection{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;max-height:200px;overflow-y:auto;padding:12px}.select-all-section{border-bottom:1px solid #e0e0e0;margin-bottom:10px;padding-bottom:10px}.select-all-btn{background:linear-gradient(45deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.select-all-btn:hover{background:linear-gradient(45deg,#5a6fd8,#6a4190);transform:translateY(-1px)}.participants-checkbox-list{display:flex;flex-direction:column;gap:8px}.participant-checkbox-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;padding:8px;transition:all .3s ease}.participant-checkbox-item:hover{background:#f0f7ff;border-color:#667eea}.participant-checkbox{cursor:pointer;margin-right:10px}.participant-info{display:flex;flex:1 1;flex-direction:column}.participant-name{color:#333;font-weight:600;margin-bottom:2px}.participant-contact{color:#666;font-size:12px;margin-left:4px}.no-participants-section{padding:15px;text-align:center}.no-participants-text{color:#999;font-size:14px;font-style:italic;margin-bottom:10px}@media (max-width:600px){.participants-selection{max-height:150px;padding:8px}.participant-checkbox-item{padding:6px}.participant-name{font-size:14px}.participant-contact{font-size:11px}.select-all-btn{font-size:11px;padding:5px 10px}}.participants-dropdown-container{position:relative;width:100%}.participants-dropdown-header{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;min-height:40px;padding:8px 12px;transition:all .3s ease}.participants-dropdown-header:hover{background:#f8f9fa;border-color:#667eea}.selected-participants-display{flex:1 1;overflow:hidden}.selected-participants-scroll{color:#333;font-size:14px;max-width:100%;overflow-x:auto;overflow-y:hidden;scrollbar-color:#ccc #0000;scrollbar-width:thin;white-space:nowrap}.selected-participants-scroll::-webkit-scrollbar{height:4px}.selected-participants-scroll::-webkit-scrollbar-track{background:#0000}.selected-participants-scroll::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.selected-participants-scroll::-webkit-scrollbar-thumb:hover{background:#999}.no-selection{color:#999;font-size:14px;font-style:italic}.dropdown-arrow{color:#666;font-size:12px;margin-left:8px;transition:transform .3s ease}.participants-dropdown-content{background:#fff;border:1px solid #ddd;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 12px #00000026;left:0;max-height:250px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.participants-dropdown-content .select-all-section{background:#f8f9fa;border-bottom:1px solid #eee;padding:8px 12px}.participants-dropdown-content .participants-checkbox-list{padding:8px}.participants-dropdown-content .participant-checkbox-item{margin-bottom:4px}.participants-dropdown-content .participant-checkbox-item:last-child{margin-bottom:0}@media (max-width:600px){.participants-dropdown-header{min-height:36px;padding:6px 10px}.selected-participants-scroll{font-size:13px}.dropdown-arrow{font-size:11px}.participants-dropdown-content{max-height:200px}.participants-dropdown-content .select-all-section{padding:6px 10px}.participants-dropdown-content .participants-checkbox-list{padding:6px}}
/*# sourceMappingURL=main.bfb7d85e.css.map*/