@import url("../../../css/reset.css") print, screen; /* Board List Header with Zoom Controls */ .board-list-header { display: flex; justify-content: center; margin: 1vh 0 2vh 0; padding: 1vh 0; } .zoom-controls { display: flex; align-items: center; gap: 0.5vw; background: rgba(255, 255, 255, 0.9); padding: 0.5vh 1vw; border-radius: 0.5vw; box-shadow: 0 0.2vh 0.5vh rgba(0,0,0,0.1); } .zoom-controls .board-header-btn { padding: 0.5vh 0.8vw !important; border-radius: 0.3vw !important; background: #fff !important; border: 1px solid #000 !important; transition: all 0.2s ease !important; text-decoration: none !important; color: #000 !important; display: flex !important; align-items: center !important; gap: 0.3vw !important; height: auto !important; line-height: normal !important; margin: 0 !important; float: none !important; overflow: visible !important; } .zoom-controls .board-header-btn i { color: #000 !important; float: none !important; display: inline !important; line-height: normal !important; margin: 0 !important; } .zoom-controls .board-header-btn:hover { background: #000 !important; border-color: #000 !important; color: #fff !important; } .zoom-controls .board-header-btn:hover i { color: #fff !important; } .zoom-controls .board-header-btn.is-active { background: #0079bf; color: white; border-color: #005a8a; } .zoom-controls .board-header-btn.is-active i { color: white; } .zoom-level { font-weight: bold; color: #333; min-width: 3vw; text-align: center; font-size: clamp(12px, 2vw, 14px); cursor: pointer; padding: 0.3vh 0.5vw; border-radius: 0.3vw; transition: all 0.2s ease; } .zoom-level:hover { background: #f0f0f0; color: #000; } .board-list { margin: 0 8px; } .board-list li { float: left; width: 20%; box-sizing: border-box; position: relative; } .board-list li.placeholder:after { content: ''; display: block; background: #ccc; border-radius: 3px; height: 106px; margin: 8px; } .board-list li.ui-sortable-helper { cursor: grabbing; transform: rotate(4deg); display: block !important; } .board-list li.starred .fa-star, .board-list li.starred .fa-star-o { opacity: 1; } .board-list .board-list-item { overflow: hidden; background-color: #999; color: #f6f6f6; min-height: 100px; font-size: 16px; line-height: 22px; border-radius: 3px; display: block; font-weight: 700; padding: 8px; margin: 8px; position: relative; text-decoration: none; word-wrap: break-word; } .board-list .board-list-item.template-container { border: 4px solid #fff; } .board-list .board-list-item.tile { background-size: auto; background-repeat: repeat; } .board-list .board-list-item-sub-name { color: rgba(255,255,255,0.5); display: block; font-size: 14px; font-weight: 400; line-height: 22px; } .board-list .board-list-item-desc { color: #fff; display: block; font-size: 14px; font-weight: 400; line-height: 18px; } .board-list .js-add-board { text-align: center; } .board-list .js-add-board .label { font-weight: normal; line-height: 56px; } .board-list .js-add-board :hover { background-color: #939393; } .board-list .fa-star, .board-list .fa-star-o { bottom: 0; font-size: 14px; height: 18px; line-height: 18px; opacity: 0; padding: 9px 9px; position: absolute; right: 0; top: 0; transition-duration: 0.15s; transition-property: color, font-size, background; } .board-list .fa-circle { bottom: 0; font-size: 10px; height: 10px; line-height: 10px; padding: 9px 9px; position: absolute; right: 0; transition-duration: 0.15s; transition-property: color, font-size, background; } .board-list .has-overtime-card-active { color: #eb4646 !important; } .board-list .no-overtime-card-active { color: #3cb500 !important; } .board-list .is-star-active { color: #fff; } .board-list .fa-clone { position: absolute; bottom: 0; font-size: 14px; height: 18px; line-height: 18px; opacity: 0; right: 0; padding: 9px 9px; transition-duration: 0.15s; transition-property: color, font-size, background; } .board-list .fa-archive { position: absolute; bottom: 0; font-size: 14px; height: 18px; line-height: 18px; opacity: 0; left: 0; padding: 9px 9px; transition-duration: 0.15s; transition-property: color, font-size, background; } .board-list li:hover a:hover .fa-star, .board-list li:hover a:hover .fa-clone, .board-list li:hover a:hover .fa-archive, .board-list li:hover a:hover .fa-star-o { color: #fff; } .board-list li:hover a .fa-star, .board-list li:hover a .fa-clone, .board-list li:hover a .fa-archive, .board-list li:hover a .fa-star-o { color: #fff; opacity: 0.75; } .board-list li:hover a .fa-star:hover, .board-list li:hover a .fa-clone:hover, .board-list li:hover a .fa-archive:hover, .board-list li:hover a .fa-star-o:hover { font-size: 18px; opacity: 1; } .board-list li:hover a .fa-star.is-star-active, .board-list li:hover a .fa-clone.is-star-active, .board-list li:hover a .fa-archive.is-star-active, .board-list li:hover a .fa-star-o.is-star-active { opacity: 1; } .board-backgrounds-list .board-background-select { box-sizing: border-box; display: block; float: left; width: 50%; padding-top: 12px; position: relative; z-index: 1; } .board-backgrounds-list .board-background-select:nth-child(-n + 2) { padding-top: 0; } .board-backgrounds-list .board-background-select:nth-child(2n) { padding-left: 6px; } .board-backgrounds-list .board-background-select:nth-child(2n+1) { padding-right: 6px; } .board-backgrounds-list .board-background-select .background-box { color: #fff; border-radius: 3px; background-size: cover; display: block; height: 74px; position: relative; width: 100%; cursor: pointer; display: flex; align-items: center; justify-content: center; } .board-backgrounds-list .board-background-select .background-box i.fa-check { font-size: 25px; color: #fff; } /* Mobile view styles - applied when isMiniScreen is true (iPhone, etc.) */ .board-list.mobile-view { height: calc(100vh - 120px); overflow-y: scroll !important; overflow-x: hidden; padding: 0 1rem; margin: 0; scrollbar-width: auto !important; scrollbar-color: #888 #f1f1f1; } .board-list.mobile-view li { width: 100%; float: none; display: block; margin-bottom: 1rem; padding-right: 50px; /* Space for drag handle */ } .board-list.mobile-view .board-list-item { overflow: visible; height: 8rem; width: 100%; margin: 0; padding-right: 50px; /* Ensure content doesn't overlap with drag handle */ } .board-list.mobile-view .board-list-item .details { padding-right: 50px; /* Extra space for drag handle */ width: 100%; box-sizing: border-box; } .board-list.mobile-view .board-list-item-sub-name { position: relative; top: -100px; left: -100px; } .board-list.mobile-view .board-handle { position: absolute; padding: 7px; top: 50%; transform: translateY(-50%); right: 10px; font-size: 24px; color: #fff; background: rgba(0,0,0,0.3); border-radius: 50%; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; z-index: 10; transition: background-color 0.2s ease; } .board-list.mobile-view .board-handle:hover { background: rgba(255, 255, 0, 0.8) !important; /* Yellow hover */ } /* Force scrollbar to be visible on mobile view */ .board-list.mobile-view::-webkit-scrollbar { width: 12px !important; display: block !important; visibility: visible !important; } .board-list.mobile-view::-webkit-scrollbar-track { background: #f1f1f1 !important; border-radius: 6px !important; display: block !important; visibility: visible !important; } .board-list.mobile-view::-webkit-scrollbar-thumb { background: #888 !important; border-radius: 6px !important; display: block !important; visibility: visible !important; } .board-list.mobile-view::-webkit-scrollbar-thumb:hover { background: #555 !important; } /* Force mobile view to have scrollable content */ .board-list.mobile-view { min-height: 100vh; /* Force content to be tall enough to scroll */ } .board-list.mobile-view::after { content: ''; display: block; height: 100px; } @media screen and (max-width: 800px), screen and (max-device-width: 800px), screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 800px), screen and (max-width: 800px) and (orientation: portrait), screen and (max-width: 800px) and (orientation: landscape) { .board-list { height: 100%; overflow-y: auto; overflow-x: hidden; padding: 0 1rem; margin: 0; } .board-list li { width: 100%; float: none; display: block; margin-bottom: 1rem; padding-right: 50px; /* Space for drag handle */ } .board-list .board-list-item { overflow: visible; height: 8rem; width: 100%; margin: 0; padding-right: 50px; /* Ensure content doesn't overlap with drag handle */ } .board-list .board-list-item .details { padding-right: 50px; /* Extra space for drag handle */ width: 100%; box-sizing: border-box; } .board-list .board-list-item-sub-name { position: relative; top: -100px; left: -100px; } .board-list .board-handle { position: absolute; padding: 7px; top: 50%; transform: translateY(-50%); right: 10px; font-size: 24px; color: #fff; background: rgba(0,0,0,0.3); border-radius: 50%; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; z-index: 10; transition: background-color 0.2s ease; } .board-list .board-handle:hover { background: rgba(255, 255, 0, 0.8) !important; /* Yellow hover */ } } /* Very small screens - ensure one board per row */ @media screen and (max-width: 360px) { .board-list li { width: 100% !important; float: none !important; display: block !important; } .board-list .board-handle { position: absolute; padding: 7px; top: 50%; transform: translateY(-50%); right: 10px; font-size: 24px; color: #fff; background: rgba(0,0,0,0.3); border-radius: 50%; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; } } /* Mobile - make all text and icons 2x bigger above #content on All Boards page */ @media screen and (max-width: 800px), screen and (max-device-width: 800px), screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 800px), screen and (max-width: 800px) and (orientation: portrait), screen and (max-width: 800px) and (orientation: landscape) { .wrapper { font-size: 2em !important; /* 2x bigger base font size for All Boards page */ } .wrapper * { font-size: inherit !important; /* Inherit the 2x scaling */ } .wrapper .fa, .wrapper .icon { font-size: 2em !important; /* 2x bigger icons */ } .board-list-header { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list-header h1 { font-size: 1em !important; /* Use inherited 2x scaling */ } .AllBoardTeamsOrgs { font-size: 1em !important; /* Use inherited 2x scaling */ } .AllBoardTeamsOrgs select { font-size: 1em !important; /* Use inherited 2x scaling */ } .AllBoardTeamsOrgs input { font-size: 1em !important; /* Use inherited 2x scaling */ } .AllBoardTeamsOrgs .fa { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .board-list-item { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .board-list-item-name { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .board-list-item-desc { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .minicard-members { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .minicard-lists { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .fa { font-size: 1em !important; /* Use inherited 2x scaling */ } .board-list .board-handle { font-size: 1em !important; /* Use inherited 2x scaling */ } } /* Fallback for iPhone devices using JavaScript detection - All Boards page */ .iphone-device .wrapper { font-size: 2em !important; /* 2x bigger base font size for All Boards page */ } .iphone-device .wrapper * { font-size: inherit !important; /* Inherit the 2x scaling */ } .iphone-device .wrapper .fa, .iphone-device .wrapper .icon { font-size: 2em !important; /* 2x bigger icons */ } .iphone-device .board-list-header { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list-header h1 { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .AllBoardTeamsOrgs { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .AllBoardTeamsOrgs select { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .AllBoardTeamsOrgs input { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .AllBoardTeamsOrgs .fa { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .board-list-item { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .board-list-item-name { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .board-list-item-desc { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .minicard-members { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .minicard-lists { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .fa { font-size: 1em !important; /* Use inherited 2x scaling */ } .iphone-device .board-list .board-handle { font-size: 1em !important; /* Use inherited 2x scaling */ } /* iPhone 12 Mini and very small screens - make everything much larger */ @media screen and (max-width: 400px) and (max-height: 900px) { .board-list { height: calc(100vh - 120px) !important; overflow-y: scroll !important; overflow-x: hidden !important; -webkit-overflow-scrolling: touch; padding: 0 0.5rem; } .board-list li { width: 100% !important; float: none !important; display: block !important; margin-bottom: 1.5rem !important; } .board-list .board-list-item { height: 12rem !important; /* Much taller */ width: 100% !important; margin: 0 !important; padding: 1rem !important; /* More padding */ font-size: 18px !important; /* Much larger text */ line-height: 1.4 !important; } .board-list .board-list-item .board-list-item-name { font-size: 20px !important; /* Larger board names */ font-weight: bold !important; margin-bottom: 0.5rem !important; } .board-list .board-list-item .board-list-item-desc { font-size: 16px !important; /* Larger descriptions */ line-height: 1.3 !important; } .board-list .board-list-item .minicard-members { font-size: 14px !important; /* Larger member avatars */ } .board-list .board-list-item .minicard-lists { font-size: 14px !important; /* Larger list counters */ } .board-list .board-handle { position: absolute; padding: 10px !important; top: 50%; transform: translateY(-50%); right: 15px !important; font-size: 28px !important; /* Much larger drag handle */ color: #fff; background: rgba(0,0,0,0.4) !important; border-radius: 50%; width: 50px !important; /* Larger handle */ height: 50px !important; display: flex; align-items: center; justify-content: center; z-index: 10; transition: background-color 0.2s ease; } .board-list .board-handle:hover { background: rgba(255, 255, 0, 0.8) !important; /* Yellow hover */ } /* Force scrollbar to be visible and larger */ .board-list::-webkit-scrollbar { width: 16px !important; /* Much wider scrollbar */ display: block !important; visibility: visible !important; } .board-list::-webkit-scrollbar-track { background: #f1f1f1 !important; border-radius: 8px !important; display: block !important; visibility: visible !important; } .board-list::-webkit-scrollbar-thumb { background: #666 !important; /* Darker for better visibility */ border-radius: 8px !important; display: block !important; visibility: visible !important; min-height: 50px !important; /* Minimum thumb size */ } .board-list::-webkit-scrollbar-thumb:hover { background: #333 !important; } /* Ensure scrollbar is always visible */ .board-list { scrollbar-gutter: stable; scrollbar-width: auto !important; min-height: 100vh !important; } .board-list::after { content: ''; display: block; height: 200px !important; /* More space to ensure scrolling */ } } .AllBoardTeamsOrgs { list-style-type: none; overflow: hidden; } .AllBoardTeams, .AllBoardOrgs, .AllBoardBtns { float: left; } .js-AllBoardOrgs { margin-left: 16px; } .AllBoardTeams { margin-left: 16px; } .AllBoardButtonsContainer { margin: 16px; } #filterBtn, #resetBtn { display: inline; } .js-board { display: block; } .minicard-members { padding: 6px 0 6px 8px; width: 100%; margin-bottom: 2px; margin-left: -4px; display: inline-block; } .minicard-lists { margin: 0 auto; max-width: 95%; height: 100%; } .flex { display: flex; } .flex-wrap { flex-wrap: wrap; } .flex-wrap .item { margin: 2px; padding-right: 6px; text-align: center; } /* Fix multiple scrollbars issue on mobile */ @media screen and (max-width: 800px), screen and (max-device-width: 800px), screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 800px), screen and (max-width: 800px) and (orientation: portrait), screen and (max-width: 800px) and (orientation: landscape) { .wrapper { overflow: hidden; height: 100vh; } .board-list { overflow-y: scroll !important; overflow-x: hidden !important; -webkit-overflow-scrolling: touch; scrollbar-width: thin; scrollbar-color: #888 #f1f1f1; height: calc(100vh - 120px); /* Ensure there's content to scroll */ } /* Force scrollbar to always be visible */ .board-list::-webkit-scrollbar { width: 12px !important; display: block !important; visibility: visible !important; } .board-list::-webkit-scrollbar-track { background: #f1f1f1 !important; border-radius: 6px !important; display: block !important; visibility: visible !important; } .board-list::-webkit-scrollbar-thumb { background: #888 !important; border-radius: 6px !important; display: block !important; visibility: visible !important; } .board-list::-webkit-scrollbar-thumb:hover { background: #555 !important; } /* Ensure scrollbar is always visible */ .board-list::-webkit-scrollbar-corner { background: #f1f1f1 !important; } /* Force scrollbar to be visible */ .board-list { scrollbar-gutter: stable; scrollbar-width: auto !important; min-height: 100vh; /* Force content to be tall enough to scroll */ } /* Ensure there's always content to scroll */ .board-list::after { content: ''; display: block; height: 100px; } /* Ensure only one scrollbar is visible */ body { overflow: hidden; } #content { overflow: hidden; } }