body{margin:0;font-family:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace}.personal-info-section{margin:20px auto;max-width:900px;border:1px solid #ccc;border-radius:10px;background-color:#f9f9f9;padding:20px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.info-container{flex-wrap:nowrap;overflow-x:auto}.info-input{flex:1 1 auto;min-width:120px;box-sizing:border-box;border:1px solid transparent;border-radius:4px;transition:border-color .2s}.text-info{min-width:0}.info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.info-title{font-size:24px;font-weight:700;text-align:left}.import-buttons{display:flex;grid-gap:10px;gap:10px}.import-button{background-color:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.import-button:hover{background-color:#45a049}.json-upload{display:none}.input-row{align-items:flex-start;flex-wrap:nowrap;width:100%;box-sizing:border-box;margin-bottom:8px}.label-container{flex:0 0 auto;min-width:60px;max-width:120px;margin-right:10px;text-align:left;word-wrap:break-word;overflow-wrap:break-word}.input-and-buttons{display:flex;flex-direction:row;align-items:center;grid-gap:5px;gap:5px;flex:1 1;min-width:0;box-sizing:border-box}.info-label{border:none;background:transparent;outline:none;color:#666;font-size:14px;font-weight:500;width:100%;padding:4px;border-radius:3px;transition:background-color .2s}.info-label:focus,.info-label:hover{background-color:#f8f9fa;color:#333}.info-input:focus,.info-input:hover{border-color:#007bff;outline:none}.button-group{grid-gap:5px;gap:5px}.add-button,.remove-button{background-color:#f5f5f5;color:#666;border:1px solid #ccc;width:40px;height:40px;font-size:18px;font-weight:700;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.remove-button{margin-right:10px}.photo-container{flex:1 1;min-width:0;align-items:flex-start;margin-top:60px}.photo-container,.profile-photo{display:flex;justify-content:center}.profile-photo{width:130px;height:180px;border:1px solid #ccc;border-radius:5px;align-items:center;background-color:#eaeaea}.photo-placeholder{color:#666;text-align:center}.photo-preview{width:100%;height:100%;object-fit:cover;border-radius:5px}.photo-upload{display:none}@media (max-width:768px){.info-container{flex-direction:column;grid-gap:20px;gap:20px}.text-info{flex:1 1}.photo-container{margin-top:0;align-self:center}.label-container{min-width:80px;max-width:150px}.info-input{min-width:100px}}@media (max-width:480px){.input-row{flex-direction:column;align-items:stretch;grid-gap:8px;gap:8px}.label-container{max-width:none;margin-right:0;margin-bottom:4px}.input-and-buttons{flex-direction:row}.info-input{min-width:0;flex:1 1}}.slider{position:relative;overflow:hidden;width:100%}.slider-content{display:flex;transition:transform .5s ease-in-out}.slide{flex:0 0 100%;box-sizing:border-box;padding:0 10px}.slider-controls{display:flex;justify-content:space-between;margin-top:10px}.slider-button{padding:8px 16px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.slider-button:disabled{background-color:#ccc;cursor:not-allowed}.project-section{margin:20px auto;max-width:900px;border:1px solid #ccc;border-radius:10px;background-color:#f9f9f9;padding:20px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.project-container{position:relative}.input-row{display:flex;flex-direction:row;align-items:center;grid-gap:10px;gap:10px;margin-bottom:10px}.info-input{flex:1 1;padding:8px;font-size:16px;border:1px solid #ccc;border-radius:5px}.info-input:focus,.info-input:hover{border:1px solid #999}.label{min-width:100px;font-weight:700;text-align:left}.label,.save-button{align-self:flex-start}.save-button{padding:10px 20px;font-size:16px;background-color:#5cb85c;color:#fff;border:none;border-radius:5px;cursor:pointer}.save-button:hover{background-color:#4cae4c}.upload-row{display:flex;flex-direction:row;align-items:center;grid-gap:10px;gap:10px;margin-bottom:10px}input[type=file]{display:none}.upload-actions{display:flex;flex-direction:row;align-items:center;grid-gap:10px;gap:10px;margin-top:10px}.file-upload-button{padding:10px 20px;font-size:16px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .2s ease}.file-upload-button:hover{background-color:#0056b3}.remove-media-button{padding:10px 20px;font-size:16px;background-color:#d9534f;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .2s ease}.remove-media-button:hover{background-color:#c9302c}.preview-media{max-width:100%;max-height:200px;margin-bottom:10px}.media-description,.preview-media{border:1px solid #ccc;border-radius:5px}.media-description{width:100%;padding:8px;font-size:16px;margin-top:5px;margin-bottom:15px}.upload-preview{display:flex;flex-direction:column;grid-gap:5px;gap:5px}.upload-success-label{display:block;margin-bottom:10px;font-size:18px;font-weight:700;color:#5cb85c;text-align:center}.label-required:after{content:" *";color:#d9534f}.section-subtitle{font-weight:600;margin:18px 0 8px;font-size:1.1rem;border-left:4px solid #007bff;padding-left:8px}.chip-optional{background:#e9ecef;color:#6c757d;padding:2px 6px;font-size:12px;border-radius:4px;margin-left:6px}.stepper{display:flex;list-style:none;padding:0;margin-bottom:12px}.stepper li{flex:1 1;text-align:center;padding:6px 0;border-bottom:3px solid #dee2e6;font-size:14px}.stepper li.active{color:#007bff;border-color:#007bff}.step-actions{display:flex;justify-content:flex-end;grid-gap:10px;gap:10px;margin-bottom:16px}.help-tip{display:inline-flex;align-items:center}.step-actions button{min-width:110px;padding:12px 0;font-size:17px;font-weight:600;border-radius:8px;border:2px solid #4f8cff;margin-left:12px;box-shadow:0 2px 8px rgba(79,140,255,.08);transition:background .18s,color .18s,box-shadow .18s;cursor:pointer}.step-actions button:last-child{background:#4f8cff;color:#fff}.step-actions button:last-child:hover{background:#2563c6;color:#fff;box-shadow:0 4px 16px rgba(79,140,255,.18)}.step-actions button:first-child{background:#fff;color:#4f8cff}.step-actions button:first-child:hover{background:#f4f8ff;color:#2563c6;border-color:#2563c6}.education-section{margin:20px auto;max-width:900px;border:1px solid #ccc;border-radius:10px;background-color:#f9f9f9;padding:20px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.info-container{display:flex;justify-content:space-between;align-items:flex-start}.education-container,.section-header{position:relative}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.button-group{display:flex;grid-gap:10px;gap:10px;margin-left:auto}.add-newButton,.remove-newButton{width:40px;height:40px;font-size:18px;font-weight:700;border-radius:50%;background-color:#000;color:#fff;border:none;cursor:pointer;position:relative;transition:box-shadow .2s ease,transform .2s ease}.add-newButton:hover,.remove-newButton:hover{transform:translateY(-2px);box-shadow:0 4px 8px hsla(0,0%,50.2%,.5)}.add-newButton:active,.remove-newButton:active{transform:translateY(1px);box-shadow:0 4px 12px hsla(0,0%,50.2%,.8)}.add-newButton:after,.remove-newButton:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:30%;background-color:hsla(0,0%,50.2%,.2);opacity:0;transition:opacity .2s ease,transform .2s ease;z-index:-1;transform:scale(1)}.add-newButton:hover:after,.remove-newButton:hover:after{opacity:1;transform:scale(1.2)}.add-newButton:active:after,.remove-newButton:active:after{opacity:1;transform:scale(1.5);background-color:hsla(0,0%,50.2%,.4)}.left-align{text-align:left}.text-info{flex:3 1;display:flex;flex-direction:column;grid-gap:15px;gap:15px}.text-photo-container{display:flex;justify-content:space-between;align-items:flex-start;grid-gap:20px;gap:20px}.text-container{flex:3 1}.course-award-row,.input-row{display:flex;flex-direction:row;align-items:center;grid-gap:10px;gap:10px;margin-bottom:10px}.award-input,.course-input,.info-input{flex:1 1;padding:8px;font-size:16px;border:1px solid #ccc;border-radius:5px}.award-input:focus,.award-input:hover,.course-input:focus,.course-input:hover,.info-input:focus,.info-input:hover{border:1px solid #999}.add-button,.remove-button{width:40px;height:40px;font-size:18px;font-weight:700;border-radius:50%;background-color:#f5f5f5;border:1px solid #ccc;cursor:pointer}.add-button:hover,.remove-button:hover{background-color:#e0e0e0}.logo-container{flex:0 0 auto;align-items:flex-start;margin-top:20px}.logo-container,.school-logo{display:flex;justify-content:center}.school-logo{width:100px;height:100px;border:1px solid #ccc;border-radius:5px;align-items:center;background-color:#eaeaea;flex-shrink:0;flex-grow:0;box-sizing:border-box;min-width:100px;min-height:100px}.logo-placeholder{color:#666;text-align:center}.logo-preview{width:100%;height:100%;object-fit:cover;border-radius:5px}.logo-upload{display:none}.skill-container{margin:20px auto;max-width:900px;border:1px solid #ccc;border-radius:10px;background-color:#f9f9f9;padding:20px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.skill-preview{text-align:left;margin:20px 0}.resume-container{position:relative;width:100%;height:100%;overflow-y:auto;box-sizing:border-box}.resume,.resume-container{padding:20px;background:#fff}.resume{max-width:800px;margin:0 auto;border-radius:10px;box-shadow:0 0 20px rgba(0,0,0,.1)}.detail-panel{position:absolute;right:0;top:0;width:100%;height:100%;background:#fff;padding:20px;box-shadow:-4px 0 20px rgba(0,0,0,.1);overflow-y:auto;box-sizing:border-box;border-left:1px solid #e0e0e0;z-index:1000;opacity:0;transform:translateX(30px);transition:all .5s cubic-bezier(.4,0,.2,1)}.detail-panel.slide-enter{animation:slideInFade .5s cubic-bezier(.4,0,.2,1) forwards}.detail-panel.slide-leave{animation:slideOutFade .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInFade{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutFade{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(30px)}}.resume-preview-container{position:relative;width:100%;height:100%;overflow:hidden}.show-detail .resume-container{position:relative}.show-detail .resume-container:after{background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;transition:opacity .5s cubic-bezier(.4,0,.2,1)}.close-btn{position:absolute;top:20px;right:20px;padding:10px 20px;border:none;background:linear-gradient(90deg,#42b983,#2e5b87);color:#fff;font-size:16px;font-weight:700;border-radius:25px;cursor:pointer;box-shadow:0 4px 8px rgba(0,0,0,.2);z-index:1001;transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeInButton .3s ease-out .3s both}@keyframes fadeInButton{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.close-btn:hover{background:linear-gradient(90deg,#2e5b87,#42b983);box-shadow:0 6px 12px rgba(0,0,0,.3);transform:translateY(-2px)}.section{margin-bottom:30px;border:none;background:none;box-shadow:none;padding:0}h1{color:#2c3e50;text-align:center;font-size:2rem;margin:0}.resume-header{justify-content:space-between}.refresh-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;padding:8px;border-radius:50%;transition:color .3s,background-color .3s,transform .3s;color:#666;transform-origin:center center}.refresh-btn:hover:not(:disabled){background-color:#f5f5f5;color:#2e5b87;transform:translateY(-50%) rotate(180deg)}.refresh-btn.refreshing{color:#42b983;cursor:not-allowed;animation:spin 1s linear infinite}.refresh-btn:disabled{cursor:not-allowed;opacity:.7}h2,h3{color:#2e5b87}.education-section{margin-bottom:30px}.section-title{font-size:24px;margin-bottom:20px;color:#2e5b87}.education-list{display:flex;flex-direction:column;grid-gap:15px;gap:15px}.education-item{display:flex;flex-direction:row;align-items:center;margin-bottom:20px;padding:15px;border-radius:8px;background-color:#f5f5f5;border:1px solid #ddd;transition:all .3s ease;cursor:pointer;overflow:hidden;position:relative}.education-item.clickable:hover{transform:translateY(-5px);box-shadow:0 4px 12px rgba(0,0,0,.1);background-color:#fff}.edu-logo{width:110px;min-width:100px;height:100px;min-height:100px;margin-right:40px;border-radius:8px;background:#fff;padding:5px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.school-logo{max-width:100px;max-height:100px;margin:0 auto}.edu-right{display:flex;flex-direction:column;flex:1 1;margin-left:20px;justify-content:center}.edu-period{font-size:14px;margin-bottom:8px}.edu-content{display:flex;flex-direction:column;align-items:flex-start}.school-name{margin:0 0 4px}.degree,.major{margin:2px 0;color:#666;font-size:14px}.education-detail{padding:20px}.detail-content{padding:40px 20px;opacity:0;animation:fadeInContent .5s ease-out .2s forwards}@keyframes fadeInContent{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-leave .detail-content{animation:fadeOutContent .3s ease-out forwards}@keyframes fadeOutContent{0%{opacity:1}to{opacity:0}}.detail-content h2{color:#2c3e50;margin-bottom:20px;font-size:2rem}.degree-info{margin:15px 0}.degree-info .major{font-size:1.2em;color:#2c3e50;margin-bottom:8px;display:flex;justify-content:space-between}.highlight{color:#2e5b87;font-weight:700;margin-right:15px}.period{font-size:1.1em}.honors,.period{color:#666}.GPA{color:#42b983;font-weight:500}.modules h3,.scholarships h3{color:#2c3e50;margin:20px 0 10px;font-size:1.1em}.modules ul{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px;gap:10px;list-style:none;padding:0}.modules li{background:#f8f9fa;padding:8px 12px;border-radius:4px;transition:all .3s ease}.modules li:hover{background:#e9ecef;transform:translateX(5px)}.scholarships ul{list-style:none;padding:0}.scholarship-item{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed #eee}.year{color:#666}.award{color:#42b983;font-weight:500}.detail-panel::-webkit-scrollbar,.resume-container::-webkit-scrollbar{width:6px}.detail-panel::-webkit-scrollbar-thumb,.resume-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.detail-panel::-webkit-scrollbar-track,.resume-container::-webkit-scrollbar-track{background:#f1f1f1}.project-video{max-width:100%}@media (max-width:768px){.resume-container{position:static;width:100%;height:auto;margin-bottom:20px}.resume,.resume-container{padding:10px;box-shadow:none}.resume{margin:0 auto;border-radius:0}.resume,.show-detail .resume{max-width:100%;transform:none!important}.detail-panel{position:fixed;left:0;top:0;width:100%;height:100vh;margin:0;box-shadow:none;border:none;background:#fff;z-index:9999;overflow-y:auto;padding:20px}.detail-panel.slide-enter-active{transform:translateX(0);opacity:1}.close-btn{position:fixed;top:20px;right:20px}.education-item{flex-direction:column;text-align:center}.edu-left{margin-right:0;margin-bottom:15px}.edu-period{margin-bottom:5px}h1{font-size:1.5rem}h2{font-size:1.2rem}h3{font-size:1rem}.detail-content{padding-top:60px}}.error,.loading{text-align:center;padding:40px;font-size:1.2rem;color:#7f8c8d}.error{color:#e74c3c}.resume-info-container{display:flex;align-items:flex-start;justify-content:space-between}.resume-text-info{flex:1 1}.resume-text-info p{margin:8px 0;font-size:1rem;color:#2c3e50}.resume-profile-photo{width:130px;height:180px;object-fit:cover;margin-left:50px;border:1px solid #ccc}.resume-internship-container,.resume-project-container{display:flex;flex-direction:column;grid-gap:20px;gap:20px}.resume-internship-item,.resume-project-item{padding:15px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;transition:all .3s ease}.resume-internship-item:hover,.resume-project-item:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}.resume-skill-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:15px;gap:15px}.resume-skill-category{padding:15px;border:1px solid #ddd;border-radius:6px;background:#fff}.skill-content b,.skill-content strong{font-weight:700}.skill-content{background:none;border:none;box-shadow:none;padding:0;margin:0 0 30px}.resume-header{display:flex;justify-content:center;align-items:center;margin-bottom:20px;position:relative}.resume-header h1{flex:1 1;text-align:center;margin:0}.skills-container{display:flex;flex-direction:column;margin-bottom:20px;padding:15px;border-radius:8px;transition:all .3s ease;border:1px solid #ccc;background:#fff}.skill-content b,.skill-content strong{font-weight:800;color:#2e5b87}.project-experience-section{margin-bottom:30px}.project-experience-section h2{color:#2e5b87;font-size:24px;margin-bottom:20px}.project-list{grid-gap:15px;gap:15px}.project-item,.project-list{display:flex;flex-direction:column}.project-item{padding:15px;border-radius:8px;transition:all .3s ease;border:1px solid #ddd;background-color:#fff;cursor:pointer}.project-item.clickable:hover{transform:translateY(-5px);box-shadow:0 4px 12px rgba(0,0,0,.1);border-color:#2e5b87}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.project-header h3{margin:0;color:#2c3e50;font-size:18px}.project-time{color:#666;font-size:16px;font-weight:700}.brief{margin:5px 0 0;color:#666;font-size:14px;line-height:1.5}.project-detail{padding:20px}.project-detail h2{color:#2c3e50;margin-bottom:20px;font-size:28px}.project-detail h3{color:#2c3e50;margin:20px 0 10px;font-size:1.1em}.project-period{margin-bottom:15px;font-size:16px}.project-summary{background-color:#f8f9fa;padding:15px;border-left:4px solid #42b983;border-radius:4px;margin:15px 0}.other-section,.project-details-section{margin:20px 0}.other-section ul,.project-details-section ul{list-style-type:disc;padding-left:20px;margin-top:10px}.other-section li,.project-details-section li{margin:8px 0;line-height:1.6}.media-section{margin:20px 0}.video-container{width:100%;max-width:100%;margin:20px 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.1)}.project-video{width:100%;height:auto;max-height:400px;object-fit:contain;display:block}.image-container{width:100%;max-width:100%;margin:20px 0;text-align:center}.project-image{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.media-description{text-align:center;color:#666;font-style:italic;margin-top:10px}@media (max-width:768px){.project-header{flex-direction:column;align-items:flex-start}.project-time{margin-top:5px;font-size:14px}.project-detail h2{font-size:24px}}.education-header{justify-content:space-between;grid-gap:12px;gap:12px;margin-bottom:8px}.edu-logo,.education-header{display:flex;align-items:center}.edu-logo{width:40px;height:40px;justify-content:center;flex-shrink:0;margin-right:8px}.school-logo{max-width:36px;max-height:36px;width:auto;height:auto;object-fit:contain;border-radius:8px;display:block}.school-name{flex:1 1;font-size:18px;color:#2c3e50;margin:0 8px 0 0;text-align:left;overflow:hidden;text-overflow:ellipsis}.edu-period,.school-name{font-weight:700;white-space:nowrap}.edu-period{color:#666;font-size:15px;margin-left:8px;min-width:90px;text-align:right}.login-modal{background:hsla(0,0%,100%,.85);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.18);padding:40px 32px 32px;min-width:320px;max-width:90vw;display:flex;flex-direction:column;align-items:center;z-index:10001}.brand-title{font-family:"Brush Script MT",cursive,"华文行楷","楷体",serif;font-size:2.5rem;font-weight:700;color:#2e5b87;text-align:center;margin-bottom:20px;text-shadow:2px 2px 4px rgba(0,0,0,.1);letter-spacing:2px;background:linear-gradient(45deg,#2e5b87,#42b983);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:titleGlow 3s ease-in-out infinite alternate}@keyframes titleGlow{0%{filter:drop-shadow(0 0 5px rgba(46,91,135,.3))}to{filter:drop-shadow(0 0 15px rgba(66,185,131,.5))}}.login-modal h2{margin-bottom:24px;color:#2e5b87}.login-modal form{width:100%;display:flex;flex-direction:column;grid-gap:16px;gap:16px}.login-modal input{padding:10px 12px;border-radius:6px;border:1px solid #ccc;font-size:16px}.login-modal button{margin-top:8px;padding:10px 0;border-radius:6px;border:none;background:linear-gradient(90deg,#42b983,#2e5b87);color:#fff;font-size:18px;font-weight:700;cursor:pointer;transition:background .2s}.login-modal button:hover{background:linear-gradient(90deg,#2e5b87,#42b983)}.login-switch{margin-top:18px;color:#666;font-size:15px;text-align:center}.login-switch span{color:#2e5b87;cursor:pointer;margin-left:4px;text-decoration:underline}.login-error{color:#e74c3c;font-size:14px;margin-top:-8px;margin-bottom:4px}.container{display:flex;height:100vh;position:relative;overflow:hidden}.App{flex:0 0 50%;width:50%;padding:20px;overflow-y:auto;text-align:center;box-sizing:border-box}.divider{width:2px;background-color:#e0e0e0;height:100%;flex-shrink:0}.preview{flex-grow:0;flex-shrink:0;flex-basis:calc(50% - 2px);width:calc(50% - 2px);padding:10px;overflow-y:auto;text-align:left;background:#fff;box-sizing:border-box;position:relative}.preview-button{display:block;margin:20px auto;padding:12px 24px;background:linear-gradient(90deg,#42b983,#2e5b87);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px rgba(0,0,0,.2)}.preview-button:hover{background:linear-gradient(90deg,#2e5b87,#42b983);transform:translateY(-2px);box-shadow:0 6px 12px rgba(0,0,0,.3)}.Education-border,.PersonalInfo-border,.Project-border{background-color:#f9f9f9;border-radius:10px;margin:20px auto;padding:15px;box-shadow:0 2px 5px rgba(0,0,0,.1)}.preview-border{border:2px solid #a4a1a1;border-radius:10px;padding:10px;height:90%}.nav{margin-top:20px;padding:12px 5px;border-radius:15px;border:1px solid #6e6b71;background-color:#f9f9f9;position:relative;z-index:99}.tabs{display:flex;width:100%;justify-content:space-around;list-style-type:none;margin:0;padding:0}.tab{padding:12px 22px;background-color:#e0efff;color:#007bff;margin-right:15px;border-radius:55px;text-align:center;white-space:nowrap;transition:.3s ease;overflow:hidden;cursor:pointer;position:relative;flex-basis:120px;max-width:0}.tab:hover{background-color:#d9f3ff;color:#007bff}.tab-is-active{max-width:100px;box-shadow:2px 2px 12px currentColor}.tab-circle{position:absolute;height:30px;width:30px;border-radius:50%;border:2px solid #007bff;z-index:10;opacity:0;left:30px;pointer-events:none}.tab-icon{margin-right:1px;font-size:18px;vertical-align:middle;position:relative;right:8px;top:-1px}.tab-name{font-size:15px;font-weight:500;position:relative;transition:.3s ease;top:1px;opacity:0}.tab-is-active .tab-name{opacity:1}.dynamic-sections .section{display:none}.dynamic-sections .section.is-visible{display:block}@media (max-width:768px){.container{flex-direction:column;height:auto;overflow:visible}.App{flex:1 1 auto;width:100%;height:auto}.divider,.preview{display:none}.tabs{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;grid-gap:8px;gap:8px}.tab{margin:5px 0;max-width:none;flex:0 0 auto;padding:8px 12px}.tab-name{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}.detail-panel{animation-fill-mode:both}.detail-panel.slide-enter-active{animation:fadeIn .4s ease-out}.detail-panel.slide-leave-active{animation:fadeOut .4s ease-out}.show-detail .resume-container:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.1);opacity:0;transition:opacity .4s ease;pointer-events:none;opacity:1}.glass-mask{position:fixed;z-index:9999}@media (max-width:768px){.mobile-preview-overlay{position:fixed;z-index:10000;top:0;left:0;right:0;bottom:0;background:#fff;display:flex;flex-direction:column}.mobile-preview-header{padding:10px 16px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:flex-start}.mobile-preview-back{padding:6px 12px;border-radius:16px;border:1px solid #ccc;background:#f8f8f8;font-size:14px;cursor:pointer}.mobile-preview-body{flex:1 1 auto;overflow-y:auto;padding:8px;-webkit-overflow-scrolling:touch}}top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.4);.glass-bg{position:absolute;width:100vw;height:100vh;object-fit:cover;z-index:-1;top:0;left:0;filter:blur(4px) brightness(.8);pointer-events:none;-webkit-user-select:none;user-select:none}.glass-title{position:absolute;top:15%;left:50%;transform:translateX(-50%);font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;font-size:3.5rem;font-weight:300;color:hsla(0,0%,100%,.9);text-align:center;letter-spacing:8px;text-shadow:2px 2px 8px rgba(0,0,0,.3);z-index:10000;animation:titleFloat 4s ease-in-out infinite;background:linear-gradient(135deg,hsla(0,0%,100%,.9),hsla(0,0%,100%,.7));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 40px;border-radius:15px;border:1px solid hsla(0,0%,100%,.2)}@keyframes titleFloat{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-10px)}}.publish-btn{position:absolute;top:10px;right:10px;z-index:10;background:linear-gradient(90deg,#42b983,#2e5b87);color:#fff;border:none;border-radius:8px;padding:4px 10px;font-weight:600;font-size:14px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.08);min-width:60px;min-height:28px;transition:all .3s ease}.publish-btn:hover:not(:disabled){background:linear-gradient(90deg,#2e5b87,#42b983);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.publish-btn:disabled{cursor:not-allowed;opacity:.8}.publish-btn.publishing{background:linear-gradient(90deg,gold,#ff8c00)}.loading-spinner{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.publish-view-wrapper{max-width:1200px;margin:0 auto;padding:20px;position:relative;min-height:100vh}@media (min-width:769px){.publish-view-wrapper{padding:0}.publish-view-wrapper .resume-preview-container{overflow:hidden!important}.publish-view-wrapper .resume-container,.publish-view-wrapper .resume-preview-container{position:fixed!important;top:0!important;left:0!important;width:100%!important;height:100vh!important}.publish-view-wrapper .resume-container{padding:20px!important;overflow-y:auto!important;background:#fff!important}.publish-view-wrapper .resume{transition:all .5s ease!important;max-width:800px!important;margin:0 auto!important;background:#fff!important;padding:20px!important;border-radius:10px!important;box-shadow:0 0 20px rgba(0,0,0,.1)!important}.publish-view-wrapper .show-detail .resume{transform:translateX(-60%)!important;max-width:40%!important}.publish-view-wrapper .detail-panel{position:fixed!important;right:0!important;top:0!important;width:50%!important;height:100vh!important;background:#fff!important;padding:20px!important;box-shadow:-2px 0 10px rgba(0,0,0,.1)!important;overflow-y:auto!important;box-sizing:border-box!important;border-left:1px solid #ccc!important;opacity:1!important;transform:none!important;transition:none!important;animation:none!important}.publish-view-wrapper .detail-panel.slide-enter{animation:publishSlideIn .5s ease forwards!important}.publish-view-wrapper .detail-panel.slide-leave{animation:publishSlideOut .5s ease forwards!important}.publish-view-wrapper .show-detail .resume-container:after{display:none!important}}@keyframes publishSlideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes publishSlideOut{0%{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}@media (max-width:768px){.publish-view-wrapper{padding:10px}.publish-view-wrapper .resume-container{position:static!important;width:100%!important;height:auto!important;padding:10px!important;margin-bottom:20px!important;box-shadow:none!important}.publish-view-wrapper .resume{margin:0 auto!important;box-shadow:none!important;border-radius:0!important;padding:10px!important}.publish-view-wrapper .resume,.publish-view-wrapper .show-detail .resume{max-width:100%!important;transform:none!important}.publish-view-wrapper .detail-panel{position:fixed!important;left:0!important;top:0!important;width:100%!important;height:100vh!important;margin:0!important;box-shadow:none!important;border:none!important;background:#fff!important;z-index:999!important;overflow-y:auto!important;padding:20px!important}.publish-view-wrapper .close-btn{position:fixed!important;top:20px!important;right:20px!important}}.publish-view-wrapper .detail-panel::-webkit-scrollbar,.publish-view-wrapper .resume-container::-webkit-scrollbar{width:6px}.publish-view-wrapper .detail-panel::-webkit-scrollbar-thumb,.publish-view-wrapper .resume-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.publish-view-wrapper .detail-panel::-webkit-scrollbar-track,.publish-view-wrapper .resume-container::-webkit-scrollbar-track{background:#f1f1f1}.publish-view-wrapper .detail-content{padding:40px 20px}.publish-view-wrapper .video-container{margin:20px 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.1)}.publish-view-wrapper .project-video{width:100%;max-width:100%;display:block}@media (max-width:768px){.publish-view-wrapper h1{font-size:2rem}.publish-view-wrapper h2{font-size:1.2rem}.publish-view-wrapper h3{font-size:1rem}.publish-view-wrapper .detail-content{padding-top:60px}}
/*# sourceMappingURL=main.6cda0d63.chunk.css.map */