@import url(./background.css);@import url(https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;700&display=swap);@font-face{font-family:'IBM VGA';src:url(/fonts/WebPlus_IBM_VGA_8x14.woff) format('woff');font-weight:400;font-style:normal}html{scroll-behavior:smooth}html,body{margin:0;padding:0;height:100%;width:100%;overflow:hidden;position:fixed;font-family:'Dongle',sans-serif}body{cursor:none;margin:0;height:100vh;display:flex;justify-content:center;align-items:center;font-family:'Fira Code',monospace}.custom-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:10000;will-change:transform}.cursor-dot{position:absolute;width:8px;height:8px;background-color:#fff;border-radius:50%;transform:translate(-50%,-50%);transition:width 0.15s ease,height 0.15s ease,background-color 0.15s ease;will-change:transform}.cursor-outline{position:absolute;width:36px;height:36px;background-color:rgb(255 255 255 / .1);border:1px solid rgb(255 255 255 / .5);border-radius:50%;transform:translate(-50%,-50%);transition:width 0.15s ease,height 0.15s ease,background-color 0.15s ease,border-color 0.15s ease;will-change:transform}a,button,.window-button,[role="button"]{cursor:none}.cursor-dot.cursor-hover{width:12px;height:12px}.cursor-outline.cursor-hover{width:48px;height:48px}.cursor-hidden{display:none!important}#boot-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000;display:flex;justify-content:center;align-items:center;z-index:9999;font-family:'IBM VGA',monospace}.boot-slide{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;background-color:#000;opacity:0}#slide-1,#slide-2{transition:opacity 0.5s ease}#slide-3,#slide-4{transition:none}.boot-slide.active{opacity:1}.slide2-logo-container{position:relative;width:400px;height:auto}.slide2-logo-container .logo-only.base-logo{display:block;width:100%;height:auto}.slide2-logo-container .logo-only.overlay-logo{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;animation:pulseOpacity 3s ease-in-out infinite;opacity:.3}.manager-wrapper{width:700px;margin:0 auto}.manager-top-bar{width:100%;background:#ccc;height:40px;position:relative;box-sizing:border-box}.manager-top-bar .manager-title{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#000;font-weight:700}.manager-body{text-align:left;line-height:1.5;margin:20px 0;color:#fff}.selected-option-container{text-align:center;margin:15px 0}.selected-option{display:inline-block;padding:2px 8px;background:#fff;color:#000;font-weight:700}.manager-bottom-bar{width:100%;background:#ccc;height:40px;display:flex;justify-content:space-evenly;align-items:center;box-sizing:border-box}.manager-bottom-bar span{color:#000;font-size:14px}.lasryos-logo-container{position:relative;width:400px;height:auto}.lasryos-logo-container .boot-logo.base-logo{display:block;width:100%;height:auto}.lasryos-logo-container .boot-logo.overlay-logo{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;animation:pulseOpacity 3s ease-in-out infinite;opacity:.3}.boot-bottom-text{position:absolute;bottom:20px;left:10px;right:0;text-align:left;font-size:16px;color:#ccc}@keyframes pulseOpacity{0%{opacity:.3}50%{opacity:1}100%{opacity:.3}}.text-container{z-index:100;width:100vw;height:100vh;display:flex;position:absolute;top:0;left:0;justify-content:center;align-items:center;font-size:96px;color:#fff;opacity:.8;user-select:none;text-shadow:1px 1px rgb(0 0 0 / .1)}#aboutModal{display:none;max-height:70vh}.terminal{position:absolute;z-index:1000;top:50%;left:50%;transform:translate(-50%,-50%) translateY(30px);width:80%;max-width:900px;height:auto!important;min-height:300px;background:rgb(30 30 40 / .4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 0 30px rgb(0 0 0 / .15);border-radius:12px;color:#fff;font-family:'Fira Code',monospace;border:1px solid rgb(255 255 255 / .12);overflow:hidden;opacity:0;transition:opacity 0.7s cubic-bezier(.4,1.3,.6,1),transform 0.7s cubic-bezier(.4,1.3,.6,1)}.terminal.terminal-appear{opacity:1;transform:translate(-50%,-50%) translateY(0)}.terminal-header{padding:10px 15px;background:rgb(42 42 42 / .3);border-bottom:1px solid rgb(255 255 255 / .08);display:flex;justify-content:center;align-items:center;position:relative}.window-buttons{position:absolute;left:15px;top:50%;transform:translateY(-50%);display:flex;gap:8px}.window-button{width:12px;height:12px;border-radius:50%;display:inline-block}.window-button.red{background-color:#ff6057;box-shadow:0 0 5px rgb(255 96 87 / .5)}.window-button.yellow{background-color:#ffbd2e;box-shadow:0 0 5px rgb(255 189 46 / .5)}.window-button.green{background-color:#28ca41;box-shadow:0 0 5px rgb(40 202 65 / .5)}.terminal-title{font-size:14px;font-weight:500;color:rgb(255 255 255 / .8)}.terminal-body{padding:20px;background:#fff0;height:400px;overflow-y:auto;font-family:'Fira Code',monospace;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;-webkit-text-size-adjust:100%;text-size-adjust:100%}.terminal-body::-webkit-scrollbar{display:none}.terminal-line{margin:0;font-size:14px;line-height:1.6;white-space:pre-wrap;color:rgb(255 255 255 / .9);display:flex;align-items:center;flex-wrap:wrap}.prompt{color:#f7c85a;font-weight:600;margin-right:0}.command{color:#fff;font-weight:400}.output{color:#fff;margin:0 0 10px 0;font-size:14px;line-height:1.6;white-space:pre-wrap;width:100%}@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}.cursor{display:inline-block;width:10px;height:16px;background-color:#fff;margin-left:0;animation:blink 1s step-end infinite;vertical-align:middle}.command-separator{border:none;height:1px;margin:12px 0;opacity:.6;background:linear-gradient(to right,rgb(255 255 255 / .05),rgb(255 255 255 / .3),rgb(255 255 255 / .05));backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:opacity 0.3s ease}.command-separator:hover{opacity:1}.welcome-message{margin-bottom:20px;color:rgb(255 255 255 / .8);display:flex;flex-direction:column;align-items:center;padding:15px 0;font-family:'Fira Code',monospace;-webkit-text-size-adjust:100%;text-size-adjust:100%}.welcome-title{font-size:18px;font-weight:600;margin-bottom:10px;color:#fff}.welcome-subtitle{font-size:14px;opacity:.9}.command-hint{color:#ffbd2e;font-weight:700;background:rgb(255 189 46 / .1);padding:2px 6px;border-radius:4px}.modal-window{position:absolute;z-index:2000;background:rgb(30 30 40 / .4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:12px;width:60%;max-width:700px;color:#fff;box-shadow:0 0 30px rgb(0 0 0 / .2);overflow:hidden;font-family:'Fira Code',monospace;border:1px solid rgb(255 255 255 / .12);top:50%;left:50%;transform:translate(-50%,-50%);min-height:300px;animation:modalOpen 0.4s cubic-bezier(.165,.84,.44,1) forwards;transition:opacity 0.3s,transform 0.3s}@keyframes modalOpen{from{opacity:0;transform:translate(-50%,-60%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modal-header{user-select:none;-webkit-user-select:none}.modal-header:hover{background:rgb(52 52 62 / .4)}.modal-header.dragging{background:rgb(62 62 72 / .5)}.modal-body{padding:0!important}.modal-minimized{display:none!important}.modal-content{padding:10px}.modal-content h2{margin-top:0;font-size:24px;color:#fff;border-bottom:1px solid rgb(255 255 255 / .1);padding-bottom:10px}.profile-section{display:flex;align-items:center;margin:20px 0}.profile-image{flex:0 0 100px;margin-right:20px}.profile-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:2px solid rgb(255 255 255 / .2);box-shadow:0 0 15px rgb(0 0 0 / .2);image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;-ms-interpolation-mode:bicubic}.placeholder-image{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#4b6cb7 0%,#182848 100%);border:2px solid rgb(255 255 255 / .2);display:none}.profile-info h3{margin-top:0;color:#fff}.profile-info .title{color:#ffbd2e;margin:5px 0;font-size:1.1em;font-weight:500}.profile-info .subtitle{font-size:.9em;color:#b0b0b0;margin-top:5px}.profile-info .bio{margin-top:10px;font-size:14px}.about-text{margin-top:30px;padding:20px;background:rgb(255 255 255 / .05);border-radius:8px;border:1px solid rgb(255 255 255 / .1)}.about-text p{line-height:1.8;margin-bottom:15px;font-size:14px;color:rgb(255 255 255 / .9)}.about-text p:last-child{margin-bottom:0;font-style:italic;color:rgb(255 255 255 / .7)}.window-dock{position:fixed;bottom:10px;left:10px;display:flex;gap:8px;height:40px;z-index:1500;width:max-content}.minimized-window{margin:0!important;padding:0!important;transform:none!important;width:210px;height:32px;background:rgb(30 30 40 / .7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:6px;border:1px solid rgb(255 255 255 / .12);display:flex;align-items:center;overflow:hidden;font-family:'Fira Code',monospace;position:relative;transition:transform 0.2s ease-out,opacity 0.2s ease-out,box-shadow 0.2s ease-out}.minimized-window .terminal-header{width:100%;height:100%;display:flex;align-items:center;padding:0 10px;background:transparent!important;border:none!important;justify-content:flex-start}.minimized-window .window-buttons{position:static!important;transform:none!important;display:flex!important;gap:5px!important;margin-left:5px!important;margin-right:20px!important;flex-shrink:0!important}.minimized-window .window-button{width:8px;height:8px}.minimized-window .terminal-title{font-size:11px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:130px!important;color:rgb(255 255 255 / .9)!important}.minimized-window:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgb(0 0 0 / .25);border:1px solid rgb(255 255 255 / .2);background:rgb(40 44 52 / .8)}.minimized-window.disappearing{animation:dockDisappear 0.2s ease-in forwards}@keyframes minimizeAnimation{0%{opacity:1;transform:scale(1) translate(0,0)}100%{opacity:0;transform:scale(.3) translate(0,150vh)}}.minimizing{animation:minimizeAnimation 0.3s cubic-bezier(.2,.9,.4,1) forwards;pointer-events:none}@keyframes restoreWindow{0%{opacity:0;transform:translate(-50%,calc(-50% + 30px)) scale(.9)}100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}.restoring{animation:restoreWindow 300ms cubic-bezier(.2,.9,.1,1) forwards!important}@keyframes dockAppear{0%{opacity:0;transform:translateY(20px) scale(.8)}100%{opacity:1;transform:translateY(0) scale(1)}}@keyframes dockDisappear{0%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(10px) scale(.9)}}.restore-animation{position:fixed;z-index:10000;pointer-events:none;border-radius:6px;overflow:hidden;background:rgb(30 30 40 / .4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgb(255 255 255 / .12);box-shadow:0 5px 30px rgb(0 0 0 / .15)}@keyframes standardRestore{0%{opacity:1;transform:scale(1)}100%{opacity:1;transform:scale(10)}}.standard-restore{animation:standardRestore 300ms cubic-bezier(.2,.9,.1,1) forwards}@keyframes greenRestore{0%{opacity:1;transform:scale(1);box-shadow:0 0 0 #fff0}15%{opacity:1;transform:scale(1.1);box-shadow:0 0 20px rgb(40 202 65 / .3)}100%{opacity:1;transform:scale(10);box-shadow:0 0 30px #fff0}}.green-restore{background:rgb(40 202 65 / .1);border:1px solid rgb(40 202 65 / .3);animation:greenRestore 350ms cubic-bezier(.34,1.56,.64,1) forwards}.modern-clock,#modern-clock,.date-header,#date-header{position:fixed!important;top:18px;color:rgb(255 255 255 / .9);left:0;width:100vw;text-align:center;z-index:1!important;pointer-events:none;user-select:none}.modern-clock{font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:300;letter-spacing:.5px;text-align:center;z-index:9000;text-shadow:0 2px 4px rgb(0 0 0 / .3);pointer-events:none;opacity:.85;transition:opacity 0.3s ease;padding:5px 12px;border-radius:4px}.modern-clock:hover{opacity:1}#main-content{display:none;position:relative;width:100%;height:100vh}#pre-lockscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;display:none;background:rgb(0 0 0 / .8);backdrop-filter:blur(10px);z-index:10000}#preLockTime{position:absolute;top:50px;right:1200px;text-align:left}.date-part{font-size:26px;color:rgb(255 255 255 / .8);font-weight:300}.hour-part{font-size:98px;color:#fff;font-weight:400}.arrow-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);font-size:32px;color:#fff;opacity:.8;animation:blinkArrow 2s infinite}@keyframes blinkArrow{0%,100%{opacity:.8}50%{opacity:.2}}@keyframes slideUpOut{0%{transform:translateY(0%);opacity:1}100%{transform:translateY(-100%);opacity:0}}@keyframes slideUpIn{0%{transform:translateY(100%);opacity:0}100%{transform:translateY(0%);opacity:1}}.slide-up-out{animation:slideUpOut 0.7s forwards ease}.slide-up-in{animation:slideUpIn 0.7s forwards ease}#login-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;display:none;flex-direction:column;justify-content:center;align-items:center;background:rgb(0 0 0 / .7);backdrop-filter:blur(10px);z-index:9999}#login-screen .login-content{display:flex;flex-direction:column;gap:20px;align-items:center;background:rgb(28 32 38 / .6);border-radius:12px;border:1px solid rgb(255 255 255 / .1);padding:30px;box-shadow:0 4px 20px rgb(0 0 0 / .3);width:320px}.login-avatar{margin-bottom:10px}.login-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid #ff702e;box-shadow:0 0 15px rgb(255 112 46 / .5)}.login-title{color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:500;letter-spacing:1px;margin:0}.input-group{position:relative;width:100%}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#ff702e;display:flex;align-items:center;pointer-events:none}#login-screen input{width:100%;cursor:none;padding:10px 10px 10px 35px;border:1px solid rgb(255 255 255 / .3);background:rgb(255 255 255 / .1);color:#fff;font-size:16px;border-radius:6px;outline:none;transition:border-color 0.3s ease;box-sizing:border-box}#login-screen input:focus{border-color:#ff702e}#login-btn{width:100%;padding:12px;border:none;border-radius:6px;background:rgb(255 112 46 / .8);color:#fff;font-size:16px;font-weight:600;transition:background 0.3s,transform 0.3s;cursor:none}#login-btn:hover{background:#ff702e;transform:scale(1.03)}#togglePassword.eye-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#fff0;border:none;outline:none;cursor:none;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}input[type="password"]::-ms-reveal,input[type="password"]::-ms-clear,input[type="password"]::-webkit-clear-button,input[type="password"]::-webkit-reveal-button{display:none}::-webkit-textfield-decoration-container{display:none}#togglePassword.eye-icon svg{fill:#fff;transition:fill 0.3s ease}#togglePassword.eye-icon:hover svg{fill:#ff702e}.login-help{color:rgb(255 255 255 / .7);font-size:14px;font-family:'Fira Code',monospace;text-align:center;margin-top:5px}@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}.fade-in{animation:fadeIn 0.7s forwards ease}.gradient-bg{filter:grayscale(100%);transition:filter 5s ease;position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0}.gradient-bg.colorized{filter:grayscale(5%)}.input-error{border-color:#ff6057!important;animation:shake 0.3s}@keyframes shake{0%,100%{transform:translateX(0)}25%,75%{transform:translateX(-5px)}50%{transform:translateX(5px)}}#skillsModal{max-width:700px!important;min-width:420px!important;max-height:420px!important}#skillsModal .skills-content{max-height:340px;overflow-y:auto;padding-right:8px;scrollbar-width:none;-ms-overflow-style:none;padding:32px 32px 32px 32px}#skillsModal .skills-content::-webkit-scrollbar{width:0;background:#fff0}#skillsModal .skills-section{margin-bottom:28px;background:rgb(255 255 255 / .03);border-radius:10px;padding:18px 18px 12px 18px;box-shadow:0 2px 8px rgb(0 0 0 / .04);border:1px solid rgb(255 255 255 / .08)}#skillsModal .skills-section h3{color:#ffbd2e;font-size:1.18em;font-weight:700;margin-bottom:14px;margin-top:0;letter-spacing:.5px;text-align:left}#skillsModal .skills-list{list-style:none;padding:0;margin:0}#skillsModal .skills-list li{margin-bottom:8px;font-size:1em;color:#fff;display:flex;align-items:center;gap:8px;line-height:1.5}#skillsModal .soft-skills li{color:#fff;font-weight:500}@media (max-width:900px){#skillsModal .skills-content{flex-direction:column;gap:10px}#skillsModal .skills-section{min-width:unset;width:100%}}.projects-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;padding:18px 18px 8px 18px;max-height:370px;overflow-y:auto;margin:0 8px}.projects-content::-webkit-scrollbar{width:0;background:#fff0}.projects-content{scrollbar-width:none;-ms-overflow-style:none}.project-card{position:relative;min-width:320px;min-height:180px;background:#23232b url(public/images/placeholder.png) center/cover no-repeat;border-radius:28px;box-shadow:0 2px 18px #0005;overflow:hidden;cursor:none;display:flex;align-items:flex-end;justify-content:center;transition:box-shadow 0.25s,transform 0.22s;background-blend-mode:overlay}.project-card .project-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgb(0 0 0 / .85) 0%,rgb(0 0 0 / .2) 60%,#fff0 100%);transition:background 0.3s ease}.project-card-content{position:relative;z-index:2;padding:20px;color:#fff;text-shadow:0 1px 5px rgb(0 0 0 / .5);transition:transform 0.3s ease;text-align:center}.project-card .project-title{font-size:1.5em;font-weight:600;line-height:1.2;margin-bottom:5px}.project-card .project-subtitle{font-size:.9em;font-weight:400;color:rgb(255 255 255 / .8);opacity:0;transition:opacity 0.3s ease,transform 0.3s ease;transform:translateY(10px)}.project-card:hover .project-overlay{background:linear-gradient(to top,rgb(0 0 0 / .9) 0%,rgb(0 0 0 / .4) 70%,rgb(0 0 0 / .1) 100%)}.project-card:hover .project-card-content{transform:translateY(-5px)}.project-card:hover .project-subtitle{opacity:1;transform:translateY(0)}.project-detail{display:flex;flex-direction:column;align-items:center;padding:30px;text-align:center;position:relative}.project-detail .project-detail-img{width:100%;max-width:420px;height:180px;object-fit:cover;border-radius:14px;margin-bottom:18px;box-shadow:0 2px 18px #0003}.project-detail .project-detail-title{font-size:1.5em;color:#ffbd2e;font-weight:800;margin-bottom:8px;text-align:center}.project-detail .project-detail-desc{color:#fff;font-size:1.08em;margin-bottom:14px;text-align:center}.project-detail .project-techs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px;justify-content:center}.project-detail .tech-badge{background:rgb(255 189 46 / .1);color:#ffbd2e;border-radius:14px;padding:7px 18px;font-size:1em;font-weight:600;box-shadow:0 2px 8px #ffbd2e22;border:1.2px solid #ffbd2e33;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);margin-bottom:2px;margin-right:7px;transition:background 0.18s,color 0.18s,transform 0.18s,box-shadow 0.18s,border 0.18s;display:inline-block}.project-detail .tech-badge:hover{background:rgb(255 189 46 / .18);color:#fff;transform:translateY(-2px) scale(1.06);box-shadow:0 4px 18px #ffbd2e33;border:1.2px solid #ffbd2e}.project-detail .project-links{margin-top:10px;display:flex;gap:16px}.project-detail .project-links a{color:#ffbd2e;font-weight:700;text-decoration:underline;font-size:1.08em;transition:color 0.18s}.project-detail .project-links a:hover{color:#fff}.project-detail .back-btn{background:rgb(255 255 255 / .1);border:1px solid rgb(255 255 255 / .2);color:#fff;padding:10px 25px;font-size:14px;border-radius:8px;font-weight:500;transition:all 0.3s ease;cursor:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);margin-top:30px}.project-detail .back-btn:hover{background:rgb(255 255 255 / .2);border-color:rgb(255 255 255 / .3)}#musicPlayerModal{min-width:250px!important;max-width:320px!important;background:rgb(45 45 55 / .55)!important;backdrop-filter:blur(14px)!important;-webkit-backdrop-filter:blur(14px)!important;border:1px solid rgb(255 255 255 / .1)!important;border-radius:22px!important;box-shadow:0 4px 30px rgb(0 0 0 / .2)!important}.music-player{padding:16px;display:flex;flex-direction:column;align-items:center;gap:16px}.music-cover{width:120px;height:120px;border-radius:18px;overflow:hidden;box-shadow:0 4px 15px rgb(0 0 0 / .25);margin-bottom:0}.music-cover img{width:100%;height:100%;object-fit:cover;border-radius:0}.music-info{text-align:center;margin-top:4px}#music-title{color:#ffbd2e;font-size:1.25em;font-weight:700;margin-bottom:4px;text-align:center}#music-artist{color:#e0e0e0;font-size:1em;text-align:center}.music-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin:0}.music-btn{background:#fff0;border:none;cursor:none!important;padding:0;display:flex;align-items:center;justify-content:center;transition:transform 0.2s,background-color 0.2s;border-radius:0;box-shadow:none;outline:none}.music-btn:hover{transform:scale(1.1);background:#fff0}#music-play{width:48px;height:48px;background-color:rgb(83 67 91 / .7);border-radius:50%;box-shadow:0 2px 8px rgb(0 0 0 / .3)}#music-play:hover{background-color:rgb(93 77 101 / .9);transform:scale(1.05)}.music-progress{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;font-size:.85em;color:#ccc;margin-top:8px;margin-bottom:0}#music-seek{accent-color:initial;background:rgb(255 255 255 / .2);height:4px}.music-volume{width:80%;display:flex;align-items:center;justify-content:center;gap:10px;font-size:.85em;color:#ccc;margin-top:8px;margin-bottom:0}#music-volume{max-width:120px;height:4px;background:rgb(255 255 255 / .2)}.music-volume-icon{color:#ccc;font-size:1.2em;opacity:1}input[type="range"]{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:rgb(255 255 255 / .25);border-radius:5px;outline:none;padding:0;margin:0}input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#ffbd2e;border-radius:50%;cursor:pointer;border:none}input[type="range"]::-moz-range-thumb{width:14px;height:14px;background:#ffbd2e;border-radius:50%;cursor:pointer;border:none}@media (max-width:500px){#musicPlayerModal{min-width:180px!important;max-width:98vw!important}}.skills-grid{display:flex;flex-wrap:wrap;gap:22px 32px;justify-content:flex-start;align-items:flex-start;margin-top:0}.skill-item{display:flex;flex-direction:column;align-items:center;min-width:90px;max-width:120px;margin-bottom:8px;transition:transform 0.18s,box-shadow 0.18s;cursor:none;flex:1 0 90px;box-sizing:border-box}.skill-item:hover{transform:translateY(-4px) scale(1.06);box-shadow:0 4px 18px rgb(255 255 255 / .08);background:rgb(255 255 255 / .03);border-radius:12px}.skill-icon{width:40px;height:40px;object-fit:contain;margin-bottom:7px;box-shadow:none;background:none;border-radius:0}.skill-item span{font-size:1em;color:#fff;margin-top:2px;text-align:center;font-weight:500;letter-spacing:.1px}#aboutModal .modal-body{display:flex;flex-direction:column;align-items:center;padding:32px 24px 24px 24px;background:rgb(30 30 40 / .18);overflow-y:auto;max-height:450px;border-radius:0 0 16px 16px;scrollbar-width:none;-ms-overflow-style:none}#aboutModal .modal-body::-webkit-scrollbar{width:0;background:#fff0}#aboutModal .modal-content{width:100%;max-width:520px;display:flex;flex-direction:column;align-items:center;gap:18px}#aboutModal h2{font-size:2.1em;color:#ffbd2e;font-family:'Space Grotesk',monospace;font-weight:800;margin-bottom:8px;letter-spacing:1.2px;text-align:center}#aboutModal .profile-section{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:10px}#aboutModal .profile-image img{width:110px;height:110px;border-radius:50%;object-fit:cover;border:3px solid #ffbd2e;box-shadow:0 2px 18px #ffbd2e33;transition:transform 0.18s,box-shadow 0.18s}#aboutModal .profile-image img:hover{transform:scale(1.06) rotate(-2deg);box-shadow:0 6px 32px #ffbd2e55}#aboutModal .profile-info h3{font-size:1.3em;color:#fff;margin:0 0 2px 0;font-weight:700;text-align:center}#aboutModal .profile-info .title{color:#ffbd2e;font-size:1.08em;font-weight:600;margin:0;text-align:center}#aboutModal .profile-info .subtitle{font-size:.9em;color:#b0b0b0;margin-top:5px}#aboutModal .bio-block{margin-top:25px;padding-top:20px;border-top:1px solid rgb(255 255 255 / .1)}#aboutModal .bio-block p{margin-bottom:1em;line-height:1.6;color:#d0d0d0}.help-output{border:1px solid rgb(255 255 255 / .15);border-radius:8px;padding:16px 20px;margin-top:10px;background:rgb(255 255 255 / .05);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.help-title{color:#ffbd2e;font-weight:700;font-size:1.1em;margin-bottom:14px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgb(255 189 46 / .3);padding-bottom:8px}.help-grid{display:grid;grid-template-columns:130px 1fr;gap:10px 15px;align-items:baseline}.help-command{color:#f7c85a;font-weight:600;text-align:right;padding-right:15px}.help-description{color:#fff;white-space:normal}.contact-output{border:1px solid rgb(255 255 255 / .1);border-radius:18px;padding:14px 18px;margin-top:10px;background:rgb(255 255 255 / .035);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);max-width:340px;text-align:left}.contact-list{display:flex;flex-direction:column;gap:18px;align-items:flex-start;width:100%}.contact-item{display:flex;align-items:center;gap:12px;color:#fff;font-size:1em;width:100%;cursor:none}.contact-link{color:#fff;text-decoration:none;font-weight:600;transition:color 0.18s,text-decoration 0.18s;display:inline-block;padding-top:2px}.contact-link:hover{color:#ffbd2e;text-decoration:underline}.contact-icon{width:22px;height:22px;min-width:22px;min-height:22px;color:#ffbd2e;margin-right:10px;vertical-align:middle;display:flex;align-items:center;justify-content:center}.play-btn{background:linear-gradient(135deg,#ff4655,#e03b48);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:none;transition:all 0.3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 15px rgb(255 70 85 / .3)}.play-btn:hover{background:linear-gradient(135deg,#e03b48,#c0323a);transform:translateY(-2px);box-shadow:0 6px 20px rgb(255 70 85 / .4)}.play-btn:active{transform:translateY(0);box-shadow:0 2px 10px rgb(255 70 85 / .3)}#promptoGameModal{width:90vw;max-width:1200px;height:80vh;max-height:800px}#promptoGameModal .modal-body{padding:0;height:calc(100% - 40px)}#promptoGameModal iframe{width:100%;height:100%;border:none}#promptoGameModal .modal-header{border-bottom:2px solid #4a4a4a}@media (max-width:768px){#promptoGameModal{width:95vw;height:90vh}}.soft-skills-section{margin-top:18px;background:rgb(255 255 255 / .04);border-radius:8px;padding:16px 14px 10px 14px;box-shadow:0 2px 8px rgb(0 0 0 / .04);border:1px solid rgb(255 255 255 / .08)}.soft-skills-section h3{color:#ffbd2e;font-size:1.08em;font-weight:600;margin-bottom:10px;margin-top:0}.soft-skills-grid{display:flex;flex-wrap:wrap;gap:22px 32px;justify-content:flex-start;align-items:flex-start;margin-top:0}.soft-emoji{font-size:40px!important;min-width:40px;min-height:40px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin-bottom:7px;text-align:center;line-height:1}@media (max-width:900px){.skills-grid,.soft-skills-grid{flex-direction:row;gap:14px 12px}.skills-section{padding:12px 6px 8px 6px}.skill-item{min-width:70px;max-width:100px}}.about-quote{position:relative;margin:24px 0 0 0;padding:32px 32px 24px 48px;background:rgb(255 255 255 / .04);border-left:5px solid #ffbd2e;border-radius:12px;font-style:italic;font-size:.98em;color:#fff;box-shadow:0 2px 12px rgb(0 0 0 / .07);font-family:'Fira Code','Fira Mono',monospace;line-height:1.7;letter-spacing:.01em}.about-quote:before{content:"“";position:absolute;left:18px;top:18px;font-size:2em;color:#ffbd2e;font-family:serif;opacity:.7;line-height:1}.about-quote:after{content:"”";position:absolute;right:24px;bottom:10px;font-size:1.5em;color:#ffbd2e;font-family:serif;opacity:.7;line-height:1}@media (max-width:700px){.about-quote{padding:22px 12px 18px 22px;font-size:1em}.about-quote:before{left:7px;top:7px;font-size:2em}.about-quote:after{right:10px;bottom:4px;font-size:1.5em}}#experiencesModal{max-width:700px!important;min-width:420px!important;max-height:480px!important}#experiencesModal .experiences-content{max-height:400px;overflow-y:auto;padding-right:8px;padding-top:10px;scrollbar-width:none;-ms-overflow-style:none}#experiencesModal .experiences-content::-webkit-scrollbar{width:0;background:#fff0}.timeline{position:relative;margin:0 0 0 30px;padding-left:20px;border-left:3px solid #ffbd2e}.timeline-item{position:relative;margin-bottom:36px;padding-left:18px;cursor:none;transition:background 0.18s,box-shadow 0.18s;border-radius:8px}.timeline-item:hover{background:rgb(255 189 46 / .07);box-shadow:0 2px 12px #ffbd2e22}.timeline-item.open{background:rgb(255 189 46 / .13);box-shadow:0 4px 18px #ffbd2e33}.timeline-date{font-size:1.08em;color:#ffbd2e;font-weight:700;margin-bottom:2px}.timeline-title{font-size:1.08em;font-weight:600;color:#fff;margin-bottom:2px}.timeline-missions{font-size:.98em;color:#e0e0e0;margin-bottom:0;line-height:1.6}.timeline-details{display:none;background:rgb(255 255 255 / .04);border-left:3px solid #ffbd2e;margin:12px 0 0 0;padding:16px 18px 12px 18px;border-radius:8px;color:#fff;font-size:.97em;box-shadow:0 2px 8px #ffbd2e11;animation:fadeInDetails 0.3s}.timeline-item.open .timeline-details{display:block}@keyframes fadeInDetails{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.timeline-item:before{content:'';position:absolute;left:-32px;top:7px;width:16px;height:16px;background:#ffbd2e;border-radius:50%;box-shadow:0 2px 8px #ffbd2e44;border:2px solid #fff2}@media (max-width:700px){#experiencesModal{min-width:90vw!important;max-width:98vw!important}.timeline{margin-left:10px;padding-left:10px}.timeline-item{padding-left:8px}.timeline-item:before{left:-18px;width:12px;height:12px}}.exp-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgb(0 0 0 / .4);z-index:3000;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay 0.3s;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:1;transition:opacity 0.35s cubic-bezier(.4,1.3,.6,1)}.exp-overlay.hide{opacity:0;pointer-events:none}.exp-focus-card{background:none!important;box-shadow:none!important;border-radius:0!important;color:#fff;padding:0!important;max-width:900px;width:98vw;max-height:98vh;margin:0 auto;font-family:'Fira Code',monospace;overflow-y:auto;animation:popInCard 0.32s cubic-bezier(.4,1.3,.6,1);display:flex;flex-direction:column;gap:0;align-items:flex-start;scrollbar-width:none;-ms-overflow-style:none}@keyframes popInCard{from{opacity:0;transform:scale(.95) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.exp-focus-card .exp-back-btn{position:fixed;top:32px;left:32px;background:none!important;border:none!important;color:#ffbd2e!important;font-size:2.5em!important;font-weight:900;cursor:none!important;z-index:4000;padding:0!important;margin-bottom:0!important;box-shadow:none!important;border-radius:50%!important;transition:all 0.2s ease!important;line-height:1;width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-family:'Fira Code',monospace;letter-spacing:-2px;text-shadow:0 2px 8px rgb(0 0 0 / .8)}.exp-focus-card .exp-back-btn:hover{color:#fff!important;background-color:rgb(255 255 255 / .1)!important;transform:scale(1.1)!important}.exp-focus-title{font-size:2.2em;font-weight:900;color:#ffbd2e;margin-bottom:18px;margin-top:32px;letter-spacing:.5px;text-align:center;width:100%;text-shadow:0 2px 18px #ffbd2e33,0 1px 0 #000}.exp-focus-section{margin-bottom:32px;font-size:1.18em;color:#fff;line-height:1.7;width:100%;text-align:left;display:flex;align-items:flex-start;gap:12px;border-radius:7px;padding:10px 14px 10px 0}.exp-focus-section:not(:last-child){border-bottom:1px solid rgb(255 255 255 / .08);padding-bottom:18px}.exp-focus-section .exp-icon{font-size:1.25em;margin-right:8px;flex-shrink:0;opacity:.85}.exp-focus-section .exp-label{color:#ffbd2e;font-weight:600;margin-right:6px;min-width:120px;display:inline-block}.exp-focus-section .exp-value{color:#fff;font-weight:500;flex:1 1 auto;word-break:break-word;line-height:1.7;border-radius:8px;padding:2px 14px}@media (max-width:700px){.exp-focus-card .exp-back-btn{top:10px;left:10px;font-size:2em!important;width:40px;height:40px}.exp-focus-title{margin-top:38px;font-size:1.3em}.exp-focus-section{font-size:1em;margin-bottom:18px;padding-bottom:10px;gap:7px}.exp-focus-section .exp-label{min-width:80px}}.exp-retour-quote{position:relative;margin:18px 0 0 0;padding:22px 22px 18px 38px;background:rgb(255 255 255 / .05);border-left:4px solid #ffbd2e;border-radius:10px;font-style:italic;font-size:1.08em;color:#fff;box-shadow:0 2px 12px rgb(0 0 0 / .07);line-height:1.7;letter-spacing:.01em}.exp-retour-quote:before{content:"“";position:absolute;left:12px;top:10px;font-size:2em;color:#ffbd2e;font-family:serif;opacity:.7;line-height:1}.exp-retour-quote:after{content:"”";position:absolute;right:18px;bottom:8px;font-size:1.5em;color:#ffbd2e;font-family:serif;opacity:.7;line-height:1}.exp-tags{display:flex;flex-wrap:wrap;gap:10px 14px;margin:8px 0 0 0}.exp-tag{background:rgb(255 189 46 / .1);color:#ffbd2e;border-radius:14px;padding:7px 18px;font-size:1em;font-weight:600;box-shadow:0 2px 8px #ffbd2e22;border:1.2px solid #ffbd2e33;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);margin-bottom:2px;margin-right:7px;transition:background 0.18s,color 0.18s,transform 0.18s,box-shadow 0.18s,border 0.18s;display:inline-block;cursor:none!important}.exp-tag:hover{background:rgb(255 189 46 / .18);color:#fff;transform:translateY(-2px) scale(1.06);box-shadow:0 4px 18px #ffbd2e33;border:1.2px solid #ffbd2e}.project-overlay-focus{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgb(0 0 0 / .4);z-index:3500;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay 0.3s;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:1;transition:opacity 0.35s cubic-bezier(.4,1.3,.6,1)}.project-overlay-focus.hide{opacity:0;pointer-events:none}.project-focus-card,.exp-focus-card{box-sizing:initial;padding-left:28px;padding-right:28px;max-width:700px;width:96vw;margin:0 auto;display:flex;flex-direction:column;align-items:center}@media (max-width:700px){.project-focus-card,.exp-focus-card{padding-left:2vw;padding-right:2vw;max-width:98vw}}.project-focus-title{font-size:3.2em;font-weight:900;color:#ffbd2e;margin-bottom:35px;margin-top:25px;letter-spacing:.5px;text-align:center;width:100%;text-shadow:0 2px 18px #ffbd2e33,0 1px 0 #000}.project-focus-img{width:100%;max-width:420px;height:180px;object-fit:cover;border-radius:14px;margin:0 auto 28px auto;box-shadow:0 2px 18px #0003;display:block;transition:transform 0.3s ease,box-shadow 0.3s ease;cursor:none}.project-focus-img:hover{transform:scale(1.05);box-shadow:0 4px 25px #0005}.project-focus-desc{max-width:650px;margin:0 auto 28px auto;line-height:1.85;font-size:1.18em;text-align:left;word-break:break-word;padding:18px 18px 18px 18px;color:#f3f3f3;background:rgb(255 255 255 / .04);border-radius:12px;box-shadow:0 2px 12px #0002}.project-focus-section{width:100%;max-width:700px;margin:0 auto 18px auto;padding:0 0 0 0;display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px 18px;background:none;border-radius:0}.project-focus-section .project-label{color:#ffbd2e;font-weight:900;font-size:1.08em;letter-spacing:.5px;min-width:120px;text-transform:uppercase;margin-right:8px;display:flex;align-items:center;justify-content:flex-start}.project-focus-tags{display:flex;flex-wrap:wrap;gap:12px 18px;margin:0 0 0 0;align-items:center}.project-focus-tag{background:rgb(255 189 46 / .1);color:#ffbd2e;border-radius:14px;padding:7px 18px;font-size:1em;font-weight:600;box-shadow:0 2px 8px #ffbd2e22;border:1.2px solid #ffbd2e33;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);margin-bottom:2px;margin-right:7px;transition:background 0.18s,color 0.18s,transform 0.18s,box-shadow 0.18s,border 0.18s;display:inline-block;cursor:none}.project-focus-tag:hover{background:rgb(255 189 46 / .18);color:#fff;transform:translateY(-2px) scale(1.06);box-shadow:0 4px 18px #ffbd2e33;border:1.2px solid #ffbd2e}.project-focus-links{margin-top:32px;display:flex;gap:16px;justify-content:center;align-items:center;width:100%;overflow:visible!important}.button-jouer{margin-bottom:0}@media (max-width:700px){.project-focus-card{padding:0 2vw 18px 2vw;max-height:98vh}.project-focus-title{margin-top:38px;font-size:1.2em}.project-focus-img{max-width:98vw;height:120px;margin-bottom:18px;transition:transform 0.3s ease,box-shadow 0.3s ease;cursor:none}.project-focus-img:hover{transform:scale(1.03);box-shadow:0 4px 20px #0004}.project-focus-desc{font-size:1em;padding:10px 4px;margin-bottom:18px}.project-focus-section{gap:7px 8px;margin-bottom:10px}.project-focus-section .project-label{min-width:70px;font-size:.98em}.project-focus-tags{gap:7px 8px}}.project-focus-card{scrollbar-width:none!important}.project-focus-card::-webkit-scrollbar{display:none!important}.button-jouer{padding:.6em 2em;border:none;outline:none;color:#fff;background:#18181c;cursor:none;position:relative;z-index:0;border-radius:10px;user-select:none;font-family:'Fira Code',monospace;font-size:1.13em;font-weight:700;letter-spacing:.5px;box-shadow:0 2px 12px #0008;transition:background 0.18s,color 0.18s,box-shadow 0.18s;overflow:hidden;margin:0 0 0 0;display:inline-block;text-decoration:none;border:2px solid #fff0}.button-jouer:before{content:"";background:linear-gradient(90deg,#ffbd2e 0%,#ffbd2e 100%);position:absolute;top:-8px;left:-8px;width:calc(100% + 16px);height:calc(100% + 16px);z-index:-1;filter:blur(10px);-webkit-filter:blur(10px);border-radius:14px;opacity:.55;pointer-events:none}.button-jouer:after{z-index:-1;content:"";position:absolute;width:100%;height:100%;background:#18181c;cursor:none;left:0;top:0;border-radius:10px}.button-jouer:hover,.button-jouer:focus{background:#23232a;color:#ffbd2e;box-shadow:0 4px 24px #ffbd2e55;border:2px solid #ffbd2e}.project-focus-card .project-back-btn{position:fixed;top:32px;left:32px;background:none!important;border:none!important;color:#ffbd2e!important;font-size:2.5em!important;font-weight:900;cursor:none!important;z-index:4000;padding:0!important;margin-bottom:0!important;box-shadow:none!important;border-radius:50%!important;transition:all 0.2s ease!important;line-height:1;width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-family:'Fira Code',monospace;letter-spacing:-2px;text-shadow:0 2px 8px rgb(0 0 0 / .8)}.project-focus-card .project-back-btn:hover{color:#fff!important;background-color:rgb(255 255 255 / .1)!important;transform:scale(1.1)!important}@media (max-width:700px){.project-focus-card .project-back-btn{top:10px;left:10px;font-size:2em!important;width:40px;height:40px}}.project-focus-card a,.exp-focus-card a{color:#ffbd2e!important;text-decoration:none!important;font-weight:700;transition:color 0.18s}.project-focus-card a:hover,.exp-focus-card a:hover{color:#fff!important}.exp-focus-card{max-width:700px;width:96vw;margin:0 auto;background:none;color:#fff;font-family:'Fira Code',monospace;display:flex;flex-direction:column;align-items:center;gap:0;box-sizing:border-box;padding:0 28px 38px 28px;border-radius:18px;overflow-y:auto!important;overflow-x:visible!important;scrollbar-width:none!important}.exp-focus-card::-webkit-scrollbar{display:none!important}.exp-focus-title{font-size:2.2em;font-weight:900;color:#ffbd2e;margin-bottom:35px;margin-top:25px;letter-spacing:.5px;text-align:center;width:100%;text-shadow:0 2px 18px #ffbd2e33,0 1px 0 #000}.exp-focus-section{width:100%;max-width:700px;margin:0 auto 18px auto;padding:0 0 0 0;display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px 18px;background:none;border-radius:0}.exp-focus-section .exp-label{color:#ffbd2e;font-weight:600;font-size:1.08em;letter-spacing:.5px;min-width:120px;margin-right:8px;display:flex;align-items:center;justify-content:flex-start}.exp-focus-section .exp-value{color:#fff;font-weight:500;flex:1 1 auto;word-break:break-word;line-height:1.7;border-radius:8px;padding:2px 14px}.exp-retour-quote{background:rgb(255 255 255 / .07);border-left:4px solid #ffbd2e;border-radius:10px;font-style:italic;font-size:1.08em;color:#fff;box-shadow:0 2px 12px rgb(0 0 0 / .07);margin:18px 0 0 0;padding:22px 22px 18px 38px}@media (max-width:700px){.exp-focus-card{padding:0 2vw 18px 2vw;max-height:98vh}.exp-focus-title{margin-top:38px;font-size:1.2em}.exp-focus-section{gap:7px 8px;margin-bottom:10px}.exp-focus-section .exp-label{min-width:70px;font-size:.98em}.exp-focus-section .exp-value{font-size:1em;padding:7px 6px}}.project-focus-card,.exp-focus-card{max-height:calc(100vh - 64px);padding-top:48px;padding-bottom:38px;overflow-y:auto!important}@media (max-width:700px){.project-focus-card,.exp-focus-card{max-height:calc(100vh - 24px);padding-top:18px;padding-bottom:18px}}.fullscreen-image-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:rgb(0 0 0 / .95);display:flex;justify-content:center;align-items:center;z-index:10000;opacity:0;transition:opacity 0.3s ease;cursor:default}.fullscreen-image-overlay.active{opacity:1}.fullscreen-image-container{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:20px}.fullscreen-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:12px;box-shadow:0 8px 32px rgb(0 0 0 / .5);cursor:default}.fullscreen-image-title{color:#fff;font-size:1.5em;font-weight:700;text-align:center;font-family:'Fira Code',monospace;text-shadow:0 2px 8px rgb(0 0 0 / .8)}.fullscreen-image-close{position:absolute;top:-50px;right:0;background:none;border:none;color:#fff;font-size:2.5em;font-weight:900;cursor:pointer;padding:0;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all 0.2s ease;text-shadow:0 2px 8px rgb(0 0 0 / .8)}.fullscreen-image-close:hover{background-color:rgb(255 255 255 / .1);transform:scale(1.1)}@media (max-width:768px){.fullscreen-image-container{max-width:95vw;max-height:95vh}.fullscreen-image{max-height:75vh}.fullscreen-image-title{font-size:1.2em}.fullscreen-image-close{top:-40px;right:-10px;font-size:2em;width:40px;height:40px}}