#root{width:100%;height:auto;color-scheme:light dark;color:var(--text-color);background-color:var(--background-color)}.dashboard{display:flex;flex-direction:column;padding:1rem;gap:16px}.dashboard .social{display:flex;margin-right:.5em;border:solid .1rem transparent;border-radius:.5rem;font-size:1.5rem;color:var(--social-link-color);border-color:var(--border-color);padding:.5rem;transition:.5s}.dashboard .social:hover{border-color:var(--hover-border-color);color:var(--hover-color)}.projects{margin-top:1rem}.projects .header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:1rem}.projects .header .toggle{color:var(--text-color)}.projects .list{display:flex;flex-direction:column;flex-wrap:wrap;gap:1rem}.projects .grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:1rem}[data-theme=dark]{--background-color: #242424;--text-color: rgba(255, 255, 255, .87);--card-background-color: #1a1a1a;--border-color: #ffffff;--hover-color: #646cff;--hover-border-color: #646cff;--social-link-color: #ffffff}[data-theme=light]{--background-color: #ffffff;--text-color: #213547;--card-background-color: #f9f9f9;--border-color: #213547;--hover-color: #747bff;--hover-border-color: #747bff;--social-link-color: #213547}.navbar{padding:.25rem;display:flex;border-bottom:solid .125rem var(--border-color);justify-content:space-between;align-items:center}.navbar .left-tray{display:flex;flex-direction:row;align-items:center}.navbar .left-tray .title{font-size:2rem;font-weight:400;transition:.5s;padding-right:1rem}.navbar .left-tray .title:hover{color:var(--hover-color)}.navbar .left-tray .portrait{height:3em;border:solid .1rem var(--border-color);border-radius:.5rem;transition:.5s;margin-right:1rem}.navbar .left-tray .portrait:hover{filter:drop-shadow(0 0 2em var(--hover-color));border-color:var(--hover-border-color)}.navbar .left-tray .portrait.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}.theme-switcher{--width: 78px;--height: 40px;--knob-size: 32px;display:inline-block;position:relative;width:var(--width);height:var(--height);vertical-align:middle}.theme-switcher input{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;opacity:0;cursor:pointer;z-index:3}.theme-switcher .track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:calc(var(--height) / 2);background:linear-gradient(90deg,#f0f0f0,#e6e6e6);box-shadow:inset 0 1px #fff9;transition:background .3s ease,box-shadow .3s ease;display:flex;align-items:center;padding:4px}.theme-switcher.light .track{background:linear-gradient(90deg,#fff7c2,#ffe6a3 55%,#ffd27a)}.theme-switcher.dark .track{background:linear-gradient(90deg,#2b3440,#1e2430);box-shadow:inset 0 1px #ffffff05}.theme-switcher .icons{position:absolute;left:8px;right:8px;top:0;bottom:0;display:flex;align-items:center;justify-content:space-between;pointer-events:none}.theme-switcher .icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:#ffffffe6;transition:opacity .22s ease,transform .22s ease,color .22s ease;position:relative}.theme-switcher.light .icon.sun{color:#b35f00;opacity:1;transform:scale(1)}.theme-switcher.light .icon.moon{color:#00000080;opacity:.4;transform:scale(.9)}.theme-switcher.dark .icon.sun{color:#ffd166;opacity:.95;transform:scale(1.05)}.theme-switcher.dark .icon.sun:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at center,#ffd16652,#ffd16614 40%,#ffd16600 70%);z-index:-1;filter:blur(6px);pointer-events:none}.theme-switcher.dark .icon.moon{color:#f6f7ff;opacity:1;transform:scale(1)}.theme-switcher .knob{position:absolute;top:4px;left:4px;width:var(--knob-size);height:var(--knob-size);border-radius:50%;background:linear-gradient(180deg,#fff,#f2f2f2);box-shadow:0 4px 8px #1018281f;transition:transform .3s cubic-bezier(.2,.9,.3,1),background .3s ease,box-shadow .3s ease;z-index:2}.theme-switcher.dark .knob{background:linear-gradient(180deg,#0f1724,#14202b);box-shadow:0 6px 14px #02061780}.theme-switcher input:checked~.track .knob,.theme-switcher.dark .knob{transform:translate(calc(var(--width) - var(--knob-size) - 8px))}.theme-switcher input:focus~.track{box-shadow:0 0 0 3px #4299e11f}.theme-switcher svg{display:block}@media(prefers-reduced-motion:reduce){.theme-switcher .knob,.theme-switcher .icon{transition:none}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--hover-color);text-decoration:inherit}a:hover{color:var(--hover-color)}body{margin:0;display:flex;min-width:320px;min-height:100vh;color:var(--text-color);background-color:var(--background-color)}h1{font-size:3.2em;line-height:1.1}h2{margin-top:0rem;margin-bottom:0rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--card-background-color);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--hover-border-color)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.about-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.social-links{display:flex;gap:1rem;margin-top:1rem}.projects-page{display:flex;flex-direction:column;align-items:center;justify-self:center;justify-content:center;padding:2rem;max-width:800px;min-width:300px;width:100%}.projects-page .header{display:flex;flex-direction:row;gap:30px}.projects-page .projects-container{margin-top:40px;display:flex;align-items:center;justify-self:center;justify-content:center;max-width:800px;min-width:300px;width:100%;flex-wrap:wrap;gap:30px}.projects-page .projects-container .project-card{min-width:300px;min-height:500px;max-height:500px}.projects-page .projects-container .project-inline{min-width:300px;min-height:200px;max-height:300px}.project-card{border:solid .125rem var(--border-color);border-radius:.5rem;padding:0rem .5rem .5rem;max-width:15rem}.project-card .project-media{border-radius:.5rem;transition:.5s;max-height:20rem;max-width:20rem}.project-card .name{font-size:1.5rem;font-weight:400;transition:.5s}.project-card .name:hover{color:var(--hover-color)}.project-card .description{display:flex;flex-direction:column;transition:.5s}.project-card .description:hover{color:var(--hover-color)}.project-inline{display:flex;flex-direction:row;align-items:center;border:solid .125rem var(--border-color);border-radius:.5rem;padding:.5rem;margin-bottom:1rem}.project-inline .project-media{border-radius:.5rem;transition:.5s;max-height:10rem;max-width:10rem;margin-right:1rem}.project-inline .name{font-size:1.5rem;font-weight:400;transition:.5s;margin-bottom:.5rem}.project-inline .name:hover{color:var(--hover-color)}.project-inline .description{display:flex;flex-direction:column;transition:.5s}.project-inline .description:hover{color:var(--hover-color)}.game-of-life-container{--background-color-board: black;--alive-color: white;--alive-hover-color: red;--border-color: rgb(0, 0, 0);--cell-size: 8px;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;margin:0;display:flex;flex-direction:column;place-items:center;min-width:320px;min-height:100vh;color:var(--color);text-align:center;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.game-of-life-container a{font-weight:500;color:#646cff;text-decoration:inherit}.game-of-life-container a:hover{color:#535bf2}.game-of-life-container h1{font-size:3.2em;line-height:1.1}.game-of-life-container button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}.game-of-life-container button:hover{border-color:#646cff}.game-of-life-container button:focus,.game-of-life-container button:focus-visible{outline:4px auto -webkit-focus-ring-color}.game-of-life-container table{margin:0 auto 20px;border-collapse:collapse;background-color:var(--background-color-board)}.game-of-life-container td{width:var(--cell-size);height:var(--cell-size);border:1px solid var(--border-color)}.game-of-life-container .alive{background-color:var(--alive-color)}.game-of-life-container .alive:hover{background-color:var(--alive-hover-color)}.game-of-life-container .dead:hover{background-color:var(--border-color)}.game-of-life-container .flexRow{display:flex;flex-flow:row wrap;justify-content:center;margin:.5rem auto;align-items:center;gap:.5rem}.game-of-life-container .upperControls,.game-of-life-container .middleControls,.game-of-life-container .lowerControls{width:100%;max-width:360px;display:flex;justify-content:center;gap:.5rem;align-items:center;margin:.25rem auto}.game-of-life-container .upperControls{flex-direction:column}.game-of-life-container .upperControls .gol-slider{display:flex;align-content:space-around;align-items:center;flex-direction:row;justify-content:space-around}.game-of-life-container .upperControls .gol-slider .left-sign{margin-top:0;font-weight:400;font-size:32px}.game-of-life-container .upperControls .gol-slider .right-sign{margin-top:-6px;font-weight:900;font-size:32px}@media(prefers-color-scheme:light){.game-of-life-container :root{--color: #213547;--background-color-body: #ffffff;--background-color-board: #f9f9f9;--alive-color: #213547;--border-color: #e0e0e0}.game-of-life-container a:hover{color:#747bff}.game-of-life-container button{background-color:#f9f9f9}}.pm-container{max-width:820px;margin:12px auto;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;color:var(--text-color)}.pm-controls{display:flex;gap:16px;align-items:center;margin-bottom:12px}.pm-diets{border:1px solid var(--border-color, #ddd);padding:8px;border-radius:6px}.pm-checkbox{display:block;margin:4px 0;font-size:14px}.pm-info{min-width:200px}.pm-result{font-weight:700;margin-top:8px}.pm-wheel-wrap{display:flex;justify-content:center}.pm-wheel{position:relative;width:340px;text-align:center}.pm-arrow{position:absolute;left:50%;transform:translate(-50%);top:-12px;font-size:20px;color:#d33;text-shadow:0 1px 0 var(--background-color);pointer-events:none}.pm-svg{display:block;margin:20px auto;touch-action:none;-webkit-user-select:none;user-select:none}.pm-actions{margin-top:8px}.pm-spin-btn{padding:8px 16px;background:linear-gradient(180deg,#ff8c42,#ff6b00);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700}.pm-spin-btn:disabled{opacity:.5;cursor:not-allowed}.compound-calculator{max-width:920px;margin:0 auto;color:var(--text-color, #213547)}.cc-title{margin-top:8px;margin-bottom:8px}.cc-controls{display:grid;gap:8px;grid-template-columns:1fr 1fr;max-width:900px}.cc-field{display:flex;flex-direction:column;gap:6px}.cc-label{font-size:.9rem;color:var(--text-color, #213547)}.cc-input,.cc-select{padding:8px 10px;border-radius:6px;border:1px solid rgba(0,0,0,.08);background:var(--card-background-color, #f9f9f9);color:var(--text-color, #213547)}.cc-input-row{display:flex;flex-direction:column;align-items:flex-start;gap:8px}@media(max-width:768px){.cc-controls{grid-template-columns:1fr}.cc-input-row{flex-direction:column}.compound-calculator{padding-left:12px;padding-right:12px}}.cc-action{display:flex;flex-direction:column;align-items:flex-start;gap:12px}.cc-preview{color:var(--text-color, #213547)}.cc-run-button{padding:8px 14px;border-radius:8px;border:1px solid transparent;background:var(--hover-color, #646cff);color:#fff;cursor:pointer;font-weight:600}.cc-run-button:hover{filter:brightness(.95)}.compound-calculator table{width:100%;border-collapse:collapse;color:var(--text-color, #213547)}.compound-calculator th,.compound-calculator td{padding:6px;border-bottom:1px solid rgba(0,0,0,.04)}[data-theme=dark] .cc-input,[data-theme=dark] .cc-select{background:var(--card-background-color, #1a1a1a);border:1px solid rgba(255,255,255,.06);color:var(--text-color, #fff)}[data-theme=dark] .cc-run-button{background:var(--hover-color, #646cff);color:#fff}[data-theme=light] .cc-input,[data-theme=light] .cc-select{background:var(--card-background-color, #f9f9f9);border:1px solid rgba(0,0,0,.06);color:var(--text-color, #213547)}[data-theme=light] .cc-run-button{background:var(--hover-color, #747bff);color:#fff}.login-container{max-width:420px;margin:48px auto;padding:32px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #10182814;display:flex;flex-direction:column;gap:16px;align-items:stretch;font-family:Inter,Roboto,Segoe UI,system-ui,-apple-system,Helvetica Neue,Arial}.login-container h1{margin:0 0 4px;font-size:1.25rem;font-weight:600;color:#0f172a;text-align:center}.username-input,.password-input{height:44px;padding:10px 12px;border:1px solid #e6e9ef;border-radius:8px;font-size:.95rem;color:#0b1220;background:#fff;transition:box-shadow .16s ease,border-color .16s ease,transform .12s ease;outline:none;box-sizing:border-box}.username-input::placeholder,.password-input::placeholder{color:#98a0b3;opacity:1}.username-input:focus,.password-input:focus{border-color:#4f46e5;box-shadow:0 6px 18px #4f46e514}.username-input[disabled],.password-input[disabled]{background:#f8fafc;color:#94a3b8}.login-button{height:48px;padding:0 16px;border:none;border-radius:10px;background:linear-gradient(180deg,#4f46e5,#3730a3);color:#fff;font-weight:600;font-size:.98rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;box-shadow:0 6px 18px #4f46e529}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #4f46e52e}.login-button:active{transform:translateY(0);opacity:.95}.login-button:disabled{background:#c7c8d9;cursor:not-allowed;box-shadow:none}@media(max-width:520px){.login-container{margin:24px;padding:20px;border-radius:10px}.login-container h1{font-size:1.05rem}}
