*{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;font-size:14px;margin-bottom:8px}.form-input{background:#fff;border:2px solid #e1e8ed;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus{box-shadow:0 0 0 3px #667eea1a}.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;display:flex;gap:8px;margin-bottom:20px}.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:800px){.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{border:none;border-radius:8px;font-size:14px;font-weight:600;padding:12px 24px;transition:background .2s ease}.fab-write-btn,.write-btn{background:#3498db;color:#fff;cursor:pointer}.fab-write-btn{border:none;border-radius:50%;bottom:80px;box-shadow:0 4px 12px #3498db66;display:none;font-size:24px;height:56px;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:900}.fab-write-btn:active{transform:scale(.95)}.fab-write-btn.permission-denied{background:#e74c3c;cursor:not-allowed;opacity:.8}.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}.fab-write-btn{align-items:center;display:flex;justify-content:center}.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;cursor:pointer;position:relative;text-decoration:underline}.editor-content a:hover{background-color:#0969da1a;text-decoration:underline}.editor-content a:after{background:#24292f;border-radius:4px;bottom:100%;color:#fff;content:attr(href);font-size:11px;left:50%;margin-bottom:4px;max-width:300px;opacity:0;overflow:hidden;padding:4px 8px;pointer-events:none;position:absolute;text-overflow:ellipsis;transform:translateX(-50%);transition:opacity .2s ease;white-space:nowrap;z-index:100}.editor-content a:hover:after{opacity:1}.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;display:flex;flex-direction:column;min-height:100%}.post-detail-content{background:#fff;flex:1 1;margin:0;min-height:auto;overflow-y: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{background:none;color:#495057;font-size:13px;justify-content:space-between;padding:8px 12px}.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}@media (max-width:800px){.post-detail-page{height:100%}.post-detail-header{flex-shrink:0;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;padding-bottom:100px}.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;display:flex;flex-direction:column;min-height:100%}.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{flex:1 1;overflow-y:auto;padding:20px;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:800px){.post-write-page{height:100%}.post-write-header{flex-shrink:0;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 16px 20px}.post-write-form{margin-bottom:80px;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{height:100vh;overflow:hidden}.board-main{overflow-y:auto;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 h3{color:#2c3e50;font-size:1.3rem}.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{color:#2c3e50;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}.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;gap:12px;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}.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;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;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;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:#fff;box-sizing:border-box;min-height:100vh;padding:0}.travel-plan-container{max-width:1200px;padding:20px}@media (min-width:801px){.travel-plan-container{margin:0 auto}}@media (max-width:800px){.travel-plan-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.travel-plan-container{flex:1 1;overflow-y:auto;padding-bottom:20px;width:100%}}.travel-plan-header{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:15px;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.travel-plan-header h1{color:#333;font-size:2.2rem;font-weight:700;margin:0}.header-buttons{align-items:center;display:flex;gap:12px}.load-from-server-btn{background:#10b981;border:none;border-radius:25px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:all .3s ease}.load-from-server-btn:hover:not(:disabled){background:#059669;box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.load-from-server-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.create-plan-btn{background:#667eea;border:none;border-radius:25px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.create-plan-btn:hover{background:#5a6fd8;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.empty-plans{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:20px;color:#333;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{background:#fff;border:1px solid #e0e0e0;border-radius:15px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.travel-plan-card:before{background:linear-gradient(45deg,#0000,#667eea0d,#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:#f8f9fa;border-color:#667eea;box-shadow:0 12px 24px #00000026;transform:translateY(-8px)}.plan-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.plan-title-section{display:flex;flex:1 1;flex-direction:column;gap:8px}.plan-title{color:#333;font-size:1.4rem;font-weight:600;margin:0}.share-badge{align-items:center;border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px;width:-webkit-fit-content;width:fit-content}.share-badge-owner{background:#667eea}.share-badge-view{background:#3b82f6}.share-badge-edit{background:#10b981}.share-badge-admin{background:#f59e0b}.plan-actions{display:flex;gap:8px}.delete-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;padding:8px;position:relative;transition:all .3s ease;z-index:10}.delete-btn:hover{transform:scale(1.1)}.plan-card-content{color:#333}.plan-info{margin-bottom:15px}.info-item{margin-bottom:8px}.info-icon{font-size:16px;margin-right:8px;width:20px}.info-text{font-size:14px;opacity:.9}.plan-description{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-top:10px;padding:12px}.plan-description p{color:#666;font-size:14px;line-height:1.4;margin:0}.modal-content{max-width:500px}.modal-header-minimal{align-items:center;display:flex;justify-content:flex-end;padding:15px 15px 0}.modal-header{padding:20px 20px 0}.form-group{margin-bottom:20px}.form-group input,.form-group textarea{padding:12px}.date-range-container{align-items:center;display:flex;gap:12px;width:100%}.date-range-input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;flex:1 1;font-size:14px;min-width:0;padding:12px}.date-range-input:focus{border-color:#667eea;outline:none}.date-range-separator{color:#999;flex-shrink:0;font-size:16px;font-weight:600}.cancel-btn,.create-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;max-width:120px;padding:12px 20px}.cancel-btn{background:#f5f5f5;color:#666}.cancel-btn:hover{background:#e0e0e0}.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{gap:10px}.travel-plan-header h1{flex:1 1;font-size:1.5rem;min-width:0}.create-plan-btn{font-size:14px;padding:10px 16px;white-space:nowrap}.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.3rem}.create-plan-btn{font-size:13px;padding:8px 12px}.travel-plans-grid{grid-template-columns:1fr}.modal-content{margin:10px;max-height:95vh}.form-row{gap:0;grid-template-columns:1fr}.date-range-container{flex-direction:column;gap:8px}.date-range-separator{display:none}.empty-plans{padding:40px 15px}.empty-icon{font-size:3rem}.empty-plans h3{font-size:1.5rem}}.participants-header{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-header{gap:8px;padding:12px}.travel-plan-header h1{font-size:1.1rem}.create-plan-btn{font-size:12px;padding:6px 10px}.travel-plan-card{padding:15px}.plan-title{font-size:1.2rem}.modal-body,.modal-footer,.modal-header-minimal{padding:15px}}.share-link-modal{max-height:90vh;max-width:550px;overflow-y:auto}.share-link-modal .modal-body{padding:24px}.form-section{margin-bottom:24px}.form-label{color:#333;display:block;font-size:15px;font-weight:600;margin-bottom:12px}.permission-options{display:flex;flex-direction:column;gap:12px}.permission-option{align-items:flex-start;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;padding:16px;transition:all .2s ease}.permission-option:hover{background:#f8f9ff;border-color:#667eea}.permission-option.selected{background:#f0f2ff;border-color:#667eea}.permission-option input[type=radio]{cursor:pointer;flex-shrink:0;height:18px;margin-right:12px;margin-top:4px;width:18px}.permission-content{align-items:flex-start;display:flex;flex:1 1;gap:12px}.permission-icon{flex-shrink:0;font-size:24px}.permission-text{flex:1 1}.permission-title{color:#333;font-size:15px;font-weight:600;margin-bottom:4px}.permission-description{color:#666;font-size:13px;line-height:1.4}.checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;margin-bottom:12px}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;margin-right:8px;width:18px}.expiry-inputs{display:flex;gap:12px;margin-top:12px}.form-input{border:1px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:14px;padding:10px 14px;transition:border-color .2s ease}.form-input:focus{border-color:#667eea;outline:none}.max-uses-input{margin-top:12px;width:120px}.error-message{background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:16px;padding:12px 16px}.modal-actions{border-top:1px solid #f0f0f0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.btn-primary:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.btn-primary:disabled{background:#b8c5f6;cursor:not-allowed}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.created-link-section{text-align:center}.success-icon{font-size:48px;margin-bottom:16px}.created-link-section h3{color:#333;font-size:18px;font-weight:600;margin-bottom:24px}.link-info{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:16px;text-align:left}.info-row{align-items:center;border-bottom:1px solid #e9ecef;padding:8px 0}.link-display{display:flex;gap:8px;margin-bottom:16px}.link-input{background:#f8f9ff;border:2px solid #667eea;border-radius:8px;color:#333;flex:1 1;font-family:monospace;font-size:14px;padding:12px}.link-input:focus{background:#fff;outline:none}.copy-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.copy-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.link-hint{color:#666;font-size:13px;line-height:1.5}@media (max-width:600px){.share-link-modal{margin:20px auto;max-width:95%}.permission-content{flex-direction:column;gap:8px}.permission-icon{font-size:20px}.expiry-inputs,.link-display{flex-direction:column}.copy-btn{width:100%}}.share-link-list-modal{max-height:80vh;max-width:900px;overflow-y:auto}.share-link-list-modal .modal-body{min-height:300px;padding:24px}.loading-section{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-section .loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:20px;width:40px}.loading-section p{color:#666;font-size:14px}.error-section{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.error-text{color:#dc3545;font-size:14px;margin-bottom:20px}.empty-section{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px}.empty-text{color:#333;font-size:16px;font-weight:600;margin-bottom:8px}.empty-hint{color:#666;font-size:14px;line-height:1.5}.share-links-table{overflow-x:auto;width:100%}.share-links-table table{background:#fff;border-collapse:collapse;width:100%}.share-links-table thead{background:#f8f9fa}.share-links-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:13px;font-weight:600;padding:14px 12px;text-align:left;white-space:nowrap}.share-links-table td{border-bottom:1px solid #e9ecef;color:#333;font-size:13px;padding:14px 12px;vertical-align:middle}.share-links-table tbody tr:hover{background:#f8f9fa}.permission-badge{border-radius:12px;color:#fff;font-size:12px;padding:4px 10px}.permission-badge,.status-badge{align-items:center;display:inline-flex;font-weight:600;gap:4px;white-space:nowrap}.status-badge{font-size:13px}.action-buttons{display:flex;gap:8px}.btn-copy,.btn-delete{background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s ease}.btn-copy:hover{background:#667eea;border-color:#667eea;transform:scale(1.1)}.btn-delete:hover{background:#dc3545;border-color:#dc3545;transform:scale(1.1)}.modal-footer{border-top:1px solid #e9ecef;padding:20px 24px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}@media (max-width:900px){.share-link-list-modal{max-width:95%}.share-links-table{font-size:12px}.share-links-table td,.share-links-table th{font-size:12px;padding:10px 8px}.permission-badge,.status-badge{font-size:11px}.action-buttons{flex-direction:column;gap:4px}.btn-copy,.btn-delete{font-size:13px;padding:5px 10px}}@media (max-width:600px){.share-links-table{display:block;overflow-x:auto}.share-links-table table{min-width:600px}}.travel-detail-page{background:#fff;border-radius:0;box-sizing:border-box;display:flex;flex-direction:column;height:100vh;overflow:hidden;padding:0}.travel-detail-container{border-radius:0;box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;min-height:0;overflow-y:auto;padding:20px;width:100%}.travel-detail-loading{align-items:center;color:#333;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #e0e0e0;border-top-color:#667eea;margin-bottom:20px}.travel-detail-header.app-bar{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;border-radius:0;box-shadow:0 1px 2px #0000000d;color:#333;display:flex;flex-shrink:0;justify-content:space-between;margin:0;padding:6px 16px;z-index:100}.app-bar-title-container{align-items:center;display:flex;flex:1 1;gap:8px;justify-content:center;min-width:0}.app-bar-title{flex-shrink:1;font-size:1rem;font-weight:600;margin:0;min-width:0;overflow:hidden;padding:0 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.nav-arrow-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#333;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;justify-content:center;padding:4px 8px;transition:all .2s ease}.nav-arrow-btn:hover{background:#f0f0f0;color:#667eea}.nav-arrow-btn:active{transform:scale(.95)}.travel-detail-header{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:15px;color:#333;margin-bottom:20px;padding:20px}.app-bar .back-btn,.app-bar .more-btn{align-items:center;background:#0000;border:none;border-radius:0;color:#333;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;min-width:32px;padding:4px 8px;transition:all .2s ease}.app-bar .back-btn:hover,.app-bar .more-btn:hover{background:#f5f5f5}.app-bar .back-btn:active,.app-bar .more-btn:active{background:#e0e0e0}.more-btn-container{align-items:center;display:flex;position:relative}.more-menu-dropdown-appbar{animation:slideDown .2s ease-out;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:8px;min-width:160px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item-appbar{align-items:center;background:#fff;border:none;border-bottom:1px solid #f0f0f0;color:#333;cursor:pointer;display:flex;font-size:14px;padding:12px 16px;text-align:left;transition:background .2s ease;width:100%}.menu-item-appbar:last-child{border-bottom:none}.menu-item-appbar:hover{background:#f8f9fa}.menu-item-appbar:active{background:#e9ecef}.menu-item-appbar:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.6}.menu-item-appbar:disabled:hover{background:#f8f9fa}.menu-divider-appbar{background:#e0e0e0;height:1px;margin:4px 0}.menu-item-appbar.save-to-server{color:#10b981;font-weight:600}.menu-item-appbar.save-to-server:hover:not(:disabled){background:#f0fdf4}.back-btn{background:#667eea;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:#5a6fd8;box-shadow:0 2px 8px #667eea4d}.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{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#333;cursor:pointer;min-width:auto;padding:10px 16px;text-align:center;transition:all .3s ease}.day-tab:hover{background:#f8f9fa;border-color:#667eea}.day-tab.active{background:#667eea;border-color:#667eea;box-shadow:0 4px 8px #667eea4d;color:#fff;transform:translateY(-2px)}.day-number{font-size:14px;font-weight:600;margin:0}.day-date{font-size:12px;margin-bottom:5px;opacity:.8}.day-budget{font-size:11px;opacity:.7}.day-activities{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:15px;padding:20px}.start-time-section{align-items:center;display:flex;gap:10px}.set-start-time-btn{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.set-start-time-btn:hover{background:#e9ecef;border-color:#ccc}.start-time-edit{align-items:center;display:flex;gap:10px}.time-input-native{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:500;min-width:120px;padding:8px 16px;transition:all .2s ease}.time-input-native:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.start-time-input{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;padding:8px 12px}.start-time-input:focus{background:#fff;border-color:#667eea;outline:none}.cancel-start-time-btn,.save-start-time-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;color:#333;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:#333;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:15px}.day-header h2{flex:0 0 auto;font-size:1.2rem;font-weight:600;margin:0;min-width:auto}.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:#666;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{gap:5px;min-height:100px}.activities-timeline,.activity-item{display:flex;flex-direction:column;position:relative}.activity-item{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 4px #0000000d;cursor:grab;gap:0;margin-bottom:8px;overflow:visible;padding:16px 20px 16px 40px;transition:all .3s ease;z-index:1}.activity-item:hover{z-index:100}.activity-item.menu-open{z-index:9999!important}.activity-item:active{cursor:grabbing}.activity-item.hidden{background:#9e9e9e99;margin-bottom:4px;padding:10px 15px 10px 30px}.activity-item.hidden .activity-duration-inline,.activity-item.hidden .activity-time-inline,.activity-item.hidden .activity-title-inline{color:#666666b3;font-size:.85rem}.activity-item.hidden .activity-row-1{gap:8px}.activity-item.hidden .activity-description,.activity-item.hidden .activity-row-2{display:none}.activity-item.hidden .drag-handle{width:20px}.activity-item.hidden .drag-icon{font-size:12px}.drag-handle{align-items:center;background:#0000;border-radius:12px 0 0 12px;bottom:0;cursor:grab;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;top:0;transition:all .2s ease;width:30px}.drag-icon{color:#ccc;font-size:16px;font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none}.activity-item.dragging{cursor:grabbing;opacity:.3;transition:opacity .2s ease}.activity-item.shift-down{transform:translateY(100px);transition:transform .3s ease}.drop-indicator{background:repeating-linear-gradient(90deg,#667eea 0,#667eea 10px,#0000 0,#0000 20px);border-radius:2px;height:4px;margin:8px 0;opacity:.8;pointer-events:none}.activity-item *{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.activity-item.add-form *,.activity-item.editing *{user-select:auto;-webkit-user-select:auto}.activity-row-1{gap:15px;justify-content:space-between}.activity-left,.activity-row-1{align-items:center;display:flex}.activity-left{flex:1 1;gap:0;min-width:0}.activity-time-inline{color:#667eea;flex-shrink:0;font-size:1.1rem;font-weight:700;white-space:nowrap}.activity-duration-inline{color:#999;flex-shrink:0;font-size:.95rem;font-weight:500;min-width:50px;text-align:right;white-space:nowrap}.activity-title-inline{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 0 5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-right{flex-shrink:0;position:relative;z-index:auto}.more-btn-activity{align-items:center;background:#0000;border:none;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;min-width:32px;padding:4px 8px;transition:all .2s ease}.more-btn-activity:hover{background:#f5f5f5}.more-menu-dropdown{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:5px;min-width:140px;overflow:hidden;position:absolute;right:0;top:100%;z-index:9999}.menu-item{align-items:center;background:#fff;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 16px;text-align:left;transition:background .2s ease;width:100%}.menu-item:hover{background:#f8f9fa}.menu-item.edit-item:hover{background:#667eea1a;color:#667eea}.menu-item.delete-item:hover{background:#f443361a;color:#f44336}.activity-row-2{display:flex;justify-content:flex-end;min-height:0}.activity-row-2:not(:empty){margin-top:6px}.activity-details-right{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.activity-details-right:empty{display:none}.detail-item-inline{align-items:center;color:#666;display:flex;font-size:13px;gap:4px;white-space:nowrap}.detail-item-inline .detail-icon{font-size:14px}.activity-item.add-form,.activity-item.editing{background:#f8f9fa;border:2px solid #667eea;cursor:default!important;opacity:1!important;padding:16px 20px!important;pointer-events:auto;transform:none!important}.activity-item.add-form:hover,.activity-item.editing:hover{background:#f8f9fa;transform:none!important}.activity-time{color:#333;display:flex;flex-direction:column;flex-shrink:0;min-width:80px;text-align:center}.activity-time-editing{align-items:center;color:#667eea;display:flex;font-size:1rem;font-weight:600;gap:8px;margin-bottom:12px}.activity-time-editing .time-text{font-weight:700}.activity-time-editing .time-separator{color:#999;font-weight:400}.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:#333;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;flex-shrink:0;gap:8px}.delete-btn,.edit-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:12px;padding:6px;transition:all .3s ease}.edit-btn:hover{background:#4caf501a;border-color:#4caf50;color:#4caf50}.delete-btn:hover{background:#f443361a;border-color:#f44336;color:#f44336}.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{align-items:flex-end;display:flex;gap:15px;justify-content:space-between;margin-top:10px}.editing-header-row{align-items:flex-end;display:flex;flex-wrap:nowrap;gap:10px}.detail-item{align-items:center;display:flex;font-size:14px;gap:5px;opacity:.9}.detail-icon{font-size:12px}.activity-description{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-top:10px;padding:10px}.activity-description p{color:#666;font-size:14px;line-height:1.4;margin:0}.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:#333;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.title-group{flex:1 1;min-width:150px}.duration-header-group{align-items:center;display:flex;flex-direction:column;flex-shrink:0;min-width:110px}.duration-header-group .input-label{margin-bottom:8px;text-align:center}.duration-header-group .duration-input-group{align-items:center;background:#fff;border:1px solid #ddd;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:#333;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:#999}.duration-header-group span{color:#666;font-size:12px;font-weight:600}.budget-input,.description-input,.location-input,.people-input,.title-input{background:#fff;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;color:#333;font-size:14px;height:38px;padding:8px 12px;width:100%}.people-input.disabled{background:#f5f5f5!important;border:1px solid #e0e0e0!important;border-radius:8px!important;box-sizing:border-box!important;color:#999!important;cursor:not-allowed!important;font-size:14px!important;height:38px!important;padding:8px 12px!important;pointer-events:none!important;width:100%!important}.people-input.disabled:focus,.people-input.disabled:hover{background:#f5f5f5!important;border:1px solid #e0e0e0!important;cursor:not-allowed!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:#fff;border:1px solid #ddd;border-radius:8px}.input-group .rich-text-editor .editor-toolbar{background:#f8f9fa;border-bottom:1px solid #e0e0e0;border-radius:8px 8px 0 0;padding:8px}.input-group .rich-text-editor .toolbar-btn{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:12px;padding:4px 8px}.input-group .rich-text-editor .toolbar-btn:hover{background:#f5f5f5}.input-group .rich-text-editor .toolbar-select{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:12px;padding:4px 8px}.input-group .rich-text-editor .editor-content{background:#fff;border-radius:0 0 8px 8px;color:#333;padding:12px}.input-group .rich-text-editor .editor-content[data-placeholder]:empty:before{color:#999}.travel-participants{border-top:1px solid #e0e0e0;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:#333;font-size:14px;font-weight:600}.participants-count{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:12px;font-weight:600;padding:2px 8px}.manage-participants-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;color:#333;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.manage-participants-btn:hover{background:#e0e0e0;border-color:#d0d0d0;transform:translateY(-1px)}.participants-preview{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.participant-chip{background:#e3f2fd;border:1px solid #bbdefb;border-radius:12px;color:#1976d2;font-size:11px;font-weight:500;padding:4px 8px}.more-participants{background:#f5f5f5;border-radius:12px;color:#666;font-size:11px;font-style:italic;padding:4px 8px}.participant-management-panel{background:#f8f9fa;border:1px solid #e0e0e0;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:#333;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:#fff;border:1px solid #e0e0e0;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:#333;font-weight:600;margin-bottom:2px}.participant-contact-detail{color:#666;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:#999;font-style:italic;margin-bottom:10px;padding:15px;text-align:center}.add-participant-form-detail{background:#fff;border:1px solid #e0e0e0;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:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:12px;padding:8px 12px}.participant-contact-input-detail:focus,.participant-name-input-detail:focus{background:#fff;border-color:#667eea;outline:none}.participant-contact-input-detail::placeholder,.participant-name-input-detail::placeholder{color:#999}.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:#f5f5f5;border:1px solid #e0e0e0;color:#333}.participant-cancel-btn-detail:hover{background:#e0e0e0}.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:#fff;border-color:#667eea;outline:none}.budget-input::placeholder,.description-input::placeholder,.location-input::placeholder,.people-input::placeholder,.title-input::placeholder{color:#999}.time-inputs{display:flex;flex-direction:column;gap:5px;min-width:200px}.time-label{color:#333;font-size:12px;opacity:.9}.duration-input-group{align-items:center;display:flex;gap:8px}.duration-label{color:#333;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.duration-input{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;padding:6px 10px;text-align:center;width:60px}.duration-input:focus{background:#fff;border-color:#667eea;outline:none}.cancel-btn,.save-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:13px;font-weight:600;height:38px;justify-content:center;min-width:50px;padding:10px 16px;transition:all .3s ease}.save-btn{background:linear-gradient(45deg,#4caf50,#45a049);box-shadow:0 2px 4px #0003;color:#fff}.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:10px 20px}.modal-header h2{color:#333;flex:1 1;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{background:#fff;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;color:#333;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-group textarea{font-family:inherit;resize:vertical}.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}.travel-info-modal{max-width:600px}.cancel-travel-info-btn,.edit-travel-info-btn,.save-travel-info-btn{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .3s ease}.edit-travel-info-btn{background:#667eea;color:#fff}.edit-travel-info-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.save-travel-info-btn{background:#4caf50;color:#fff}.save-travel-info-btn:hover{background:#45a049;transform:translateY(-1px)}.cancel-travel-info-btn{background:#f5f5f5;border:1px solid #e0e0e0;color:#666}.cancel-travel-info-btn:hover{background:#e0e0e0}.info-section{border-bottom:1px solid #f0f0f0;margin-bottom:24px;padding-bottom:20px}.info-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-row{align-items:flex-start;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:12px 0}.info-row:last-child{border-bottom:none}.info-row.description-row{align-items:stretch;flex-direction:column}.info-label{font-weight:600;min-width:100px}.info-value{flex:1 1;text-align:right}.description-value{color:#666;line-height:1.6;margin-top:8px;text-align:left}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h3{color:#333;font-size:1.1rem;font-weight:600;margin:0}.activity-actions-bottom{border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;margin-top:15px;padding-top:15px}.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}.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-dropdown-content .participants-checkbox-list{padding:8px}.participants-checkbox-list{display:flex;flex-direction:column;gap:8px}.participants-dropdown-content .participant-checkbox-item{margin-bottom:4px}.participants-dropdown-content .participant-checkbox-item:last-child{margin-bottom:0}.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}.participants-selection{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;max-height:200px;overflow-y:auto;padding:12px}.no-participants-section{padding:15px;text-align:center}.no-participants-text{color:#999;font-size:14px;font-style:italic;margin-bottom:10px}.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}@media (max-width:800px){.travel-detail-page{height:100vh}.travel-detail-container{margin-bottom:72px;padding:15px}.app-bar-title{font-size:.95rem}.app-bar .back-btn,.app-bar .more-btn{font-size:16px;height:30px;min-width:30px;padding:4px 6px}}@media (max-width:900px){.travel-meta{flex-direction:column;gap:5px}.day-header{gap:8px}.day-header h2{font-size:1rem}.activity-item{gap:0;padding:12px 16px 12px 35px}.drag-handle{width:25px}.drag-icon{font-size:14px}.activity-row-1{gap:10px}.activity-left{gap:8px}.activity-time-inline,.activity-title-inline{font-size:1rem}.more-btn-activity{font-size:16px;height:28px;min-width:28px;padding:3px 6px}.activity-details-right{gap:8px}.detail-item-inline{font-size:12px}.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{align-items:stretch;flex-direction:column;gap:10px}.editing-header-row{gap:8px}.editing-header-row .title-group{flex:1 1;min-width:0}.editing-header-row .duration-header-group{min-width:100px}.editing-header-row .activity-actions{gap:6px}.editing-header-row .cancel-btn,.editing-header-row .save-btn{font-size:14px;height:32px;min-width:32px;padding:6px 8px}.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:center;flex-direction:row;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 10px 90px}.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}.activity-item{padding:12px 16px 12px 35px!important}.drag-handle{width:25px}.drag-icon{font-size:13px}.modal-content{margin:10px;max-height:95vh}.form-row{gap:0;grid-template-columns:1fr}.modal-body,.modal-footer,.modal-header{padding:15px}.editing-header-row{gap:6px}.editing-header-row .title-group{min-width:0}.editing-header-row .duration-header-group{min-width:90px}.editing-header-row .duration-header-group .input-label{font-size:11px;margin-bottom:5px}.editing-header-row .duration-input-group{height:34px;padding:6px 8px}.editing-header-row .duration-input{font-size:13px;width:45px}.editing-header-row .activity-actions{gap:4px}.editing-header-row .cancel-btn,.editing-header-row .save-btn{font-size:13px;height:30px;min-width:30px;padding:5px 6px}.info-row{flex-direction:column;gap:4px}.info-value{text-align:left}.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-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}}@media (max-width:400px){.day-tab{min-width:auto;padding:8px 12px}.day-number{font-size:13px}.activity-item{gap:0;padding:10px 12px 10px 30px}.drag-handle{width:20px}.drag-icon{font-size:12px}.activity-row-1{gap:8px}.activity-left{gap:6px}.activity-time-inline,.activity-title-inline{font-size:.95rem}.more-btn-activity{font-size:15px;height:26px;min-width:26px;padding:2px 5px}.activity-details-right{gap:6px}.detail-item-inline{font-size:11px}.editing-header-row{gap:4px}.editing-header-row .title-group .title-input{font-size:13px;padding:6px 8px}.editing-header-row .duration-header-group{min-width:80px}.editing-header-row .duration-header-group .input-label{font-size:10px;margin-bottom:4px}.editing-header-row .duration-input-group{height:30px;padding:4px 6px}.editing-header-row .duration-input{font-size:12px;width:40px}.editing-header-row .cancel-btn,.editing-header-row .save-btn{font-size:12px;height:28px;min-width:28px;padding:4px 5px}}.category-row{margin-bottom:15px}.category-selection{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.category-btn{background:#0000;border:2px solid;border-radius:20px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.category-btn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-2px)}.category-btn.selected{color:#fff!important}.category-manage-btn{background:#0000;border:none;border-radius:50%;cursor:pointer;font-size:16px;padding:6px 10px;transition:all .2s ease}.category-manage-btn:hover{background:#f0f0f0;transform:rotate(90deg)}.category-management-panel{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-top:10px;padding:15px}.category-management-panel h4{color:#333;font-size:14px;margin:0 0 10px}.category-list{display:flex;flex-direction:column;gap:8px;margin-bottom:15px}.category-item{align-items:center;background:#fff;border-radius:6px;display:flex;gap:10px;padding:8px}.category-name{flex:1 1;font-size:13px;font-weight:500}.category-color-picker{border:1px solid #ccc;border-radius:4px;cursor:pointer;height:30px;width:40px}.category-delete-btn{background:#fff;border:1px solid #f44336;border-radius:4px;color:#f44336;cursor:pointer;font-size:14px;padding:4px 8px;transition:all .2s ease}.category-delete-btn:hover{background:#f44336;color:#fff}.category-add-form{align-items:center;display:flex;gap:8px}.category-name-input{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:13px;padding:8px}.category-add-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.category-add-btn:hover{background:#5568d3;transform:translateY(-2px)}.participants-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.select-all-toggle-btn{background:#fff;border:1px solid #667eea;border-radius:4px;color:#667eea;cursor:pointer;font-size:12px;font-weight:500;padding:4px 10px;transition:all .2s ease}.select-all-toggle-btn:hover{background:#667eea;color:#fff}.participants-toggle-container{display:flex;flex-wrap:wrap;gap:8px}.participant-toggle-label{background:#fff;border:2px solid #ddd;border-radius:20px;color:#666;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.participant-toggle-label:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33;color:#667eea;transform:translateY(-2px)}.participant-toggle-label.selected{background:#667eea;border-color:#667eea;color:#fff}.participant-toggle-label.selected:hover{background:#5568d3;border-color:#5568d3}.icon-selector-container{margin-bottom:15px}.icon-selector-label{color:#333;display:block;font-size:12px;font-weight:600;margin-bottom:8px}.icon-selector-grid{grid-gap:6px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));max-height:120px;overflow-y:auto;padding:8px}.icon-option{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.icon-option:hover{border-color:#667eea;transform:scale(1.1)}.icon-option.selected{background:#667eea;border-color:#667eea;transform:scale(1.15)}.participant-icon{display:inline-block;font-size:18px;margin-right:6px;vertical-align:middle}.booking-page-content{display:flex;flex-direction:column;gap:20px}.booking-page-content .info-section h3{align-items:center;color:#333;display:flex;font-size:1.2rem;font-weight:600;gap:8px;margin-bottom:0}.add-booking-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.add-booking-btn:hover{background:#5568d3;box-shadow:0 2px 6px #667eea4d;transform:translateY(-1px)}.add-booking-btn:active{transform:translateY(0)}.booking-items-list{display:flex;flex-direction:column;gap:12px;margin-top:15px}.booking-item-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:16px;transition:all .2s ease}.booking-item-card:hover{border-color:#d0d0d0;box-shadow:0 2px 8px #0000001a}.booking-item-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.booking-item-header h4{color:#333;font-size:1.1rem;font-weight:600;margin:0}.delete-booking-btn{background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .2s ease}.delete-booking-btn:hover{background:#e0e0e0;color:#e74c3c}.booking-item-body{display:flex;flex-direction:column;gap:8px}.booking-field{display:flex;font-size:14px;gap:8px}.field-label{color:#666;font-weight:600;min-width:80px}.field-value{color:#333}.booking-memo{border-top:1px solid #e0e0e0;color:#555;font-size:14px;margin-top:8px;padding-top:12px}.booking-memo img{display:block;height:auto;margin:8px 0;max-width:100%}.participant-tag{background:#f0f0f0;border-radius:4px;display:inline-block;font-size:13px;margin-bottom:4px;margin-right:6px;padding:4px 8px}.booking-add-form{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-top:15px;padding:20px}.booking-add-form .form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:15px}.booking-add-form label{color:#555;font-size:13px;font-weight:600}.booking-input{background:#fff;border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s ease}.booking-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-actions{align-items:center;border-top:1px solid #e0e0e0;display:flex;flex-direction:row;flex-wrap:nowrap;gap:10px;justify-content:flex-end;margin-top:15px;padding-top:15px}.form-actions .cancel-btn,.form-actions .save-btn{flex-shrink:0;min-width:70px;width:70px}.booking-empty{background:#f8f9fa;border-radius:8px;color:#999;font-style:italic;margin-top:15px;padding:40px 20px;text-align:center}.checklist-page-content{display:flex;flex-direction:column;gap:20px}.checklist-input-container{align-items:center;display:flex;gap:10px;margin-bottom:20px}.checklist-input{border:1px solid #e0e0e0;border-radius:8px;flex:1 1;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease}.checklist-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.add-checklist-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.add-checklist-btn:hover{background:#5568d3;box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.add-checklist-btn:active{box-shadow:0 1px 4px #667eea4d;transform:translateY(0)}.checklist-items{display:flex;flex-direction:column;gap:10px;min-height:200px}.checklist-item{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.checklist-item:hover{background:#f0f1f3;border-color:#d0d0d0}.checklist-checkbox{cursor:pointer;flex-shrink:0;height:18px;width:18px}.checklist-item-text{color:#333;flex:1 1;font-size:14px}.checklist-item-text.completed{color:#999;text-decoration:line-through}.checklist-item-delete{background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;font-size:16px;padding:4px 8px;transition:all .2s ease}.checklist-item-delete:hover{background:#e0e0e0;color:#e74c3c}@media (max-width:900px){.nav-arrow-btn{font-size:14px;padding:3px 6px}.app-bar-title{font-size:.95rem}.booking-edit-form,.checklist-input-container{gap:12px}}@media (max-width:600px){.nav-arrow-btn{font-size:13px;padding:2px 4px}.app-bar-title{font-size:.9rem;padding:0 4px}.checklist-input-container{align-items:stretch;flex-direction:column}.add-checklist-btn{width:100%}}@media (max-width:400px){.app-bar-title-container{gap:4px}.app-bar-title{font-size:.85rem}}.share-preview-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.share-preview-container{margin:0 auto;max-width:600px;width:100%}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;margin:0 auto 20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.share-preview-container>p{color:#fff;font-size:16px;text-align:center}.error-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;padding:48px 32px;text-align:center}.error-icon{font-size:64px;margin-bottom:24px}.error-card h2{color:#333;font-size:24px;font-weight:700;margin-bottom:12px}.error-card p{color:#666;font-size:16px;line-height:1.6;margin-bottom:32px}.share-preview-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;overflow:hidden}.preview-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:48px 32px;text-align:center}.preview-icon{animation:bounce 2s infinite;font-size:64px;margin-bottom:16px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.preview-header h1{font-size:28px;font-weight:700;margin-bottom:8px}.preview-subtitle{font-size:16px;margin:0;opacity:.95}.preview-content{padding:32px}.preview-info-card{background:#f8f9fa;border-radius:12px;margin-bottom:20px;padding:24px}.preview-info-card h3{color:#333;font-size:18px;font-weight:600;margin-bottom:20px}.info-grid{grid-gap:16px;display:grid;gap:16px}.info-item{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:12px 0}.info-item:last-child{border-bottom:none}.info-label{color:#666;font-size:14px;font-weight:500}.info-value{color:#333;font-size:14px;font-weight:600}.info-value.highlight{color:#667eea;font-size:16px}.time-remaining{color:#f59e0b;font-size:13px;margin-left:4px}.info-badge{align-items:center;border-radius:20px;color:#fff;display:inline-flex;font-size:13px;font-weight:600;gap:4px;padding:6px 12px}.permission-description-card{background:#f0f2ff;border:2px solid #667eea;border-radius:12px;padding:20px}.permission-description-card h4{color:#333;font-size:16px;font-weight:600;margin-bottom:8px}.permission-description-card p{color:#666;font-size:14px;line-height:1.6;margin:0}.preview-actions{padding:0 32px 32px}.btn-accept{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;padding:16px 24px;transition:all .3s ease;width:100%}.btn-accept:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-accept:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-required{text-align:center}.login-message{color:#666;font-size:15px;margin-bottom:16px}.btn-login{background:#fff;border:2px solid #667eea;border-radius:12px;color:#667eea;cursor:pointer;font-size:18px;font-weight:700;padding:16px 24px;transition:all .3s ease;width:100%}.btn-login:hover{background:#667eea;box-shadow:0 6px 20px #667eea66;color:#fff;transform:translateY(-2px)}.btn-primary{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn-primary:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}@media (max-width:600px){.share-preview-page{padding:10px}.preview-header{padding:32px 24px}.preview-icon{font-size:48px}.preview-header h1{font-size:22px}.preview-subtitle{font-size:14px}.preview-content{padding:24px}.preview-info-card{padding:20px}.permission-description-card{padding:16px}.preview-actions{padding:0 24px 24px}.btn-accept,.btn-login{font-size:16px;padding:14px 20px}}
/*# sourceMappingURL=main.585e49e8.css.map*/