:root[data-theme=light]{--bg-primary: #f5f6fa;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #333;--text-secondary: #555;--text-tertiary: #666;--text-muted: #999;--border-color: #e5e7eb;--border-light: #f0f0f0;--card-bg: #ffffff;--card-shadow: rgba(0, 0, 0, .1);--input-bg: #ffffff;--input-border: #ccc;--accent-primary: #007bff;--accent-hover: #0056b3;--accent-success: #28a745;--accent-danger: #dc3545;--code-bg: #1e1e1e;--code-text: #d4d4d4}:root[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--text-primary: #e4e4e4;--text-secondary: #b8b8b8;--text-tertiary: #999;--text-muted: #666;--border-color: #404040;--border-light: #4a4a4a;--card-bg: #2d2d2d;--card-shadow: rgba(0, 0, 0, .5);--input-bg: #3a3a3a;--input-border: #555;--accent-primary: #4a9eff;--accent-hover: #3b7dd9;--accent-success: #51cf66;--accent-danger: #ff6b6b;--code-bg: #1e1e1e;--code-text: #d4d4d4}body,html{margin:0;padding:0;padding-top:var(--navbar-height, 60px);font-family:Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.page-container{width:100%;min-height:calc(100vh - var(--navbar-height, 60px));display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box}.Toastify__toast{font-family:Arial,sans-serif;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 4px 12px #00000026;border:none}.Toastify__toast--success{background-color:#d4edda;border-left:5px solid var(--accent-success)}.Toastify__toast--success .Toastify__toast-body{color:#155724;padding-left:10px}:root[data-theme=dark] .Toastify__toast--success{background-color:#51cf6626}:root[data-theme=dark] .Toastify__toast--success .Toastify__toast-body{color:#81ff99}.Toastify__toast--error{background-color:#f8d7da;border-left:5px solid var(--accent-danger)}.Toastify__toast--error .Toastify__toast-body{color:#721c24;padding-left:10px}:root[data-theme=dark] .Toastify__toast--error{background-color:#ff6b6b26}:root[data-theme=dark] .Toastify__toast--error .Toastify__toast-body{color:#ff9fa3}.Toastify__toast--warning{background-color:#fff3cd;border-left:5px solid #ffc107}.Toastify__toast--warning .Toastify__toast-body{color:#856404;padding-left:10px}:root[data-theme=dark] .Toastify__toast--warning{background-color:#ffc10726}:root[data-theme=dark] .Toastify__toast--warning .Toastify__toast-body{color:#ffd54f}.Toastify__toast--info{background-color:#d1ecf1;border-left:5px solid #17a2b8}.Toastify__toast--info .Toastify__toast-body{color:#0c5460;padding-left:10px}:root[data-theme=dark] .Toastify__toast--info{background-color:#4a9eff26}:root[data-theme=dark] .Toastify__toast--info .Toastify__toast-body{color:#81d4ff}.Toastify__progress-bar{height:4px}.Toastify__progress-bar--success{background:linear-gradient(to right,var(--accent-success),#20c997)}.Toastify__progress-bar--error{background:linear-gradient(to right,var(--accent-danger),#fd7e14)}.Toastify__progress-bar--warning{background:linear-gradient(to right,#ffc107,#ff9800)}.Toastify__progress-bar--info{background:linear-gradient(to right,#17a2b8,#20c997)}.Toastify__close-button{opacity:.7;color:inherit;transition:opacity .2s ease}.Toastify__close-button:hover{opacity:1}.Toastify__toast-container{position:fixed;top:calc(var(--navbar-height, 60px) + 15px)!important}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--navbar-height: 60px;--nav-bg-light: #1f1f1f;--nav-hover-light: #3a3a3a;--nav-active-light: #333333;--nav-bg-dark: #0d0d0d;--nav-hover-dark: #2a2a2a;--nav-active-dark: #1a1a1a;--nav-accent: #007bff;--nav-accent-dark: #4a9eff;--nav-border: rgba(255, 255, 255, .1)}.navbar{position:fixed;top:0;left:0;width:100%;height:var(--navbar-height);background-color:var(--nav-bg-light);box-shadow:0 2px 8px #00000040;z-index:1000;transition:background-color .3s ease}:root[data-theme=dark] .navbar{background-color:var(--nav-bg-dark);box-shadow:0 2px 8px #00000080}.nav-container{display:flex;justify-content:space-between;height:100%;width:100%}.left,.right{display:flex;height:100%}.nav-tile{display:flex;align-items:center;justify-content:center;padding:0 20px;color:#e4e4e4;text-decoration:none;font-size:16px;font-weight:500;height:100%;border-right:1px solid var(--nav-border);transition:all .2s ease;cursor:pointer;background:transparent}.left .nav-tile:first-child{border-left:1px solid var(--nav-border)}.nav-tile:hover{background-color:var(--nav-hover-light);color:#fff}:root[data-theme=dark] .nav-tile:hover{background-color:var(--nav-hover-dark)}.nav-tile.active{background-color:var(--nav-active-light);color:#fff;box-shadow:inset 0 -3px 0 var(--nav-accent)}:root[data-theme=dark] .nav-tile.active{background-color:var(--nav-active-dark);box-shadow:inset 0 -3px 0 var(--nav-accent-dark)}.theme-btn{background:transparent;color:#fff;border:none;border-left:1px solid var(--nav-border);padding:0 15px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;gap:5px;height:100%;font-family:inherit}.theme-btn:hover{background-color:var(--nav-hover-light)}:root[data-theme=dark] .theme-btn:hover{background-color:var(--nav-hover-dark)}.logout-btn{background-color:#e63946!important;border:none;font-weight:600}.logout-btn:hover{background-color:#c6282e!important}@media(max-width:600px){.nav-tile{padding:0 12px;font-size:14px}.theme-btn{padding:0 12px;font-size:13px}}.form-box{background-color:var(--card-bg);padding:40px 30px;border-radius:12px;box-shadow:0 4px 15px var(--card-shadow);width:350px;display:flex;flex-direction:column;transition:all .3s ease}.form-box h2{text-align:center;margin-bottom:25px;color:var(--text-primary);transition:color .3s ease}.form-box input{margin-bottom:8px;padding:12px;font-size:16px;border:1px solid var(--input-border);border-radius:6px;width:100%;box-sizing:border-box;background-color:var(--input-bg);color:var(--text-primary);transition:all .3s ease}.form-box input::placeholder{color:var(--text-tertiary)}.form-box input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #007bff1a}:root[data-theme=dark] .form-box input:focus{box-shadow:0 0 0 2px #4a9eff33}.valid{border-color:var(--accent-success);background-color:var(--input-bg)}.invalid{border-color:var(--accent-danger);background-color:var(--input-bg)}.form-box button{margin-top:15px;padding:12px;font-size:16px;background-color:var(--accent-primary);border:none;color:#fff;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease}.form-box button:hover{background-color:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}:root[data-theme=dark] .form-box button:hover{box-shadow:0 4px 12px #4a9eff4d}.form-box button:active{transform:translateY(0)}.error{color:var(--accent-danger);font-size:13px;margin-bottom:10px;font-weight:500;transition:color .3s ease}.password-wrapper{position:relative}.toggle-password{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--accent-primary);font-weight:700;padding:0 8px;font-size:13px;transition:all .2s ease}.toggle-password:hover{color:var(--accent-hover)}.password-strength{font-size:13px;margin-bottom:10px;font-weight:700;transition:color .3s ease}.password-strength.weak{color:var(--accent-danger)}.password-strength.medium{color:orange}.password-strength.strong{color:var(--accent-success)}@media(max-width:400px){.form-box{width:90%;padding:30px 20px}.form-box h2{font-size:1.75rem;margin-bottom:20px}.form-box input{font-size:15px;padding:10px}.toggle-password{font-size:12px}}.opm-upload-container{background:var(--card-bg);border-radius:12px;box-shadow:0 10px 40px var(--card-shadow);max-width:900px;width:100%;padding:50px 40px;margin-top:20px;transition:all .3s ease}.page-title{text-align:center;font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 50px;letter-spacing:-.5px;transition:color .3s ease}.welcome-section{margin-bottom:40px;text-align:center}.welcome-message{font-size:16px;color:var(--text-secondary);margin:0;font-weight:500;transition:color .3s ease}.user-name{color:var(--accent-success);font-weight:700}.upload-form{display:flex;flex-direction:column;gap:40px}.upload-section{display:flex;flex-direction:column;gap:16px}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.5px;transition:color .3s ease}.drag-drop-area{border:2px dashed var(--border-color);border-radius:8px;padding:60px 30px;text-align:center;transition:all .3s ease;cursor:pointer;background:var(--bg-tertiary);min-height:250px;display:flex;flex-direction:column;justify-content:center;align-items:center}.drag-drop-area:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.drag-drop-area.active{border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 0 4px #007bff1a}:root[data-theme=dark] .drag-drop-area.active{box-shadow:0 0 0 4px #4a9eff26}.drag-drop-area.has-file{border-color:var(--accent-primary);background:var(--bg-secondary);padding:30px;min-height:auto}.upload-icon{margin-bottom:20px;display:flex;justify-content:center}.upload-icon svg{animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.drag-text{font-size:18px;color:var(--text-secondary);margin:0 0 8px;font-weight:500;transition:color .3s ease}.or-text{font-size:14px;color:var(--text-tertiary);margin:0 0 16px;transition:color .3s ease}.browse-button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-weight:600;text-decoration:underline;font-size:14px;padding:0;transition:color .2s ease;font-family:inherit}.browse-button:hover{color:var(--accent-hover)}.file-status{font-size:13px;color:var(--text-tertiary);margin:0;font-style:italic;transition:color .3s ease}.file-info{display:flex;justify-content:space-between;align-items:center;gap:20px;background:var(--bg-tertiary);padding:20px;border-radius:8px;transition:all .3s ease}.file-details{display:flex;align-items:center;gap:16px;flex:1}.file-icon{flex-shrink:0;width:48px;height:48px;background:var(--card-bg);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .3s ease}.file-text{display:flex;flex-direction:column;gap:4px}.file-name{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;word-break:break-word;transition:color .3s ease}.file-size{font-size:12px;color:var(--text-tertiary);margin:0;transition:color .3s ease}.remove-button{background-color:var(--accent-danger);color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;padding:0}.remove-button:hover{background-color:#c53030;transform:scale(1.1)}.error-message{font-size:13px;color:var(--accent-danger);margin-top:8px;display:block;transition:color .3s ease}.error-alert{background:var(--bg-tertiary);border-left:4px solid var(--accent-danger);padding:16px 20px;border-radius:4px;color:var(--accent-danger);font-size:14px;margin-top:10px;transition:all .3s ease}.error-alert-title{font-weight:600;margin:0 0 8px;color:var(--accent-danger)}.error-alert-message{margin:0;line-height:1.5;color:var(--accent-danger)}.language-section{display:flex;flex-direction:column;gap:16px}.language-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.language-radio{display:flex;align-items:center;gap:10px;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .3s ease;background:var(--card-bg)}.language-radio:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.language-radio input[type=radio]{cursor:pointer;width:18px;height:18px;margin:0;accent-color:var(--accent-primary);flex-shrink:0}.language-radio input[type=radio]:checked+.radio-label{font-weight:600;color:var(--accent-primary)}.radio-label{font-size:14px;color:var(--text-primary);-webkit-user-select:none;user-select:none;transition:color .2s ease}.language-radio:has(input[type=radio]:checked){border-color:var(--accent-primary);background:var(--bg-tertiary);box-shadow:0 0 0 3px #007bff1a}:root[data-theme=dark] .language-radio:has(input[type=radio]:checked){box-shadow:0 0 0 3px #4a9eff1a}.generate-button{padding:14px 24px;font-size:16px;font-weight:600;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #007bff4d;margin-top:10px;font-family:inherit}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #007bff66}:root[data-theme=dark] .generate-button:hover:not(:disabled){box-shadow:0 6px 16px #4a9eff66}.generate-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #007bff4d}.generate-button:disabled{background:linear-gradient(135deg,var(--border-color) 0%,var(--border-light) 100%);cursor:not-allowed;box-shadow:0 4px 12px #0000001a;opacity:.7}.requirements-section{background:var(--bg-tertiary);padding:24px;border-radius:8px;border-left:4px solid var(--accent-primary);margin-top:40px;transition:all .3s ease}.requirements-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px;transition:color .3s ease}.requirements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.requirements-list li{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;transition:color .3s ease}.requirements-list li:before{content:"•";color:var(--accent-primary);font-weight:700;font-size:16px;line-height:1}@media(max-width:768px){.opm-upload-container{padding:30px 20px}.page-title{font-size:24px;margin-bottom:30px}.drag-drop-area{padding:40px 20px;min-height:200px}.upload-icon svg{width:48px;height:48px}.drag-text{font-size:16px}.language-options{grid-template-columns:repeat(2,1fr)}.file-info{flex-direction:column;text-align:center}.file-details{width:100%;justify-content:center}.remove-button{position:absolute;top:10px;right:10px}}@media(max-width:480px){.page-container{padding:20px 10px!important}.opm-upload-container{padding:20px 15px}.page-title{font-size:20px;margin-bottom:25px}.section-title{font-size:16px}.drag-drop-area{padding:30px 15px;min-height:180px}.drag-text{font-size:14px}.language-options{grid-template-columns:1fr}.language-radio{padding:10px 12px}.requirements-section{padding:16px}.requirements-title,.requirements-list li{font-size:12px}}.drag-drop-area:focus-within{outline:2px solid var(--accent-primary);outline-offset:2px}.generate-button:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.loading-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-in-out}.loading-modal-content{background:var(--card-bg);border-radius:16px;padding:48px 40px;max-width:500px;width:90%;box-shadow:0 20px 60px var(--card-shadow);text-align:center;animation:slideUp .4s ease-out;transition:all .3s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.spinner-container{display:flex;justify-content:center;margin-bottom:24px}.spinner{width:60px;height:60px;border:4px solid var(--bg-tertiary);border-top:4px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;transition:border-color .3s ease}.loading-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 12px;letter-spacing:-.5px;transition:color .3s ease}.loading-message{font-size:16px;color:var(--text-secondary);margin:0 0 24px;min-height:24px;animation:fadeInOut 2s ease-in-out infinite;transition:color .3s ease}@keyframes fadeInOut{0%,to{opacity:1}50%{opacity:.7}}.time-estimate{background:var(--bg-tertiary);border-left:4px solid var(--accent-primary);padding:16px 20px;border-radius:8px;margin-bottom:24px;transition:all .3s ease}.estimate-text{font-size:15px;color:var(--text-primary);margin:0 0 6px;font-weight:500;transition:color .3s ease}.estimate-highlight{color:var(--accent-danger);font-weight:700;font-size:16px}.estimate-subtext{font-size:13px;color:var(--text-tertiary);margin:0;font-style:italic;transition:color .3s ease}.loading-progress{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;transition:background .3s ease}.progress-bar-animated{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-hover),var(--accent-primary));background-size:200% 100%;border-radius:3px;animation:progressAnimation 2s ease-in-out infinite}@keyframes progressAnimation{0%{width:0%;background-position:0% 0%}50%{width:90%;background-position:100% 0%}to{width:100%;background-position:200% 0%}}@media(max-width:768px){.loading-modal-content{padding:40px 24px;max-width:90%}.loading-title{font-size:20px}.loading-message,.estimate-text{font-size:14px}.spinner{width:50px;height:50px;border-width:3px}}@media(max-width:480px){.loading-modal-content{padding:32px 20px;width:95%}.loading-title{font-size:18px;margin-bottom:10px}.loading-message{font-size:13px;margin-bottom:20px}.time-estimate{padding:12px 16px;margin-bottom:20px}.estimate-text{font-size:13px;margin-bottom:4px}.estimate-subtext{font-size:11px}.spinner-container{margin-bottom:20px}.spinner{width:45px;height:45px;border-width:3px}}.page-container{padding:40px 20px!important;align-items:flex-start;background:var(--bg-primary);transition:background .3s ease}:root[data-theme=light] .page-container{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%)}:root[data-theme=dark] .page-container{background:var(--bg-primary)}.success-container{background:var(--card-bg);border-radius:12px;box-shadow:0 10px 40px var(--card-shadow);max-width:1000px;width:100%;padding:50px 40px;margin-top:20px;transition:all .3s ease}.success-content{display:flex;flex-direction:column;gap:40px}.explanation-section{background:var(--bg-tertiary);border:2px solid var(--accent-primary);border-radius:12px;padding:24px;transition:all .3s ease}.explanation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.explanation-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;transition:color .3s ease}.explanation-badge{display:inline-block;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease}.explanation-text{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0;white-space:pre-wrap;word-wrap:break-word;transition:color .3s ease}.code-section{display:flex;flex-direction:column;gap:16px}.code-header{display:flex;justify-content:space-between;align-items:center}.code-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;transition:color .3s ease}.code-language{background:var(--bg-tertiary);color:var(--accent-primary);padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease}.code-display{background:var(--code-bg);border-radius:8px;padding:20px;overflow-x:auto;max-height:400px;overflow-y:auto;transition:background .3s ease;border:1px solid var(--border-color)}.code-display pre{margin:0;font-family:Fira Code,Courier New,monospace;font-size:13px;line-height:1.6;color:var(--code-text);transition:color .3s ease}.code-display code{color:var(--code-text)}.code-actions{display:flex;gap:12px;flex-wrap:wrap}.copy-button,.download-button{padding:8px 16px;border:2px solid var(--accent-primary);border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;background:var(--bg-tertiary);color:var(--accent-primary);transition:all .2s ease}.copy-button.feedback{background:var(--accent-success);color:#fff;border-color:var(--accent-success)}.copy-button:hover,.download-button:hover{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px #007bff4d}:root[data-theme=dark] .copy-button:hover,:root[data-theme=dark] .download-button:hover{box-shadow:0 4px 12px #4a9eff4d}.copy-button.feedback:hover{background:var(--accent-success);box-shadow:0 4px 12px #28a7454d}.copy-button:active,.download-button:active{transform:scale(.95)}.success-actions-wrapper{display:flex;flex-direction:column;gap:20px}.success-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;animation:fadeIn .3s ease}.inline-fix-instructions{background:var(--bg-tertiary);border:2px solid #ffc107;border-radius:12px;padding:30px;animation:slideDown .3s ease;display:flex;flex-direction:column;gap:20px;transition:all .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.inline-fix-header{margin-bottom:10px}.inline-fix-header h3{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px;transition:color .3s ease}.inline-fix-header p{font-size:14px;color:var(--text-secondary);margin:0;transition:color .3s ease}.fix-instructions-textarea{width:100%;padding:12px 16px;border:2px solid #ffc107;border-radius:8px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:14px;color:var(--text-primary);background-color:var(--input-bg);resize:vertical;transition:all .2s ease;box-sizing:border-box}.fix-instructions-textarea:focus{outline:none;border-color:#ff9800;box-shadow:0 0 0 3px #ff98001a}.fix-instructions-textarea::placeholder{color:var(--text-tertiary)}.refinement-error-alert{background:var(--bg-tertiary);border-left:4px solid var(--accent-danger);padding:16px 20px;border-radius:4px;color:var(--accent-danger);margin:0;transition:all .3s ease}.refinement-error-alert .error-alert-title{font-weight:600;margin:0 0 8px;color:var(--accent-danger)}.refinement-error-alert .error-alert-message{margin:0;line-height:1.5;color:var(--accent-danger)}.inline-fix-actions{display:flex;gap:12px;flex-wrap:wrap}.send-button{background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff;border:none;transition:all .3s ease}.send-button:hover:not(:disabled){background:linear-gradient(135deg,#ffb300,#f57c00);box-shadow:0 4px 12px #ff98004d}.send-button:active:not(:disabled){transform:scale(.95)}.send-button:disabled{background:var(--border-color);color:var(--text-tertiary);cursor:not-allowed;opacity:.6}.cancel-button{background:var(--border-color);color:var(--text-secondary);border:none;transition:all .3s ease}.cancel-button:hover:not(:disabled){background:var(--border-light);box-shadow:0 4px 12px #a0aec04d}.cancel-button:active:not(:disabled){transform:scale(.95)}.cancel-button:disabled{cursor:not-allowed;opacity:.6}.upload-button-below{width:100%;justify-content:center}.action-button{padding:12px 24px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;font-family:inherit;display:flex;align-items:center;gap:8px}.primary-button{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;box-shadow:0 4px 12px #007bff4d}:root[data-theme=dark] .primary-button{box-shadow:0 4px 12px #4a9eff4d}.primary-button:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover) 0%,#0d47a1 100%);box-shadow:0 6px 16px #007bff66;transform:translateY(-2px)}:root[data-theme=dark] .primary-button:hover:not(:disabled){box-shadow:0 6px 16px #4a9eff66}.primary-button:active:not(:disabled){transform:translateY(0)}.primary-button:disabled{background:var(--border-color);color:var(--text-tertiary);cursor:not-allowed;box-shadow:none}.secondary-button{background:var(--bg-tertiary);color:var(--accent-primary);border:2px solid var(--accent-primary)}.secondary-button:hover:not(:disabled){background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}:root[data-theme=dark] .secondary-button:hover:not(:disabled){box-shadow:0 4px 12px #4a9eff4d}.secondary-button:active:not(:disabled){transform:translateY(0)}.secondary-button:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);border-color:var(--border-color);cursor:not-allowed}.error-container{background:var(--card-bg);border-radius:12px;box-shadow:0 10px 40px var(--card-shadow);max-width:600px;width:100%;padding:50px 40px;text-align:center;margin-top:20px;transition:all .3s ease}.error-container h2{font-size:24px;font-weight:700;color:var(--accent-danger);margin:0 0 16px;transition:color .3s ease}.error-container p{font-size:16px;color:var(--text-secondary);margin:0 0 32px;transition:color .3s ease}@media(max-width:768px){.success-container{padding:30px 20px}.inline-fix-instructions{padding:20px;gap:16px}.explanation-header{flex-direction:column;align-items:flex-start;gap:12px}.code-display{max-height:300px}.code-display pre{font-size:12px}.code-actions{flex-direction:column}.copy-button,.download-button{width:100%;justify-content:center}.success-actions{flex-direction:column}.action-button{width:100%;justify-content:center}.inline-fix-actions{flex-direction:column}.send-button,.cancel-button{width:100%;justify-content:center}}@media(max-width:480px){.page-container{padding:20px 10px!important}.success-container{padding:20px 15px}.inline-fix-instructions{padding:15px;gap:15px}.inline-fix-header h3,.code-header h2{font-size:16px}.code-display{padding:15px;max-height:250px}.code-display pre{font-size:11px}.action-button{padding:10px 16px;font-size:12px}.copy-button,.download-button{padding:8px 12px;font-size:12px}.explanation-text{font-size:13px}.send-button,.cancel-button{padding:10px 16px;font-size:12px}}.action-button:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.copy-button:focus,.download-button:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.send-button:focus,.cancel-button:focus{outline:2px solid #ff9800;outline-offset:2px}.fix-instructions-textarea:focus{outline:none}.about-page{min-height:100vh;padding:3rem 1rem;background-color:var(--bg-primary);transition:background-color .3s ease}.about-container{max-width:1400px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:2rem;color:var(--text-primary);text-transform:none;transition:color .3s ease}.overview-section{margin-bottom:5rem}.overview-text{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);text-align:justify;max-width:1200px;margin:0 auto;background:var(--card-bg);padding:2.5rem;border-radius:16px;box-shadow:0 2px 8px var(--card-shadow);transition:all .3s ease}.team-section{margin-bottom:3rem}.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem}.person-card{padding:2rem;background:var(--card-bg);border-radius:16px;box-shadow:0 2px 8px var(--card-shadow);transition:all .3s ease;text-align:center;display:flex;flex-direction:column;align-items:center}.person-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px var(--card-shadow)}.supervisor-card{position:relative}.supervisor-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary) 0%,var(--accent-success) 100%);border-radius:16px 16px 0 0}.person-image-container{margin-bottom:1.5rem}.person-image{height:150px;max-width:120px;border-radius:12px;overflow:hidden;border:3px solid var(--border-color);display:inline-flex;align-items:center;justify-content:center;background:var(--card-bg);transition:border-color .3s ease}.person-image img{height:100%;width:auto;max-width:100%;display:block}.person-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;transition:color .3s ease}.person-role{font-size:1rem;font-weight:600;color:var(--accent-primary);margin:0 0 .75rem;transition:color .3s ease}.supervisor-role{font-size:1.1rem;color:var(--accent-primary);font-weight:700}.person-email{font-size:.95rem;color:var(--text-tertiary);margin-bottom:1rem;font-weight:500;transition:color .3s ease}.person-description{font-size:.95rem;line-height:1.6;color:var(--text-secondary);text-align:center;transition:color .3s ease}@media(max-width:1200px){.team-grid{grid-template-columns:1fr;gap:2.5rem}.supervisor-card{order:-1}.overview-text{text-align:left}}@media(max-width:768px){.about-page{padding:2rem 1rem}.section-title{font-size:2rem}.overview-text{font-size:1rem;padding:1.5rem;text-align:left}.person-card{padding:1.5rem}.person-name{font-size:1.25rem}.person-image{height:120px;max-width:100px}}@media(max-width:480px){.about-page{padding:1.5rem .5rem}.section-title{font-size:1.75rem}.overview-section{margin-bottom:3rem}.overview-text{font-size:.95rem;padding:1.25rem}.person-card{padding:1.25rem}.person-name{font-size:1.15rem}.person-role{font-size:.9rem}.person-email{font-size:.85rem}.person-description{font-size:.9rem}.person-image{height:100px;max-width:90px}}.projects-layout{padding:40px 20px;align-items:flex-start;min-height:auto;background:var(--bg-primary);transition:background .3s ease}.projects-container{max-width:1400px;width:100%}.projects-page-title{text-align:center;font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 40px;letter-spacing:-.5px;transition:color .3s ease}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid var(--bg-tertiary);border-top:4px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;transition:border-color .3s ease}.loading-container p{font-size:16px;color:var(--text-secondary);font-weight:500;transition:color .3s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:80px 20px;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 15px var(--card-shadow);transition:all .3s ease}.empty-icon{font-size:80px;margin-bottom:20px;opacity:.8}.empty-state h2{font-size:28px;color:var(--text-primary);margin:0 0 10px;font-weight:700;transition:color .3s ease}.empty-state p{font-size:16px;color:var(--text-secondary);margin:0 0 30px;line-height:1.5;transition:color .3s ease}.cta-button{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;padding:14px 30px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #007bff4d;font-family:inherit}:root[data-theme=dark] .cta-button{box-shadow:0 4px 12px #4a9eff4d}.cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #007bff66;background:linear-gradient(135deg,var(--accent-hover) 0%,#0d47a1 100%)}:root[data-theme=dark] .cta-button:hover{box-shadow:0 6px 16px #4a9eff66}.cta-button:active{transform:translateY(0)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px}.project-card{background:var(--card-bg);border-radius:12px;box-shadow:0 4px 15px var(--card-shadow);transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #007bff26}.project-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 15px;border-bottom:2px solid var(--border-color);background:var(--bg-tertiary);transition:all .3s ease}.project-language{display:flex;align-items:center;gap:8px}.language-icon{font-size:24px;line-height:1}.language-name{font-size:14px;font-weight:600;color:var(--accent-primary);letter-spacing:.5px;transition:color .3s ease}.delete-icon-btn{background:none;border:none;font-size:20px;cursor:pointer;opacity:.6;transition:all .2s ease;padding:4px;border-radius:4px}.delete-icon-btn:hover{opacity:1;transform:scale(1.2);background:#dc35451a}.project-body{padding:20px;flex:1}.project-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px;word-break:break-word;line-height:1.3;transition:color .3s ease}.project-date{font-size:13px;color:var(--text-tertiary);margin:0 0 15px;display:flex;align-items:center;gap:5px;transition:color .3s ease}.project-date:before{content:"📅";font-size:14px}.project-info{display:flex;flex-direction:column;gap:8px}.info-item{display:flex;justify-content:space-between;align-items:center;font-size:14px;gap:10px}.info-label{color:var(--text-secondary);font-weight:500;flex-shrink:0;transition:color .3s ease}.info-value{color:var(--text-primary);font-weight:600;font-family:Courier New,monospace;font-size:13px;text-align:right;word-break:break-all;transition:color .3s ease}.project-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;border-top:1px solid var(--border-color)}.action-btn{padding:12px;border:none;background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border-right:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;gap:5px;font-family:inherit}.action-btn:last-child{border-right:none}.action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.view-btn:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.download-btn:hover{background:var(--bg-tertiary);color:var(--accent-success)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card-bg);border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px var(--card-shadow);animation:slideUp .3s ease;transition:all .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:25px 30px;border-bottom:2px solid var(--border-color);position:sticky;top:0;background:var(--card-bg);z-index:10;transition:all .3s ease}.modal-header h2{font-size:24px;color:var(--text-primary);margin:0;font-weight:700;word-break:break-word;padding-right:20px;transition:color .3s ease}.modal-close{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-family:inherit}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:30px}.modal-section{margin-bottom:30px}.modal-section:last-child{margin-bottom:0}.modal-section h3{font-size:18px;color:var(--text-primary);margin:0 0 15px;font-weight:600;display:flex;align-items:center;gap:8px;transition:color .3s ease}.modal-section h3:before{content:"📝";font-size:20px}.modal-section:nth-child(2) h3:before{content:"💻"}.explanation-text{font-size:15px;line-height:1.7;color:var(--text-secondary);margin:0;padding:15px;background:var(--bg-tertiary);border-radius:8px;border-left:4px solid var(--accent-primary);transition:all .3s ease}.code-preview{background:var(--code-bg);color:var(--code-text);padding:20px;border-radius:8px;overflow-x:auto;margin:0;max-height:400px;overflow-y:auto;box-shadow:inset 0 2px 8px #0000004d;transition:all .3s ease}.code-preview code{font-family:Courier New,Courier,monospace;font-size:13px;line-height:1.6;white-space:pre;color:var(--code-text)}.code-preview::-webkit-scrollbar{width:10px;height:10px}.code-preview::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.code-preview::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.code-preview::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.modal-actions{display:flex;gap:10px;padding:25px 30px;border-top:2px solid var(--border-color);background:var(--bg-tertiary);position:sticky;bottom:0;transition:all .3s ease}.modal-btn{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:6px;font-family:inherit}.download-pdf-btn{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #007bff4d}:root[data-theme=dark] .download-pdf-btn{box-shadow:0 2px 8px #4a9eff4d}.download-pdf-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #007bff66}:root[data-theme=dark] .download-pdf-btn:hover{box-shadow:0 4px 12px #4a9eff66}.download-code-btn{background:var(--accent-success);color:#fff;box-shadow:0 2px 8px #28a7454d}.download-code-btn:hover{background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.delete-btn{background:var(--accent-danger);color:#fff;box-shadow:0 2px 8px #dc35454d}.delete-btn:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.modal-btn:active{transform:translateY(0)}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}}@media(max-width:768px){.projects-layout{padding:30px 15px}.projects-page-title{font-size:28px;margin-bottom:30px}.projects-grid{grid-template-columns:1fr;gap:20px}.empty-state{padding:60px 20px}.empty-icon{font-size:60px}.empty-state h2{font-size:24px}.empty-state p{font-size:15px}.modal-content{max-height:95vh;margin:10px}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-body{padding:20px}.modal-section h3{font-size:16px}.explanation-text{font-size:14px;padding:12px}.code-preview{padding:15px;font-size:12px}.modal-actions{flex-direction:column;padding:20px;gap:10px}.modal-btn{width:100%}}@media(max-width:480px){.projects-layout{padding:20px 10px}.projects-page-title{font-size:24px;margin-bottom:25px}.project-card{box-shadow:0 2px 10px var(--card-shadow)}.project-header,.project-body{padding:15px}.project-title{font-size:16px}.project-actions{grid-template-columns:1fr}.action-btn{border-right:none;border-bottom:1px solid var(--border-color);padding:14px}.action-btn:last-child{border-bottom:none}.modal-overlay{padding:10px}.modal-header{padding:15px}.modal-header h2{font-size:18px}.modal-close{width:36px;height:36px;font-size:24px}.modal-body{padding:15px}.modal-section{margin-bottom:20px}.modal-section h3{font-size:15px}.code-preview{max-height:300px;padding:12px}.code-preview code{font-size:11px}.modal-actions{padding:15px}.modal-btn{padding:12px 16px;font-size:13px}.empty-state{padding:40px 15px}.empty-icon{font-size:50px}.empty-state h2{font-size:20px}.cta-button{padding:12px 24px;font-size:15px}}@media(max-width:360px){.projects-page-title{font-size:20px}.project-title{font-size:15px}.language-name{font-size:12px}.info-item{font-size:13px}.action-btn{font-size:12px}}
