.header-dark{text-align:center;display:flex;justify-content:space-between;height:60px;padding:0 5%;box-sizing:border-box;background-color:#212122;color:#fff;box-shadow:0 2px 6px #32a376;z-index:1000}.header-light{text-align:center;display:flex;justify-content:space-between;height:60px;padding:0 5%;box-sizing:border-box;background-color:#fff;color:#000;box-shadow:0 2px 6px #32a37633;z-index:1000}.header-logo{width:10%;display:flex;align-items:center;justify-content:center}.header-logo-img{width:100px;cursor:pointer}.header-user-name{font-size:16px;font-weight:700;margin-right:5px}.header-small-text{font-size:12px}.header-navbar-div{width:60%;height:100%}.header-auth-button-div{width:30%;display:flex;height:40px;margin:auto 0;justify-content:center;gap:16px;align-items:center}.header-auth-button-div a{display:flex;align-items:center}.auth-button{letter-spacing:1px;width:120px;height:80%;border:none;border-radius:5px;color:#fff;background-color:#2db880;justify-content:center;cursor:pointer;font-size:14px}.header-link-img{width:35px;height:35px}.navbar{display:flex;align-items:center;width:100%;padding:0 5%;height:100%;box-sizing:border-box;font-size:16px}.navbar-links{list-style:none;display:flex;gap:20px;width:100%;justify-content:left;padding:0;margin:0}.navbar-links span{text-decoration:none;cursor:pointer}.navbar-links a:hover{color:#4bd674}footer{background-color:#424242;color:#fff;height:160px;padding:0 200px}.footer-content{display:flex;padding:1% 5%}.footer-content-area-1{width:30%}.footer-content-area-2{width:50%}.footer-content-area-3{width:20%}.footer-content-area-1-img-div{height:60%;display:flex;align-items:end}.footer-content-area-1-img{width:100px;cursor:pointer}.footer-content-area-1-text p{font-size:12px}.footer-content-area-2 p{font-size:10px}.footer-content-area-3-icons{height:55%;display:flex;gap:10px;justify-content:end;align-items:flex-end;margin-bottom:5%}.footer-content-area-3-icons img{width:30px;height:30px;cursor:pointer}.footer-content-area-3-btns{height:40%;display:flex;gap:10px;justify-content:end}.footer-content-area-3-btns button{border-radius:5px;border:1px solid white;height:80%;cursor:pointer}.footer-content-area-3-btns button:first-child{font-size:12px;background-color:#424242;color:#fff;width:60px}.footer-content-area-3-btns button:last-child{font-size:10px;background-color:#fff;color:#424242;width:130px}body,html{height:100%;margin:0;background-color:#f5f5f5}.wrapper{display:flex;flex-direction:column;min-height:100vh}.content{flex:1}.not-found-container{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;height:100%;background-color:#f9f9f9}.not-found-h1{font-size:3rem;margin-bottom:1rem;color:#333}.not-found-p{font-size:1.25rem;margin-bottom:2rem;color:#666}.home-button{padding:10px 20px;font-size:1rem;color:#fff;background-color:#007bff;border:none;border-radius:5px;cursor:pointer}.home-button:hover{background-color:#0056b3}.signin-wrapper{display:flex;justify-content:center;align-items:center;margin-top:100px}.signin-container{background-color:#fafafa;padding:3rem;border-radius:8px;box-shadow:0 4px 8px #2db88033;width:100%;max-width:400px;box-sizing:border-box}.signin-header{text-align:center;margin-bottom:1.5rem}.signin-header span{font-size:24px;font-weight:600}.signin-inputs{margin-bottom:1.5rem;width:100%}.signin-input{background-color:#fff;margin-bottom:1rem;width:100%;display:flex;align-items:center;padding:0 10px;border:1px solid #ccc;border-radius:5px;box-sizing:border-box}.envelope-icon,.lock-icon{font-size:.8rem}.input-field.signin{padding:.6rem;box-sizing:border-box;border:none;margin-left:5px;outline:none}.input-field::placeholder{color:#ccc;font-weight:700}.signin-options{text-align:right;margin-bottom:1.5rem;display:flex;justify-content:space-between;font-size:12px;color:#888;font-weight:700}.signin-checkbox-container,.signin-link-container{display:flex;align-items:center}.signin-link-container{justify-content:start}.signin-checkbox{appearance:none;-webkit-appearance:none;background-color:#f0f0f0;border:1px solid #ddd;border-radius:2px;cursor:pointer;width:12px;height:12px;position:relative;outline:none}.signin-checkbox:checked{background-color:#4caf50;border-color:#4caf50}.signin-checkbox:checked:after{content:"";position:absolute;top:.1px;left:2.5px;width:3px;height:6px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.signin-checkbox-container span{cursor:pointer}.signin-link{cursor:pointer;display:inline}.signin-button{text-align:center;margin-bottom:1.5rem;width:100%}.signin-button button{width:100%;color:#fff;font-weight:700;font-size:.8rem;padding:.5rem;border-radius:3px;cursor:pointer;border:none;margin:0;background-color:#2db880;letter-spacing:2px}.signin-divider{display:flex;align-items:center;text-align:center;font-size:.8rem;letter-spacing:-.05rem;color:#b8b8b8;font-weight:700;margin-bottom:10px}.signin-divider:before,.signin-divider:after{content:"";flex:1;border-bottom:2px solid #dfdfdf}.divider-text{margin-left:10%;margin-right:5%;letter-spacing:.5px}.signin-social{display:block;justify-content:center;margin-bottom:1.5rem;width:100%;text-align:center}.signin-social img{width:300px;height:40px;cursor:pointer;border-radius:5px}.signin-social img:last-child{border:1px solid #ccc;box-sizing:border-box}.signin-footer{display:flex;justify-content:center;text-align:center}.signin-footer span:first-child,.signin-footer span:last-child{margin-right:5px;font-size:.8rem}.signin-footer span:first-child{color:#888}.signin-footer span:last-child{color:#2db880;font-weight:700}.date-picker{font-family:sans-serif;position:absolute;width:100%;background:#fff;border:1px solid #ddd;border-radius:5px;box-shadow:0 2px 10px #0000001a;z-index:1000}.header{display:flex;justify-content:space-between;align-items:center;padding:5px;background:#46d89e;border-bottom:1px solid #ddd}.nav-btn,.close-btn{border:none;background:none;font-size:18px;cursor:pointer;padding:0;margin:0}.close-btn{color:#dc3545;width:10%}.weekdays,.days{display:grid;grid-template-columns:repeat(7,1fr)}.weekday,.day{text-align:center;padding:5px;font-size:14px}.weekday{background:#f1f1f1}.day{cursor:pointer;-webkit-user-select:none;user-select:none}.day.empty{background:#f9f9f9}.day.selected{background:#007bff;color:#fff;border-radius:50%}.month-picker,.year-picker{display:grid;gap:5px;padding:10px;justify-items:center}.month-picker,.year-picker{grid-template-columns:repeat(4,1fr)}.month,.year{cursor:pointer;padding:10px;font-size:14px;border:1px solid #ddd;border-radius:5px;background-color:#f9f9f9;text-align:center;width:100%}.month.selected,.year.selected{background-color:#007bff;color:#fff}@media screen and (max-width:350px){.month,.year{padding:4px;font-size:10px;width:100%}}@media screen and (max-width:250px){.month,.year{padding:2px;font-size:9px;width:100%}}.signup-wrapper{display:flex;justify-content:center;align-items:center;background-color:#f5f5f5;padding:1rem 0}.signup-container{background-color:#fafafa;padding:2rem;border-radius:8px;box-shadow:0 6px 10px #2db8801a;width:100%;max-width:500px;box-sizing:border-box}.signup-header{text-align:center;margin-bottom:1.5rem;font-size:24px}.signup-form{margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-label{display:flex;justify-content:start;margin-bottom:.5rem;gap:10px}.label-essential{color:red}.form-input{display:flex;align-items:center;position:relative}.input-field.signup{width:100%;padding:.75rem;border:1.5px solid #cfcfcf;border-radius:4px;box-sizing:border-box;outline:none}.form-error{color:red;font-size:.875rem;margin-top:.5rem}.input-field.signup.email::placeholder{font-size:10px}.calendar-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:1rem;color:#666;cursor:pointer}.privacy-section{margin-bottom:1.5rem}.privacy-header{font-weight:700;margin-bottom:.5rem}.privacy-table{display:table;width:100%;border-collapse:collapse}.privacy-row{display:table-row}.privacy-cell{display:table-cell;padding:.5rem;border:1px solid #ddd}.agree-section{display:flex;align-items:center;margin-bottom:1.5rem}.agree-checkbox{margin-right:.5rem;display:flex;align-items:center}.checkbox-input{appearance:none;-webkit-appearance:none;background-color:#f0f0f0;border:1px solid #ddd;border-radius:2px;cursor:pointer;width:12px;height:12px;position:relative;outline:none}.checkbox-input:checked{background-color:#4caf50;border-color:#4caf50}.checkbox-input:checked:after{content:"";position:absolute;top:.1px;left:2.5px;width:3px;height:6px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.agree-text{display:flex;align-items:center}.agree-text span:last-child{margin-left:10px;color:#ccc}.signup-button-div{text-align:center}.signup-button{background-color:#2db880;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;transition:background-color .3s;cursor:pointer}.signup-button:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.agree-dropdown{position:relative;display:inline-block;cursor:pointer}.agree-detail{display:flex;margin-bottom:1.5rem;width:100%;text-align:center;justify-content:center;gap:20px}.agree-detail span{color:#aaa;cursor:pointer;font-size:14px;text-decoration-line:underline}.help-wrapper{display:flex;justify-content:center;align-items:center;margin-top:100px}.help-container{background-color:#f8faf7;padding:3rem;border-radius:8px;box-shadow:0 4px 8px #2db88033;width:100%;max-width:400px;box-sizing:border-box}.help-header{text-align:center;margin-bottom:1.5rem}.help-header span{font-size:24px;font-weight:600}.help-selections{cursor:pointer;height:40px;display:flex}.help-selection{display:flex;width:50%;justify-content:center;align-items:center;letter-spacing:-.1rem;font-size:.9rem;font-weight:700}.help-selection.active{border-top:2px solid #2db880;background-color:#f8faf7;color:#2db880}.help-selection:first-child:not(.active){background-color:#f0f0f0;color:#8c8c8c;border-right:2px solid #2db880;border-bottom:2px solid #2db880}.help-selection:last-child:not(.active){background-color:#e6e6e6;color:#8c8c8c;border-left:2px solid #2db880;border-bottom:2px solid #2db880}.help-comment{height:50px;display:flex;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;letter-spacing:-.03rem;color:#aaa}.help-input-div{display:flex;flex-direction:column;align-items:center;gap:10px;height:90px;width:300px;margin:0 auto}.help-input-container{border:1px solid rgb(216,216,216);border-radius:5px;height:35px;width:300px;display:flex;justify-content:start;align-items:center}.help-input{border:none;font-size:.7rem;letter-spacing:-.05rem;outline:none;padding-left:10px;background-color:#f8faf7}input::placeholder{color:#c2c2c2;font-weight:700}.recovery-success-div{width:100%;height:37%;display:flex;flex-direction:column;justify-content:center;align-items:center}.recovery-success-text{height:58%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;letter-spacing:-.05rem;width:60%}.recovery-success-userdata{background-color:#fafafa;border-radius:5px;height:28%;width:100%;border:1px solid #c7c7c79d;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#8585859d;font-weight:700}.help-button-wrapper{height:70px;display:flex;align-items:center;justify-content:center;margin:0 auto}.help-button{width:300px;color:#fff;font-weight:700;font-size:1rem;padding:5px;height:35px;border-radius:3px;cursor:pointer;border:none;margin:0;background-color:#2db880}.help-links{height:12%;display:flex;width:45%;margin:0 auto}.help-link{width:50%;height:35%;font-size:.8rem;font-weight:700;color:#a1a1a1}.help-link.sign-in{text-align:end;border-right:.5px solid rgb(214,214,214);padding-right:15px}.help-link.sign-up{text-align:start;border-left:.5px solid rgb(214,214,214);padding-left:15px}.help-link span{cursor:pointer}.support-container{max-width:1200px;margin:50px auto;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:block}.support-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.support-title{font-size:30px;font-weight:700;margin-left:20px}.support-title-text p{margin:5px 0;font-size:28px;font-weight:700;background:linear-gradient(90deg,#539129,#feb47b);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.support-img-container{display:flex;justify-content:center;align-items:center}.support-img-container img{width:200px;height:100px}.support-content{padding:20px}.faq-category-filter{margin-bottom:20px;display:flex;justify-content:center;flex-wrap:wrap}.faq-category-filter button{margin-right:10px;margin-bottom:10px;padding:10px 20px;border:none;background-color:#2db880;color:#fff;border-radius:4px;cursor:pointer}.faq-category-filter button.active{background-color:#1e589b}.faq-category-filter button:hover{background-color:#1e9b69}.faq-list{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.faq-item{width:25%;margin-bottom:20px;padding:20px;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;cursor:pointer}.faq-item h3{margin-top:0}.faq-categories{margin-top:10px}.faq-category{display:inline-block;margin-right:10px;padding:5px 10px;background-color:#e0e0e0;border-radius:4px}.pagination{display:flex;justify-content:center;margin-top:20px}.pagination button{margin:0 5px;padding:10px;width:40px;height:40px;border:none;background-color:#2db880;color:#fff;border-radius:4px;cursor:pointer}.pagination button:hover{background-color:#1e9b69}.pagination button:disabled{background-color:#e0e0e0;cursor:not-allowed}.pagination .active{background-color:#1e589b}.support-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center}.support-modal-content{background:#fff;padding:20px;border-radius:5px;max-width:500px;width:100%;position:relative}.support-modal-close{position:absolute;top:10px;right:10px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#ff7e5f;transition:color .3s}.support-modal-close:hover{color:#ff6842;background-color:#fff}.support-footer{display:flex;justify-content:center;padding:20px;gap:100px;background-color:#f1f1f1;border-top:1px solid #e0e0e0}.support-footer-left,.support-footer-right{display:flex;flex-direction:column;justify-content:center}.support-footer-left-text{font-size:18px;font-weight:700;padding:10px;text-align:center}.support-left-btn-container{display:flex;justify-content:center;align-items:center}.support-left-btn-container img{width:300px;margin:10px;border-radius:20px}.support-footer-right{justify-content:end;padding:30px 0}.support-footer-right p{margin:0;font-size:10px;color:#979797;font-weight:700}.support-footer-right p:first-child{margin:5px 0;font-size:13px;font-weight:500;color:#000}.support-footer-right p:nth-child(2){margin:5px 0;font-size:24px;color:#000}*{font-family:Noto Sans KR,serif}.policy-container{max-width:800px;margin:0 auto;padding:20px;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a}.policy-h1{font-size:2rem;margin-bottom:20px;color:#333;text-align:center}.policy-section-title{font-size:1.5rem;margin-top:20px;margin-bottom:10px;color:#555}.policy-content{font-size:15px;line-height:1.6;color:#666}.policy-button{display:block;width:100%;padding:10px;margin-top:20px;background-color:#2db881;color:#fff;font-size:1rem;text-align:center;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.my-container{max-width:1200px;margin:50px auto;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:flex;height:590px}.my-aside{width:300px;background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;padding:10px 20px}.my-aside-title{height:70px;font-size:1.7rem;color:#2db880;font-weight:700}.my-aside-title span{cursor:pointer}.my-aside-profile{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:20px;height:170px}.my-aside-profile-photo{display:flex;justify-content:center;align-items:center;border:1px solid #ddd;border-radius:50%;margin-bottom:10px}.my-aside-profile-name{font-size:1.3rem;font-weight:700}.my-aside-profile-email{font-size:.8rem;color:#666}.my-aside-list{height:270px;padding:20px;display:flex;justify-content:center}.my-aside-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;align-items:center}.my-aside-list li{width:200px;padding:12px;margin:8px 0;background-color:#f5f5f5;border-radius:10px;text-align:center;cursor:pointer;font-weight:600;font-size:16px;color:#333;transition:none}.my-aside-list li:hover{background-color:#dcdcdc}.my-aside-list span{font-size:16px;font-weight:700;color:inherit}.my-aside-list li.active{background-color:#2db880;color:#fff;font-weight:700}.my-content{width:900px;padding:10px 60px}.my-content-info{width:100%}.my-info-container{border-radius:15px;background-color:#fff;margin-bottom:20px;box-shadow:0 4px 8px #0000001a}.my-info-title{font-size:1.2rem;font-weight:700;background-color:#2db880;border-radius:15px 15px 0 0;color:#fff;width:100%;cursor:pointer;padding:5px 0}.my-info-title span{margin-left:10px}.my-info-content{padding:20px;display:block}.my-info-content-item{height:40px;display:flex;margin-bottom:10px;align-items:center;border-bottom:#2e795b5b 1px solid}.my-info-content-item img{width:25px;height:25px;margin-right:10px}.my-info-content-item input{border:none;font-size:1rem;flex-grow:1;outline:none;background-color:#d3d3d3;padding-left:10px}.my-info-content-item input:disabled{background-color:#fff;color:#000}.my-info-content-item button{border:none;outline:none;cursor:pointer;padding:5px;border-radius:5px}.my-info-content-item button:hover{background-color:#2db880;color:#fff}.my-content-detail{width:100%}.my-detail-container{border-radius:15px;background-color:#fff;margin-bottom:20px;box-shadow:0 4px 8px #0000001a}.my-detail-title{font-size:1.2rem;font-weight:700;background-color:#e0e0e0;border-radius:15px 15px 0 0;color:#000;width:100%;cursor:pointer;padding:5px 0}.my-detail-title span{margin-left:10px}.my-detail-content{padding:10px 20px;display:block}.my-detail-content-title{font-size:1rem;font-weight:700;margin-bottom:10px}.my-detail-content-item{height:40px;display:flex;margin-bottom:10px;align-items:center;border-bottom:#2e795b5b 1px solid}.my-detail-content-item img{width:25px;height:25px;margin-right:10px}.my-detail-content-item span{width:70px;height:22px;margin-right:10px;padding-right:10px;border-right:2px solid #888;font-size:14px;display:flex;justify-content:center}.my-detail-content-item-last-span{font-size:12px!important}.my-detail-content-item input{border:none;font-size:1rem;flex-grow:1;outline:none;background-color:#d3d3d3;padding-left:10px}.my-detail-content-item input:disabled{background-color:#fff;color:#000}.my-detail-content-item button{border:none;outline:none;cursor:pointer;padding:5px;border-radius:5px}.my-detail-content-item button:hover{background-color:#2db880;color:#fff}.my-detail-content-item-count{border-right:none!important;font-size:16px!important}.my-detail-sample-item{cursor:pointer}.my-delete-user-container p{font-size:1.1rem;font-weight:700;margin-bottom:10px;width:100%}.my-delete-user-actions{width:100%;display:flex;justify-content:center}.my-delete-user-actions button{width:120px;padding:12px;margin:10px;border:1px solid #d9534f;border-radius:5px;background-color:#fff;color:#d9534f;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .3s,color .3s;text-decoration:none;text-underline-offset:3px;text-decoration-thickness:2px}.my-delete-user-actions button:hover{background-color:#d9534f;color:#fff;border-color:#d9534f}.my-modal{display:flex;justify-content:center;align-items:center;position:fixed;z-index:1;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#000;background-color:#0006}.my-modal-content{border-radius:15px;background-color:#fefefe;margin:auto;padding:20px;border:1px solid #888;width:80%;max-width:500px;text-align:center}.my-modal-content input{width:80%;padding:10px;margin:10px 0;border:1px solid #ccc;border-radius:5px;font-size:16px}.my-modal-content button{width:30%;padding:10px;margin:10px 0;border:none;border-radius:5px;background-color:#2db880;color:#fff;font-size:16px;cursor:pointer}.my-modal-content button:hover{background-color:#249d6e}.my-modal-content button:disabled{background-color:#ccc}.my-modal-close{color:#aaa;float:right;font-size:28px;font-weight:700}.my-modal-close:hover,.my-modal-close:focus{color:#000;text-decoration:none;cursor:pointer}.my-input-wrapper{position:relative;width:100%}.my-input-wrapper .my-timer{position:absolute;right:50px;top:50%;transform:translateY(-50%);font-size:16px;color:#888;font-weight:700;background-color:transparent;pointer-events:none}.main-container{position:relative;width:100%;height:100vh;overflow:hidden}.sections-wrapper{width:100%;height:100vh;transition:transform .7s ease-in-out}.scroll-page{width:100%;height:100vh;display:flex;justify-content:center}.section-container{width:100%}.section-last-container{display:flex;flex-direction:column;justify-content:space-between;align-items:center;width:100%;height:100vh;padding:20px 0}.section-last-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.section-last-footer{width:100%;position:relative;bottom:0}.titles-container{position:fixed;top:10%;right:5%;display:flex;flex-direction:column;gap:10px;z-index:1000}.title-item{padding:10px;background-color:#0009;color:#fff;border-radius:5px;cursor:pointer;transition:background-color .3s ease-in-out}.title-item.active{background-color:#2db880}.sample-list-container{max-width:1200px;margin:50px auto;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:block;height:90vh}.sample-list-title{display:flex;justify-content:center;align-items:center;padding-top:20px;padding-bottom:10px;font-size:20px;font-weight:700;color:#2db880}.sample-list-description{display:flex;flex-direction:column;justify-content:center;align-items:center;margin-bottom:10px}.sample-list-description p{margin:0;font-size:30px;font-weight:700}.sample-list-search{display:flex;justify-content:center;align-items:center;margin-bottom:20px;gap:10px}.sample-list-search input{height:40px;width:300px;box-sizing:border-box;border:2px solid #c5c5c5;border-radius:5px;padding:0 10px}.sample-list-search-button{width:100px;height:40px;background-color:#3b3b3b;display:flex;align-items:center;justify-content:center;border-radius:5px;cursor:pointer;color:#fff}.sample-list-reset-button{padding:8px 15px;background-color:#ccc;color:#fff;border-radius:5px;cursor:pointer}.sample-list-reset-button:hover{background-color:#999}.sample-list-search-filter{width:40px;height:40px;background-color:#2db880;display:flex;align-items:center;justify-content:center;border-radius:5px;position:relative;cursor:pointer}.sample-list-search-filter .line{width:30px;height:3px;background:#fff;border-radius:2px;position:absolute}.sample-list-search-filter .line:nth-child(1){top:10px;left:5px}.sample-list-search-filter .line:nth-child(2){top:18px;left:5px}.sample-list-search-filter .line:nth-child(3){top:26px;left:5px}.sample-list-search-filter .circle{width:6px;height:6px;background:#fff;border-radius:50%;position:absolute}.sample-list-search-filter .circle:nth-child(4){top:8px;left:24px}.sample-list-search-filter .circle:nth-child(5){top:16px;left:10px}.sample-list-search-filter .circle:nth-child(6){top:24px;left:16px}.sample-list-filter-results{display:flex;flex-wrap:wrap;justify-content:center;gap:20px 60px;width:100%}.sample-item{display:flex;justify-content:space-between;background-color:#fff;padding:15px 30px;border-radius:8px;box-shadow:0 2px 4px #0000001a;min-width:400px;text-align:start;font-size:18px;font-weight:700;color:#333;cursor:pointer}.sample-item-open-text{border-left:2px solid #acacac;padding:0 10px;display:flex;align-items:center}.sample-item-open-text:after{content:">";font-size:1.2rem;margin-left:15px}.sample-list-pagination{display:flex;justify-content:center;margin-top:40px}.sample-list-pagination button{margin:0 5px;padding:10px;width:40px;height:40px;border:none;background-color:#2db880;color:#fff;border-radius:4px;cursor:pointer}.sample-list-pagination button:hover{background-color:#1e9b69}.sample-list-pagination button:disabled{background-color:#e0e0e0;cursor:not-allowed}.sample-list-pagination .active{background-color:#1e589b}.sample-list-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.sample-list-modal-container{padding:30px;width:700px;background:#fff;border-radius:4px;box-shadow:0 0 10px #0000001a}.sample-list-modal-title{display:flex;align-items:center;font-size:20px;font-weight:700;margin-bottom:20px}.sample-list-modal-search-filter{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:5px;position:relative;cursor:pointer}.sample-list-modal-search-filter .line{width:30px;height:3px;background:#666;border-radius:2px;position:absolute}.sample-list-modal-search-filter .line:nth-child(1){top:10px;left:5px}.sample-list-modal-search-filter .line:nth-child(2){top:18px;left:5px}.sample-list-modal-search-filter .line:nth-child(3){top:26px;left:5px}.sample-list-modal-search-filter .circle{width:6px;height:6px;background:#666;border-radius:50%;position:absolute}.sample-list-modal-search-filter .circle:nth-child(4){top:8px;left:24px}.sample-list-modal-search-filter .circle:nth-child(5){top:16px;left:10px}.sample-list-modal-search-filter .circle:nth-child(6){top:24px;left:16px}.sample-list-modal-title span{margin-left:10px}.sample-list-modal-input-container{display:flex;margin-bottom:10px}.sample-list-modal-input-container div{width:50%}.sample-list-modal-selected-local-text{font-size:14px;align-items:end;display:flex;margin-left:10px}.sample-list-modal-result-container{display:flex;text-align:center;justify-content:center;gap:10px;margin-top:10px;height:200px}.sample-list-modal-select-local,.sample-list-modal-selected-local{width:50%;border:1px solid #d4d4d4;overflow-y:auto;text-align:left}.search-result-list{padding:0;margin:0;list-style:none}.search-result-item{padding:2px 5px;margin-bottom:5px;border-radius:4px;display:flex;align-items:center;gap:10px}.search-result-item label{display:flex;align-items:center;width:100%;cursor:pointer}.search-result-item:hover{background-color:#d4d4d4}.search-result-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.sample-list-modal-selected-local-list ul{padding:0;margin:0;list-style:none}.selected-item{display:flex;justify-content:space-between;align-items:center;padding:2px 5px;border-radius:4px;margin-bottom:5px}.remove-btn{padding:0;background:none;border:none;color:#fff;font-size:14px;cursor:pointer}.remove-btn:hover{color:red}.category-btn{padding:5px 10px;margin:5px;border:1px solid #ccc;cursor:pointer;background-color:#fff;transition:all .3s ease}.category-btn.selected{background-color:#007bff;color:#fff;border-color:#007bff}.sample-detail-container{max-width:1200px;margin:50px auto;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:block;padding:20px}.sample-detail-title{display:flex;justify-content:start;align-items:center;margin-bottom:10px;font-size:30px;font-weight:700}.sample-detail-header-items{display:flex;justify-content:space-between;align-items:center;align-items:end;margin-bottom:10px}.sample-detail-description{display:flex;flex-direction:column;justify-content:start;margin-bottom:10px}.sample-detail-description p{margin:0;font-size:14px;font-weight:700;color:#666}.sample-detail-btns{display:flex;justify-content:space-between;align-items:center;gap:20px}.sample-detail-btns div{display:flex;justify-content:center;align-items:center;border-radius:5px;cursor:pointer;border:1px solid #666666;padding:10px}.sample-detail-image-container{display:flex;justify-content:center;align-items:center;margin-bottom:10px}.sample-detail-item{width:50%;display:flex;flex-direction:column;justify-content:center;text-align:center;padding:10px}.sample-detail-document-name{padding-bottom:10px}.myCanvas{width:100%;height:700px;background-color:#d3d3d3;border:2px solid black}.sample-detail-local-list span{margin-right:10px}.sample-detail-back,.sample-detail-text,.sample-detail-tel{text-align:center;margin-bottom:20px}:root{--brand-green:#2db880;--brand-green-600:#1e9b69;--brand-blue:#1e589b;--ink-900:#222;--ink-700:#444;--ink-500:#65727a;--ink-300:#8a959c;--bg-75:#f7f9f9;--line-200:#e3e6e6}.project-sidebar{width:240px;background:var(--bg-75);border-right:1px solid var(--line-200);padding:18px 0;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto}.project-sidebar .sidebar-title{font-weight:800;font-size:16px;color:var(--ink-900);padding:0 20px 12px}.project-sidebar .sidebar-nav{display:flex;flex-direction:column;gap:2px}.project-sidebar .nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:11px 20px;border:0;background:transparent;color:var(--ink-700);text-decoration:none;cursor:pointer;border-left:3px solid transparent;transition:background .15s,color .15s,border-left-color .15s}.project-sidebar .nav-item:hover{background:#eef6f3;color:var(--brand-green-600)}.project-sidebar .nav-item.active{background:#e9f7f1;color:var(--brand-green);font-weight:700;border-left-color:var(--brand-green)}.project-sidebar .nav-icon{width:18px;text-align:center;color:inherit}@media(max-width:1100px){.project-sidebar{position:static;height:auto}}.sidebar-title-link{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;border:0;background:transparent;font-weight:800;font-size:16px;color:#222;cursor:pointer;text-align:left}.sidebar-title-link{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;border:0;background:transparent;font-weight:800;font-size:16px;color:#222;text-align:left;cursor:pointer}.sidebar-title-link:hover{background:#eef6f3;color:#1e9b69}.project-sidebar .nav-item.disabled{opacity:.55;cursor:not-allowed}.project-sidebar .nav-item.disabled:hover{background:transparent;color:inherit}.nav-item{position:relative}.nav-badge{margin-left:auto;font-size:11px;line-height:1;padding:2px 6px;border-radius:999px;background:#e53e3e;color:#fff}:root{--brand-green: #2db880;--brand-green-600: #1e9b69;--brand-blue: #1e589b;--ink-950: #111;--ink-900: #222;--ink-800: #2f3437;--ink-700: #444;--ink-600: #556068;--ink-500: #65727a;--ink-400: #7f8a91;--ink-300: #8a959c;--bg-50: #fbfcfc;--bg-75: #f7f9f9;--card: #f6faf8;--line-100: #eef2f3;--line-200: #e6eaeb;--danger: #e4573d;--danger-600: #c94a34;--focus: #3b82f6;--shadow-sm: 0 2px 6px rgba(0, 0, 0, .06);--shadow-md: 0 6px 14px rgba(0, 0, 0, .1)}.project-layout{display:flex;align-items:stretch;background:#fff}.project-main{flex:1;padding:24px 24px 40px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.page-title-row{display:flex;justify-content:space-between}.page-title{font-size:22px;font-weight:800;color:var(--ink-900);margin:6px 0 18px}.cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.card{background:var(--card);border:1px solid var(--line-200);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow-sm)}.card-title{font-weight:700;margin-bottom:10px;color:var(--ink-700)}.empty-card{display:flex;align-items:center;gap:12px;padding:18px;border:1px dashed #d7dddd;border-radius:10px;background:#fff;color:var(--ink-500)}.empty-card i{color:#b8c4ca;font-size:18px}.stats{color:var(--brand-green);font-weight:800}.table-wrap{margin-top:16px}.tbl-main{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line-200);border-radius:12px;overflow:hidden}.tbl-main th,.tbl-main td{border-bottom:1px solid var(--line-200);padding:12px 14px;text-align:left}.tbl-main thead th{background:var(--bg-75);color:var(--ink-700);font-weight:800}.tbl-main tbody tr:last-child td{border-bottom:0}.tbl-main tbody tr:hover{background:#fafbfb}.tbl-main .empty{text-align:center;color:var(--ink-300);padding:28px 0}.tbl-main .link{color:#167c5d;cursor:pointer;font-weight:600}.tbl-main .link:hover{text-decoration:underline}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;border:1px solid var(--line-200);background:#fff;color:var(--ink-700)}.badge.PLANNING{background:#fff8ec;color:#a86411;border-color:#ffe7c2}.badge.IN_PROGRESS{background:#eaf8f2;color:#1c8c68;border-color:#d7efe5}.badge.PAUSED{background:#f4f6f8;color:#5a6470;border-color:#e2e7ec}.badge.HOLD{background:#fff4f4;color:#b83b2d;border-color:#ffdcdc}.badge.COMPLETED{background:#ecf6ff;color:#2b7fc9;border-color:#d6eaff}.btn{--btn-bg: var(--brand-green);--btn-fg: #fff;--btn-bg-hover: var(--brand-green-600);--btn-ring: var(--focus);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border:0;border-radius:10px;background:var(--btn-bg);color:var(--btn-fg);font-weight:700;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s ease,transform .04s ease,box-shadow .15s ease}.btn:hover{background:var(--btn-bg-hover)}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:2px solid var(--btn-ring);outline-offset:2px}.btn:disabled,.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn.primary{--btn-bg: var(--brand-blue);--btn-bg-hover: color-mix(in srgb, var(--brand-blue) 92%, #000 8%)}.btn.danger{--btn-bg: var(--danger);--btn-bg-hover: var(--danger-600)}.btn.outline{--btn-bg: #fff;--btn-fg: var(--ink-800);background:#fff;border:1px solid var(--line-200)}.btn.outline:hover{background:#f7faf9}.btn.ghost{--btn-bg: transparent;--btn-fg: var(--brand-blue);background:transparent;border:1px dashed transparent}.btn.ghost:hover{background:#f3f6fb;border-color:#e5eefc}.btn.sm{padding:8px 10px;border-radius:8px;font-size:12px}.btn.lg{padding:12px 18px;border-radius:12px;font-size:15px}.btn.icon{width:36px;height:36px;padding:0;border-radius:50%;display:inline-grid;place-items:center}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;width:min(560px,calc(100% - 32px));border-radius:14px;box-shadow:var(--shadow-md);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line-200)}.modal-header h3{margin:0;font-size:18px}.modal-close{background:transparent;border:0;font-size:22px;cursor:pointer;line-height:1;padding:4px;border-radius:8px}.modal-close:hover{background:#f4f6f8}.modal-body{padding:16px}.form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.form-row.two{flex-direction:row;gap:12px}.form-row.two>div{flex:1;display:flex;flex-direction:column;gap:8px}.form-row input,.form-row select{border:1px solid var(--line-200);border-radius:10px;padding:10px 12px;font-size:14px}.form-row input:focus,.form-row select:focus{outline:2px solid var(--focus);outline-offset:1px}.req{color:var(--danger);margin-left:4px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:0 16px 16px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:10px 14px;border-radius:10px;font-size:14px;z-index:1100;box-shadow:var(--shadow-md)}@media(max-width:1100px){.cards{grid-template-columns:1fr}}@media(max-width:720px){.page-header{flex-direction:column;align-items:flex-start;gap:10px}.tbl-main th,.tbl-main td{padding:10px 12px}}.ellipsis-1{display:inline-block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-list{list-style:none;margin:0;padding:8px 12px;display:grid;gap:8px}.mini-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px}.mini-link{all:unset;cursor:pointer;color:var(--link, #2a6bff)}.mini-link:hover{text-decoration:underline;background-color:transparent;font-weight:700}.mini-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:24rem}.badge.sm{font-size:12px;padding:2px 6px;border-radius:10px}.mini-dates{font-size:12px;color:#8a959c}:root{--brand-green:#2db880;--brand-blue:#1e589b;--ink-900:#222;--ink-700:#444;--ink-500:#65727a;--line-200:#e6eaeb;--bg-75:#f7f9f9}.unauth-wrap{min-height:calc(100vh - 320px);display:flex;align-items:center;justify-content:center;background:#fff;padding:24px}.unauth-card{width:100%;max-width:560px;background:#fff;border:1px solid var(--line-200);border-radius:16px;padding:28px 24px;box-shadow:0 8px 24px #0000000f;text-align:center}.unauth-icon{width:64px;height:64px;margin:0 auto 10px;display:grid;place-items:center;background:#e9f7f1;color:var(--brand-green);border-radius:16px;font-size:28px}.unauth-title{margin:8px 0 6px;font-size:22px;font-weight:800;color:var(--ink-900)}.unauth-desc{margin:0 0 12px;color:var(--ink-500);line-height:1.6}.unauth-contact{margin:12px auto 18px;padding:12px;border:1px dashed var(--line-200);border-radius:10px;background:var(--bg-75);text-align:left;max-width:420px}.contact-item{display:flex;align-items:center;gap:8px;color:var(--ink-700);margin:4px 0}.contact-item i{width:18px;text-align:center;color:var(--brand-green)}.unauth-actions{display:flex;justify-content:center;gap:10px;margin-top:4px}.btn{padding:10px 14px;border:0;border-radius:8px;cursor:pointer;background:#e9f7f1;color:#167c5d;font-weight:700}.btn:hover{filter:brightness(.98)}.btn.primary{background:var(--brand-blue);color:#fff}.btn.primary:hover{filter:brightness(.95)}.sched-root{isolation:isolate}.page-title{font-size:20px;font-weight:800;margin:8px 0 14px}.sched{--leftW: 520px;--rowH: 42px;--line: #e6eaeb;--dash: #eef1f3;--col-gear: 40px;--col-name: 2fr;--col-owner: 2fr;--col-start: 1.2fr;--col-end: 1.2fr;--col-status: .8fr;--col-note: 1.3fr;--col-log: .8fr;--left-grid: var(--col-gear) var(--col-name) var(--col-owner) var(--col-start) var(--col-end) var(--col-status) var(--col-note) var(--col-log);position:relative;width:100%;max-width:100%;height:620px;border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden;box-sizing:border-box}:root{--month-h: 42px;--day-h: 28px;--header-h: calc(var(--month-h) + var(--day-h))}.split{position:relative;display:grid;grid-template-columns:var(--leftW) 1fr}.sched-header{border-bottom:1px solid var(--line);background:#f9fafb}.sched-header .left{border-right:1px solid var(--line);min-width:0}.sched-header .right{min-width:0;overflow:hidden;border-left:1px solid var(--line)}.sched-body{height:calc(100% - var(--header-h));overflow:auto}.sched-body .left{border-right:1px solid var(--line);min-width:0}.sched-body .right{position:relative;min-width:0;overflow:hidden;border-left:1px solid var(--line)}.resizer-overlay{position:absolute;top:0;bottom:0;left:calc(var(--leftW) - 4px);width:8px;cursor:col-resize;background:linear-gradient(90deg,#f2f4f6,#e6eaee);border-left:1px solid #e9edf1;border-right:1px solid #e9edf1;z-index:3}.resizer-overlay:hover{background:#e3e8ec}.row{display:grid;grid-template-columns:var(--left-grid);height:var(--rowH);align-items:center;padding:0 12px;border-bottom:1px solid #f2f3f5;box-sizing:border-box;position:relative}.row.header{height:var(--header-h);font-weight:700;background:#f8f9fa}.cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;text-align:center}.cell.name{font-weight:600}.log-btn{all:unset;cursor:pointer;font-size:14px;color:#616161;font-weight:700}.log-btn:hover{color:#222}.cell.status.완료{color:#26a97f}.cell.gear{display:flex;align-items:center}.gear-btn{width:28px;height:28px;border:0;border-radius:6px;background:#f3f5f7;color:#65727a;cursor:pointer;display:grid;place-items:center}.gear-btn:hover{background:#e9eef2;color:#3b556b}.gear-menu{position:absolute;z-index:10;top:5px;left:45px;width:120px;background:#fff;border:1px solid #e6eaeb;border-radius:10px;box-shadow:0 8px 20px #00000014;display:flex;flex-direction:column}.gear-menu__header{padding:8px 12px;font-weight:700;color:#fff;background:#23b07a;border-radius:10px 10px 0 0}.gear-menu__item{width:100%;padding:10px 12px;border:0;background:#fff;font-size:14px;cursor:pointer;text-align:center;border-radius:10px}.gear-menu__item:hover{background:#f6faf8}.cell.gear.header-gear{justify-content:left;position:relative}.gear-menu.gear-menu--header{position:absolute;top:48px!important;left:8px!important;z-index:111111111;box-shadow:0 10px 24px #0000001a}.header-months{display:grid;height:var(--month-h);background:#f6faf8;border-bottom:1px solid var(--line);align-items:center}.header-months .month{display:flex;align-items:center;justify-content:center;font-weight:700;color:#1e589b;border-right:1px solid var(--line)}.header-days{display:grid;height:var(--day-h);background:#fbfdfe;border-bottom:1px solid var(--line);align-items:center}.header-days .day{display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1}.header-days .day.today{font-weight:700;color:#fff;border-bottom:2px solid #23b07a;background-color:#23b07a}.bar-row{position:relative;height:var(--rowH);border-bottom:1px solid #f2f3f5;box-sizing:border-box}.bar{position:absolute;top:8px;height:26px;border-radius:14px;padding:0 10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;box-shadow:0 1px 2px #00000014}.bar.진행{background:#2b7fc9}.bar.대기{background:#f7c54b;color:#222}.bar.보류{background:#e0645c}.bar.완료{background:#26a97f}.gantt-pan{cursor:grab}.gantt-pan--dragging,.gantt-pan:active{cursor:grabbing}.today-btn{background:#2a7be4;color:#fff;font-size:13px;padding:4px 10px;border-radius:6px;border:none;cursor:pointer;transition:background .15s}.today-btn:hover{background:#1f66c0}.today-btn:active{transform:scale(.95)}.right{position:relative;overflow:hidden}.today-line{pointer-events:none;z-index:10}.task-name{display:flex;align-items:center;gap:6px}.file-icon{display:inline-flex;color:#23b07a}.row.level-2 .cell.name{padding-left:8px}.row.level-3 .cell.name{padding-left:24px}.expand-btn{display:inline-flex;justify-content:center;align-items:center;width:20px;height:20px;padding:0;border:1px solid #c9c9c9;background:#fff;color:#23b07a;border-radius:4px;font-size:12px;line-height:1;cursor:pointer}.expand-spacer{display:inline-block;width:20px;height:20px;visibility:hidden}.right::-webkit-scrollbar{height:10px}.right::-webkit-scrollbar-track{background:#f3f4f5}.right::-webkit-scrollbar-thumb{background:#c4cbd0;border-radius:10px}.modal-backdrop{position:fixed;inset:0;background:#11182759;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{width:min(720px,94vw);background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000026;display:flex;flex-direction:column;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #eef1f3;background:#f9fafb}.modal__title{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:18px;color:#111827}.modal__emoji{font-size:18px}.modal__close{width:32px;height:32px;border:0;border-radius:8px;background:transparent;color:#6b7280;cursor:pointer;font-size:20px;line-height:1}.modal__close:hover{background:#eef2f7;color:#374151}.modal__body{padding:16px 18px;display:flex;flex-direction:column;gap:6px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:2px}.form-group>label{font-size:13px;font-weight:700;color:#111827}.form-group input,.form-group select,.form-group textarea{appearance:none;border:1px solid #e6eaeb;border-radius:8px;padding:9px 10px;font-size:14px;outline:none;color:#111827;background:#fff;transition:border-color .12s,box-shadow .12s,background .12s}.form-group textarea{resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#23b07a;box-shadow:0 0 0 3px #23b07a1f}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid #eef1f3;background:#fafbfc}.btn{border:0;border-radius:8px;padding:10px 16px;font-size:14px;cursor:pointer;transition:transform .06s ease,background .15s ease,color .15s ease}.btn-ghost{background:#eef2f7;color:#111827}.btn-ghost:hover{background:#e6ebf2}.btn-primary{background:#23b07a;color:#fff;font-weight:700}.btn-primary:hover{background:#1e9a6b}.title-btn{all:unset;cursor:pointer;font-weight:600;color:#111827}.title-btn:hover{text-decoration:underline;color:#2563eb;transition:all .2s ease;transform:translateY(-2px)}@media(max-width:520px){.modal__body{padding:14px}.modal__footer{padding:12px 14px}.grid-2{grid-template-columns:1fr}}.link-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid #fff;background:#ffffff4d;color:#fff;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.link-btn.left{margin-right:6px}.link-btn.right{margin-left:6px}.link-btn:hover{background:#fff;color:#333}.link-btn.selected{background:#fff;color:#26a97f;border-color:#26a97f}.link-btn.active{border-color:#2b7fc9;box-shadow:0 0 0 3px #2b7fc92e}.dep-links path{stroke:#444;stroke-width:1.8;stroke-dasharray:4;fill:none}.bar{display:flex;align-items:center;justify-content:center;padding:0 30px;box-sizing:border-box}.bar>.link-btn{position:absolute;top:50%;transform:translateY(-50%);margin:0;width:20px;height:20px;z-index:1}.bar>.link-btn:first-of-type{left:6px}.bar>.link-btn:last-of-type{right:6px}.modal.modal--log{width:880px;max-width:calc(100vw - 32px)}.log-title-dot{margin:0 6px;color:#f1b22b}.log-tabs{display:flex;gap:6px;padding:4px 8px 0;border-bottom:1px solid #eee}.log-tab{padding:8px 12px;border:0;background:transparent;border-radius:8px 8px 0 0;font-weight:600;color:#666;cursor:pointer}.log-tab.is-active{background:#fff;color:#222;box-shadow:0 -2px #23b07a inset}.log-body{padding:8px}.log-table-wrap{border:1px solid #e9edf1;border-radius:10px;overflow:hidden;background:#fff}.log-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;table-layout:fixed}.log-table thead th{background:#f8fafb;color:#58636f;font-weight:700;padding:11px 12px;text-align:left;border-bottom:1px solid #e9edf1}.log-table tbody td{padding:10px 12px;border-bottom:1px solid #f3f5f7;vertical-align:middle;color:#1f2937;word-break:break-word}.log-table tbody tr:hover{background:#fbfdfe}.log-table tbody td:nth-child(1){text-align:left}.log-table tbody td:nth-child(2){text-align:left;color:#475569;font-weight:600}.log-table tbody td:nth-child(3){text-align:left;position:relative;background:#f5f7fb;border:1px solid #e4e9f0;color:#0f172a;padding:6px 12px;border-radius:10px;font-variant-numeric:tabular-nums;box-shadow:inset 0 1px #fff9}.log-table tbody tr:last-child td{border-bottom:0}.diff-inline{display:inline-flex;align-items:center;gap:8px}.diff-inline .diff-before{color:#9aa3ad;text-decoration:line-through}.diff-inline .diff-arrow{opacity:.6}.diff-inline .diff-after{color:#111827;font-weight:700}.log-empty{padding:28px;text-align:center;color:#9aa3ad}.log-error{padding:14px;color:#b00020;background:#fff5f5;border:1px solid #f3c0c0;border-radius:6px}.pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;background:#fff}.pager-btn{width:36px;height:36px;border:1px solid #e6edf2;border-radius:10px;background:#fff;color:#64748b;cursor:pointer;font-size:16px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,transform .06s;box-shadow:0 1px 2px #1018280a}.pager-btn:hover{background:#f6f8fb;color:#0f172a;border-color:#d9e1e8}.pager-btn:active{transform:scale(.98)}.pager-btn:disabled{background:#f3f5f7;color:#b8c2cc;border-color:#eef1f4;cursor:not-allowed;box-shadow:none}.pager-list{display:flex;align-items:center;gap:8px;margin:0;padding:0;list-style:none}.pager-num{min-width:36px;height:36px;padding:0 12px;border:1px solid #e6edf2;border-radius:12px;background:#fff;color:#0f172a;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,transform .06s;box-shadow:0 1px 2px #1018280a}.pager-num:hover{background:#f6f8fb;border-color:#d9e1e8}.pager-num:active{transform:scale(.98)}.pager-num.is-active{background:#23b07a;border-color:#23b07a;color:#fff;font-weight:800;box-shadow:0 2px 6px #23b07a40}@media(max-width:560px){.pager{gap:10px;padding:10px}.pager-btn,.pager-num{width:34px;height:34px;min-width:34px}.pager-num{padding:0 10px}}.right .deadline-line{position:absolute;top:0;bottom:0;width:0;border-left:2px dashed var(--deadline-color, #f24d61);opacity:.95;pointer-events:none;z-index:2}.right .deadline-line .deadline-badge{position:absolute;top:4px;transform:translate(-50%);background:#1b1f233d;color:#fff;font-size:11px;line-height:1.6;white-space:nowrap;padding:2px 6px;border-radius:10px;-webkit-user-select:none;user-select:none;pointer-events:auto;border:1px solid rgba(255,255,255,.1)}.right .deadline-line .deadline-badge:hover{background:#1b1f23;transform:translate(-50%) scale(1.05);color:#fff}.right .deadline-line .deadline-badge .date{opacity:.8;margin-left:6px}:root{--ctl-h: 36px;--ctl-r: 8px;--dl-border: #e6eaeb;--dl-border-weak: #f0f2f5;--dl-green: #23b07a;--dl-green-dark: #1e9a6b;--dl-danger: #ff4d4f}.modal--deadline .deadline-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:12px;align-items:end;margin-bottom:12px}.modal--deadline .deadline-form .form-group label{display:block;font-size:12px;color:#888;margin-bottom:6px}.modal--deadline .deadline-form .form-actions{align-self:end}.modal--deadline .deadline-list .empty{padding:16px;color:#aaa;text-align:center;border:1px dashed var(--dl-border);border-radius:10px}.deadline-table{width:100%;border-collapse:collapse;border:1px solid var(--dl-border);border-radius:10px;overflow:hidden}.deadline-table thead th{background:#fff;font-weight:600;text-align:left;padding:10px;border-bottom:1px solid var(--dl-border)}.deadline-table tbody td{padding:10px;border-bottom:1px solid var(--dl-border-weak);vertical-align:middle}.deadline-table tbody tr:last-child td{border-bottom:none}.deadline-table .color-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.2);margin-right:6px;vertical-align:-2px}.deadline-table td.ctrls{white-space:nowrap;text-align:right;margin-left:6px}.btn-danger{background:#ff4d4f;color:#fff;border:none;border-radius:8px;cursor:pointer}.btn-danger:hover{filter:brightness(.95)}.modal--deadline .deadline-form .form-group input[type=date],.modal--deadline .deadline-form .form-group input[type=text],.modal--deadline .deadline-form .form-group select,.modal--deadline .deadline-form .form-group textarea{height:var(--ctl-h);line-height:var(--ctl-h);padding:0 10px;border:1px solid var(--dl-border);border-radius:var(--ctl-r);box-sizing:border-box}.modal--deadline .deadline-form .form-group input[type=color]{height:var(--ctl-h);width:48px;padding:0;border:1px solid var(--dl-border);border-radius:var(--ctl-r);box-sizing:border-box;vertical-align:middle}.modal--deadline .deadline-form .form-actions .btn{height:var(--ctl-h);padding:0 14px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--ctl-r)}.deadline-table tbody td input[type=date],.deadline-table tbody td input[type=text],.deadline-table tbody td select,.deadline-table tbody td textarea{height:var(--ctl-h);line-height:var(--ctl-h);padding:0 10px;border:1px solid var(--dl-border);border-radius:var(--ctl-r);box-sizing:border-box}.deadline-table tbody td input[type=color]{height:var(--ctl-h);width:48px;padding:0;border:1px solid var(--dl-border);border-radius:var(--ctl-r);box-sizing:border-box;vertical-align:middle}.deadline-table tbody td.ctrls .btn,.deadline-table tbody td.ctrls .btn-danger{height:var(--ctl-h);padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--ctl-r);margin-left:6px}.deadline-manage-btn{margin-left:8px;height:28px;padding:0 10px;border-radius:8px;border:1px solid var(--border-color, #2b2f36);background:#0f1114;color:var(--fg, #e8e8e8)}.gear-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;line-height:1}.gear-btn i{font-size:18px;color:currentColor}.owner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:12px;color:#666}.owner-header__label{font-weight:500}.owner-header__count{color:#06c;font-weight:600}.owner-multi{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;border-radius:6px;border:1px solid #dde1ea;background-color:#f7f8fb;max-height:140px;overflow-y:auto}.owner-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid #d5d9e3;background-color:#fff;font-size:12px;color:#333;cursor:pointer;outline:none;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease,color .15s ease,transform .05s ease}.owner-chip:hover{border-color:#b4bdd2;background-color:#f9fbff}.owner-chip:active{transform:translateY(1px)}.owner-chip__dot{width:14px;height:14px;border-radius:999px;border:2px solid #d5d9e3;background-color:#fff;box-sizing:border-box}.owner-chip.is-selected{background-color:#e8f3ff;border-color:#2d7ff9;color:#174273;box-shadow:0 0 0 1px #2d7ff933}.owner-chip.is-selected .owner-chip__dot{border-color:#2d7ff9;background-color:#2d7ff9}.owner-chip__name{white-space:nowrap}.owner-empty{padding:8px 10px;border-radius:6px;background-color:#f7f8fb;border:1px dashed #dde1ea;font-size:12px;color:#888}.owner-help{display:block;margin-top:4px;font-size:11px;color:#888}:root{--page-header-h: 56px;--left-pane-w: 60%;--line: #e6eaeb;--bg: #ffffff;--bg-weak: #f9fafb}@media(max-width:1200px){:root{--left-pane-w: 60%}}.doc-shell{position:relative;width:100%;max-width:100%;border:1px solid var(--line);border-radius:10px;background:var(--bg);box-shadow:0 1px 2px #0000000a;padding:8px 10px;overflow:visible}.file-manager.two-pane{display:grid;grid-template-columns:var(--left-pane-w) minmax(0,1fr);gap:0}.doc-shell .file-manager.two-pane{min-height:560px;height:calc(100vh - var(--page-header-h) - 60px)}@media(max-width:900px){.file-manager.two-pane{grid-template-columns:1fr}.pane.left{border-right:none;border-bottom:1px solid var(--line)}}.pane.left{border-right:1px solid var(--line);padding-right:10px;background:var(--bg-weak);overflow-y:auto;overflow-x:visible}.pane.right{background:#fff;overflow-y:auto;overflow-x:visible}.fm-tree{height:100%;display:flex;flex-direction:column;min-height:0}.fm-tree-header{position:sticky;top:0;z-index:3;display:flex;flex-direction:column;gap:6px;padding:6px 8px 8px;background:linear-gradient(to bottom,#f9fafb,#eef2ff);border-bottom:1px solid var(--line)}.fm-tree-header-top{display:flex;align-items:center;gap:8px;min-height:28px}.fm-tree-title{font-weight:600;font-size:13px;color:#111827;white-space:nowrap}.fm-tree-header-actions{margin-left:auto;display:flex;align-items:center;gap:6px;flex-shrink:0}.fm-tree-header-top .fm-tree-filter-field.fm-tree-filter-grow{flex:1 1 auto;min-width:0;margin-left:12px}@media(max-width:900px){.fm-tree-header-top .fm-tree-filter-field.fm-tree-filter-grow{margin-left:6px}}.fm-tree-header-filters{display:grid;grid-template-columns:minmax(0,.7fr) minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr);gap:6px;padding:4px 6px 3px;border-radius:6px;background:#ffffffe6;box-shadow:0 0 0 1px #94a3b840}.fm-tree-filter-field{display:flex;align-items:center;gap:4px;min-width:0}.fm-filter-input,.fm-filter-select{width:100%!important;height:28px;padding:0 8px;border-radius:6px;border:1px solid #d0d5dd;background-color:#fff;font-size:12px;color:#111827;box-sizing:border-box;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.fm-filter-input::placeholder{color:#9ca3af}.fm-filter-select{padding-right:22px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:none}.fm-filter-text{max-width:320px!important}.fm-filter-input:focus,.fm-filter-select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26;background-color:#fff}.fm-filter-range{display:flex;align-items:center;gap:4px;min-width:0}.fm-filter-date{width:100%}.fm-filter-range-sep{font-size:11px;color:#9ca3af;flex-shrink:0}@media(max-width:1100px){.fm-tree-header-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.fm-tree-header-filters>.fm-tree-filter-field:nth-child(1){grid-column:1 / 2}.fm-tree-header-filters>.fm-tree-filter-field:nth-child(2){grid-column:2 / 3}.fm-tree-header-filters>.fm-tree-filter-field:nth-child(3){grid-column:1 / 2}.fm-tree-header-filters>.fm-tree-filter-field:nth-child(4){grid-column:2 / 3}}@media(max-width:720px){.fm-tree-header-filters{grid-template-columns:1fr;gap:4px;padding:4px}.fm-tree-header-filters>.fm-tree-filter-field:nth-child(1),.fm-tree-header-filters>.fm-tree-filter-field:nth-child(2),.fm-tree-header-filters>.fm-tree-filter-field:nth-child(3),.fm-tree-header-filters>.fm-tree-filter-field:nth-child(4){grid-column:1 / 2}.fm-filter-range{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);column-gap:4px}}.fm-tree-level{list-style:none;margin:0;padding:0}.fm-tree-row{position:relative;display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;cursor:pointer}.fm-tree-row:hover{background:#f6f8fb}.fm-tree-row.active{background:#eaf1ff}.fm-tree-row.depth-0{padding-left:8px}.fm-tree-row.depth-1{padding-left:22px}.fm-tree-row.depth-2{padding-left:36px}.fm-tree-row.depth-3{padding-left:50px}.fm-tree-row.depth-4{padding-left:64px}.fm-tree-row.depth-5{padding-left:78px}.fm-tree-row.depth-6{padding-left:92px}.fm-tree-row.depth-7{padding-left:106px}.fm-tree-row.depth-8{padding-left:120px}.fm-tree-icon{width:18px;text-align:center}.fm-tree-name:hover{text-decoration:underline;color:#2563eb;transition:all .2s ease;transform:translateY(-2px)}.fm-tree-checkbox{margin-right:4px}.expand-btn,.expand-spacer{display:inline-flex;justify-content:center;align-items:center;width:20px;height:20px;padding:0}.expand-btn{border:1px solid #c9c9c9;background:#fff;color:#23b07a;border-radius:4px;font-size:12px;line-height:1;cursor:pointer}.expand-btn:hover{background:#eef2f7}.expand-btn.is-dash{background:transparent;cursor:default;font-size:14px;font-weight:700}.fm-tree-row-right{margin-left:auto;display:grid;grid-template-columns:110px 110px 70px;column-gap:6px;align-items:center;justify-items:stretch}.fm-tree-row-right .status-badge{width:100%;justify-content:center;box-sizing:border-box;padding-bottom:2px}.status-badge:hover{box-shadow:0 0 0 2px #c0e6d640}.fm-tree-row-right .date-badge,.fm-tree-row-right .dept-badge{width:100%;justify-content:center;align-items:center;padding-bottom:2px}.fm-grid{display:flex;flex-direction:column;height:100%;min-height:0}.fm-grid-toolbar{position:sticky;top:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:start;padding:6px 10px 8px;background:var(--bg);border-bottom:1px solid var(--line);gap:16px}.crumbs{color:#6b7280;font-size:14px;margin-left:14px}.fm-grid-toolbar .left,.fm-grid-toolbar .right{width:100%}.fm-grid-toolbar .left .crumbs{font-size:13px;color:#4a5568}.fm-grid-toolbar .right .btn+.btn{margin-left:6px}.table-wrap{position:relative;flex:1 1 auto;min-height:0;margin:8px 0 0;border-radius:8px;border:1px solid var(--line);background:#fff;overflow:visible}.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.tbl thead th{position:sticky;top:0;z-index:1;background:#f7fafc;font-weight:600;padding:6px 8px;border-bottom:1px solid #e2e8f0;text-align:left;white-space:nowrap}.tbl tbody td{padding:6px 8px;border-bottom:1px solid #edf2f7;background:#fff}.tbl tbody tr:hover td{background:#f7fafc}.tbl .empty{text-align:center;color:#8a959c}.tbl .col-select{width:34px;text-align:center}.tbl .col-uploader{width:110px;white-space:nowrap}.tbl .col-size{width:80px;text-align:center;white-space:nowrap}.tbl .col-updated{width:130px;white-space:nowrap;text-align:center}.tbl .col-actions{width:60px;text-align:center}.tbl td.link{display:flex;align-items:center;gap:6px}.file-row-icon{width:18px;flex:0 0 18px;text-align:center;margin-right:0}.file-name-button{border:none;background:none;padding:0;cursor:pointer;text-align:left;color:#1a202c;font-size:13px;max-width:100%;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-name-button:hover{text-decoration:underline}.cell-gear{position:relative;display:flex;gap:8px;align-items:center}.btn.sm{padding:6px 10px;border:1px solid #d0d7e2;background:#fff;border-radius:8px;cursor:pointer;font-size:12px}.btn.sm:disabled{opacity:.5;cursor:not-allowed}.btn.sm.primary{background:#2563eb;border-color:#2563eb;color:#fff}.btn.sm.danger{background:#dc2626;border-color:#dc2626;color:#fff}.cell-gear .btn.xs{font-size:11px;padding:3px 8px}.status-badge{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;border:1px solid #d0d7e2;background:#fff;font-size:12px;cursor:pointer}.status-badge__icon{margin-left:4px}.cell.status.진행{color:#2b7fc9;font-weight:700}.cell.status.대기{color:#b97700}.cell.status.보류{color:#e0645c}.cell.status.완료,.cell.status.수락{color:#26a97f}.cell.status.거절{color:#e0645c}.status--진행{color:#2b7fc9;border-color:#bcd7f0;background:#eef6fd}.status--대기{color:#b97700;border-color:#f0d29f;background:#fff5e6}.status--보류{color:#e0645c;border-color:#f3c1bd;background:#fff0ee}.status--완료{color:#26a97f;border-color:#b8eadb;background:#ecfbf6}.status-menu,.date-menu,.dept-menu{transform:translate(-50%)}.gear-menu{position:absolute;z-index:11111;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 6px 24px #0000001f;overflow:visible}.gear-menu__header{padding:8px 10px;font-size:12px;font-weight:600;border-bottom:1px solid #e5e7eb;text-align:center}.gear-menu--header{top:50px;left:8px}.col-gear .gear-btn{margin:0 auto}.gear-btn i{font-size:13px}.gear-btn:hover{background:#edf2f7;color:#2d3748}.gear-menu.dropdown-menu{padding:0;border-radius:14px;overflow:visible;background:#fff;box-shadow:0 12px 28px #0f172a2e;min-width:260px;max-width:min(320px,calc(100vw - 24px))}.gear-menu.dropdown-menu .gear-menu__header{background:#16a96b;color:#fff;font-size:13px;font-weight:700;text-align:center;padding:8px 12px;letter-spacing:.04em;border-bottom:none}.dropdown-menu__body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:8px}.dropdown-field{display:flex;flex-direction:column;gap:4px}.dropdown-field__label{font-size:11px;font-weight:600;color:#6b7280}.dropdown-field__hint{font-size:11px;color:#9ca3af;margin:2px 0 0}.dropdown-input{width:100%;box-sizing:border-box;border-radius:8px;border:1px solid #d1d5db;background-color:#f9fafb;font-size:13px;line-height:1.4;padding:6px 10px;outline:none;box-shadow:0 0 0 1px transparent;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.dropdown-input::-ms-expand{display:none}.dropdown-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:none}.dropdown-input:focus{border-color:#16a96b;box-shadow:0 0 0 2px #16a96b40;background-color:#fff}.status-menu .dropdown-menu__body,.dept-menu .dropdown-menu__body,.date-menu .dropdown-menu__body{min-width:240px}.date-menu-actions{text-align:center}.date-menu-body,.dept-menu-body{display:flex;flex-direction:column;align-items:center;gap:12px}.dnd-zone{position:relative}.dnd-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#3c64ff0f;border:2px dashed #7aa3ff;border-radius:8px;z-index:5;pointer-events:none}.dnd-overlay.is-disabled{background:#0000000d;border-color:#cfcfcf}.dnd-inner{text-align:center}.dnd-icons{display:flex;gap:18px;justify-content:center;font-size:40px}.dnd-title{margin-top:10px;font-weight:700;font-size:18px}.dnd-sub{margin-top:4px;color:#6b7280;font-size:13px}.upload-notice{margin-bottom:8px;padding:8px 12px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px}.upload-notice--success{background:#ecfdf3;border:1px solid #22c55e}.upload-notice--warning{background:#fef3c7;border:1px solid #facc15}.upload-notice__close{margin-left:auto;border:none;background:transparent;cursor:pointer;font-size:14px}.modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:999;background:#0f172a59}.modal-card{width:520px;max-width:92vw;border-radius:10px;background:#fff;box-shadow:0 10px 30px #0f172a2e}.modal-card--narrow{max-width:420px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #e5e7eb}.modal-body{padding:14px;display:grid;gap:12px}.modal-field-label{margin-bottom:6px;font-size:13px}.modal-text{line-height:1.6;font-size:13px}.modal-text-muted{margin-top:6px;opacity:.8;font-size:12px}.modal-text-danger{margin-top:8px;color:#b91c1c;font-size:13px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.modal-actions--lg{margin-top:16px}.modal-audit{display:flex;flex-direction:column;gap:2px;font-size:12px;color:#6b7280}.form-row--mt{margin-top:12px}.upload-progress-text{font-size:13px}.upload-progress-bar{margin-top:8px;width:100%;height:8px;border-radius:999px;background:#e5e7eb;overflow:hidden}.upload-progress-bar-inner{height:100%;background:#3b82f6;transition:width .2s ease}.upload-progress-bar-inner.step-0{width:0%}.upload-progress-bar-inner.step-5{width:5%}.upload-progress-bar-inner.step-10{width:10%}.upload-progress-bar-inner.step-15{width:15%}.upload-progress-bar-inner.step-20{width:20%}.upload-progress-bar-inner.step-25{width:25%}.upload-progress-bar-inner.step-30{width:30%}.upload-progress-bar-inner.step-35{width:35%}.upload-progress-bar-inner.step-40{width:40%}.upload-progress-bar-inner.step-45{width:45%}.upload-progress-bar-inner.step-50{width:50%}.upload-progress-bar-inner.step-55{width:55%}.upload-progress-bar-inner.step-60{width:60%}.upload-progress-bar-inner.step-65{width:65%}.upload-progress-bar-inner.step-70{width:70%}.upload-progress-bar-inner.step-75{width:75%}.upload-progress-bar-inner.step-80{width:80%}.upload-progress-bar-inner.step-85{width:85%}.upload-progress-bar-inner.step-90{width:90%}.upload-progress-bar-inner.step-95{width:95%}.upload-progress-bar-inner.step-100{width:100%}.upload-progress-help{margin-top:4px;font-size:12px;opacity:.7}.hidden-input{display:none}.text-muted{opacity:.7;font-size:12px}.bulk-dropzone{border:1px dashed #cbd5e0;border-radius:8px;padding:16px;text-align:center;background:#f9fafb;transition:background .15s ease,border-color .15s ease;font-size:13px}.bulk-dropzone.is-over{background:#f0f4ff;border-color:#93c5fd}.bulk-dropzone-title{font-weight:600;margin-bottom:6px}.bulk-dropzone-sub{font-size:12px;opacity:.8;margin-bottom:10px}.bulk-dropzone-file{margin-top:10px;font-size:12px}.bulk-dropzone-loading{margin-top:8px;font-size:12px;opacity:.7}.bulk-preview-grid{margin-top:12px;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,2fr);gap:12px;align-items:flex-start}.bulk-preview-panel{border:1px solid #e2e8f0;border-radius:8px;padding:10px;font-size:13px;background:#fff}.bulk-preview-panel .panel-title{font-weight:600;margin-bottom:6px}.bulk-status-ok{color:#15803d;font-weight:600}.bulk-status-error{color:#b91c1c;font-weight:600}.bulk-status-errors,.bulk-status-warnings{max-height:120px;overflow:auto;padding:6px;border-radius:6px;margin-top:6px;font-size:12px}.bulk-status-errors{background:#fef2f2;border:1px solid #fecaca}.bulk-status-warnings{background:#fffbeb;border:1px solid #facc15}.bulk-tree-scroll{max-height:220px;overflow:auto}.bulk-tree-level{list-style:none;margin:0;padding-left:18px}.bulk-tree-level>li{position:relative}.bulk-tree-level>li:before{content:"";position:absolute;top:0;bottom:-6px;left:6px;border-left:1px solid #d4d4d8}.bulk-tree-level>li:last-child:before{bottom:12px}.bulk-tree-row{position:relative;display:flex;align-items:center;padding:2px 0 2px 14px;font-size:13px;line-height:1.4;border-radius:4px}.bulk-tree-row:hover{background:none}.bulk-tree-row:before{content:"";position:absolute;left:6px;top:50%;width:8px;border-top:1px solid #d4d4d8;transform:translateY(-50%)}.bulk-tree-icon{width:18px;text-align:center;margin-right:6px}.bulk-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.fm-tree-expand-buttons{display:flex;gap:4px;flex-shrink:0}.fm-tree-expand-buttons .btn.xs{white-space:nowrap}.fm-tree-header-top{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px}.fm-tree-title{flex:0 0 auto}.fm-tree-header-top .fm-tree-filter-field.fm-tree-filter-grow{flex:1 1 220px;min-width:160px;margin-left:8px}.fm-tree-header-actions{flex:0 0 auto}@media(max-width:1300px){.fm-tree-header-top{align-items:flex-start}.fm-tree-title{order:1}.fm-tree-expand-buttons{order:2}.fm-tree-header-top .fm-tree-filter-field.fm-tree-filter-grow{order:3;margin-left:0}.fm-tree-header-actions{order:4;margin-left:0;width:100%;justify-content:flex-end}}@media(max-width:900px){.fm-tree-header-top{flex-direction:column;align-items:stretch}.fm-tree-expand-buttons,.fm-tree-header-actions,.fm-tree-header-top .fm-tree-filter-field.fm-tree-filter-grow{width:100%;margin-left:0}.fm-tree-header-actions{justify-content:flex-start;flex-wrap:wrap;row-gap:4px}}@media(max-width:1300px){.fm-tree-row-right{grid-template-columns:100px 100px 70px}}@media(max-width:1100px){.fm-tree-row-right{grid-template-columns:repeat(3,minmax(0,1fr));column-gap:4px}.fm-tree-row-right .status-badge,.fm-tree-row-right .date-badge,.fm-tree-row-right .dept-badge{font-size:11px}}:root{--bg: #ffffff;--panel: #ffffff;--panel-alt: #f9fafb;--line: #e6eaeb;--line-soft: #eef1f3;--text: #0f172a;--text-subtle: #6b7280;--primary: #23b07a;--primary-dark: #1e9a6b;--danger: #ef4444;--badge: #eef2f7;--radius: 12px;--gap: 16px;--pad: 14px;--shadow: 0 8px 24px rgba(16, 24, 40, .06)}.page-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:.2px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.panel-header{display:flex;align-items:center;gap:12px;padding:12px var(--pad);background:var(--panel-alt);border-bottom:1px solid var(--line)}.panel-title{margin:0;font-size:15px;font-weight:800;color:var(--text)}.panel-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.panel-body{padding:var(--pad);max-height:450px;overflow:auto}.panel+.panel{margin-top:16px}.panel-header-right{margin-left:auto}.btn{height:34px;padding:0 12px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:600;line-height:32px;cursor:pointer;font-size:13px;transition:transform .06s ease,background .15s ease,border-color .15s ease,color .15s ease,opacity .15s}.btn:hover{background:#f6f8fb;border-color:#d9e1e8}.btn:active{transform:scale(.98)}.btn[disabled]{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.danger{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.btn.danger:hover{background:#fecaca;border-color:#fca5a5}.btn-group{display:inline-flex;gap:8px}.search-input,input[type=text],input:not([type]),input[type=search]{height:36px;padding:0 12px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);outline:none;min-width:220px;font-size:13px;transition:border-color .15s,box-shadow .15s,background .15s}.search-input::placeholder{color:var(--text-subtle)}.search-input:focus,input[type=text]:focus,input[type=search]:focus,input:not([type]):focus{border-color:var(--primary);box-shadow:0 0 0 3px #23b07a26}.form-select{height:32px;padding:0 10px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);font-size:13px;outline:none;min-width:120px;transition:border-color .15s,box-shadow .15s,background .15s}.form-select.small{height:30px;font-size:12px;padding:0 8px}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #23b07a26}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;color:var(--text)}.table.simple thead th{text-align:left;font-weight:700;padding:12px 10px;color:#475569;background:#f9fafb;border-bottom:1px solid var(--line)}.table.simple tbody td{padding:10px;border-bottom:1px solid var(--line-soft)}.table.simple thead th:nth-child(2){width:60px}.table.simple tbody tr:hover{background:#fbfdfe}.table.simple tbody tr.is-disabled{opacity:.5}.table.simple input[type=checkbox]{transform:translateY(1px)}.table.simple tbody tr.row-active{background:#f0f9ff}.badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;background:var(--badge);color:#0f172a;font-size:12px;font-weight:700;letter-spacing:.2px;border:1px solid #e6edf2}.role-stack{display:flex;flex-wrap:wrap;gap:4px}.role-badge.muted{opacity:.6}.empty-card{display:grid;place-items:center;min-height:120px;border:1px dashed var(--line);border-radius:10px;color:var(--text-subtle);background:#fff;font-size:13px}.form-grid{display:flex;flex-direction:column;gap:14px}.form-row{display:flex;flex-direction:column;gap:6px}.form-row.two{display:grid;grid-template-columns:1fr auto;gap:12px}.form-label{font-size:13px;font-weight:600;color:var(--text-subtle)}.form-label .required{color:var(--danger);margin-left:2px}.form-input{width:95%;height:36px;padding:0 10px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #23b07a26}.form-textarea{width:95%;padding:8px 10px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);font-size:13px;resize:vertical;min-height:90px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #23b07a26}.form-static{min-height:36px;display:flex;align-items:center;font-size:13px;color:var(--text)}.form-actions{margin-top:16px;display:flex;gap:8px;justify-content:flex-end}.project-manage-tabs{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;border-bottom:1px solid var(--line)}.tab-list{display:flex;gap:8px;align-items:flex-end}.tab-item{padding:6px 12px;border:none;border-bottom:2px solid transparent;background:transparent;font-size:14px;font-weight:500;color:var(--text-subtle);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.tab-item:hover{color:var(--text);background:#eef2ff;border-radius:8px 8px 0 0}.tab-item.tab-item-active{border-bottom-color:var(--primary);color:var(--primary-dark);font-weight:700}.tab-actions{display:flex;align-items:center;gap:8px;margin-bottom:4px;padding-right:4px}.excel-input-hidden{display:none}.selection-mode-label{color:var(--text-subtle);font-size:12px}.invite-hint-text{margin-top:8px;color:var(--text-subtle);font-size:12px}.muted-text{color:var(--text-subtle);font-size:12px}@media(max-width:1100px){.two-col{grid-template-columns:1fr}.panel-actions .search-input{min-width:160px;width:100%}}.excel-preview-header{display:flex;flex-direction:column;gap:4px;font-size:13px;margin-bottom:4px}.excel-preview-summary{color:var(--text-subtle)}.excel-preview-summary strong{color:var(--text)}.excel-preview-errors{margin-top:4px;padding:6px 8px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;font-size:12px;color:#991b1b;max-height:90px;overflow-y:auto}.excel-error-line+.excel-error-line{margin-top:2px}.excel-preview-grid{display:flex;flex-direction:column;gap:8px}.excel-preview-panel{display:flex;flex-direction:column;gap:6px}.excel-preview-title{font-size:14px;font-weight:700;color:var(--text)}.excel-preview-scroll{border:1px solid var(--line-soft);border-radius:10px;background:#fff;max-height:260px;overflow:auto}.invite-preview-table tbody tr.excel-row-has-missing{background:#fff7ed}.excel-missing-label{color:#b91c1c;font-size:12px;font-weight:600}.excel-missing-cell{background:#fef2f2}@media(max-width:768px){.invite-excel-card{width:96vw!important}}.dept-color-cell{display:inline-flex;align-items:center;gap:6px}.dept-color-chip{width:18px;height:18px;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#fff;box-shadow:0 0 0 1px #ffffffe6 inset;flex-shrink:0}.dept-color-value{font-size:11px;color:var(--text-subtle);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.dept-color-edit{display:inline-flex;align-items:center;flex-wrap:wrap;gap:8px}.dept-color-input{width:50px;height:32px;padding:0;border:none;background:transparent;cursor:pointer}.dept-color-input::-webkit-color-swatch-wrapper{padding:0}.dept-color-input::-webkit-color-swatch{border-radius:999px;border:1px solid rgba(148,163,184,.9)}.form-hint{font-size:11px;color:var(--text-subtle)}
