:root{--primary: #667eea;--primary-dark: #764ba2;--bg-dark: #0d1117;--bg-card: #151b23;--border: rgba(255, 255, 255, .1);--text-primary: #f0f6fc;--text-secondary: #a0a0a0;--font-size: .875rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji" }*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background:var(--bg-dark);color:var(--text-primary);line-height:1.5}.app{min-height:100vh}.app-container{display:flex;min-height:100vh;margin:0 4rem;padding:0 .5rem}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);width:48px;height:48px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;transition:all .3s}.mobile-menu-btn:hover{background:#667eea1a;border-color:var(--primary)}.mobile-overlay{display:none;position:fixed;inset:0;background:#000000b3;z-index:999}.sidebar{width:18rem;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-header{display:flex;flex-direction:column;padding:2rem;border-bottom:1px solid var(--border)}.sidebar-header img{width:10rem;margin:0 auto;margin-bottom:1.5rem}.sidebar-nav{flex:1;padding:1.5rem 0}.nav-link{display:flex;align-items:center;gap:1rem;padding:.875rem 2rem;color:var(--text-secondary);text-decoration:none;transition:all .3s;border-left:3px solid transparent;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left;cursor:pointer;font-size:1rem;font-family:inherit}.nav-link:hover{color:var(--text-primary);background:#ffffff0d}.nav-link.active{color:var(--primary);background:#667eea1a;border-left-color:var(--primary)}.sidebar-footer{padding:1.5rem 2rem;border-top:1px solid var(--border)}.main{flex:1;padding:2rem;min-height:100vh}.page-content{width:100%;margin:0 auto 1.5rem}.page-title{font-size:3rem;font-weight:800;margin-bottom:2rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-section{display:flex;flex-direction:column}.home-header{display:flex;justify-content:flex-end;gap:2rem;margin-bottom:2rem}.home-header img{width:25rem}.about-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem}.about-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.about-card{flex:1;padding:1.5rem;border:1px solid #e5e7eb;border-radius:.125rem;box-shadow:0 1px 2px #0000001a}.about-card h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.about-card ul{list-style:none;padding:0;margin:0}.about-card li{margin-bottom:1rem}.about-card h3{font-size:1.25rem;font-weight:500;margin-bottom:.25rem}.about-meta{font-size:1.125rem;color:var(--text-secondary)}.about-text{font-size:.875rem;margin-top:.25rem;color:#ccc;line-height:1.5}@media(max-width:1400px){.app-container{margin:0 3rem}.sidebar{min-width:16rem}}@media(max-width:1200px){.app-container{margin:0 2.5rem}.sidebar{min-width:13rem}}@media(max-width:992px){.app-container{margin:0 2rem}.sidebar{min-width:12rem}}@media(max-width:768px){.app-container{flex-direction:column;margin:0 1rem;padding:0}.mobile-menu-btn{display:flex}.mobile-overlay{display:block}.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%);transition:transform .3s ease;z-index:1000}.sidebar.mobile-open{transform:translate(0)}.main{margin-left:0;padding:5rem 1rem 2rem;width:100%}.page-title{font-size:2rem}.about-cols{flex-direction:column}}@media(max-width:576px){.app-container{margin:0 .5rem}.main{padding:5rem .5rem 1.5rem}.page-title{font-size:1.75rem}}@media(max-width:425px){.app-container{margin:0}.main{padding:5rem .75rem 1rem}.page-title{font-size:1.5rem}}.my-btn{display:inline-block;font-weight:400;text-align:center;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;user-select:none;border:1px solid transparent;padding:.375rem .75rem;font-size:1rem;line-height:1.5rem;border-radius:.25rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.my-btn-primary{color:#fff;background-color:var(--primary);border-color:var(--primary)}.my-btn:hover{color:var(--white-font);background-color:#0069d9;border-color:#0062cc}.my-btn:focus .my-btn:hover{outline:0;text-decoration:none}.my-btn:not(:disabled):not(.disabled){cursor:pointer}.projects-title{font-size:2rem;font-weight:700;margin-bottom:2rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.project-card{display:flex;flex-direction:column;padding:1.5rem;border:1px solid #e5e7eb;border-radius:12px;background:#fff;box-shadow:0 1px 2px #0000000d;transition:transform .15s ease,box-shadow .15s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.project-card h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:var(--bg-card)}.project-description{flex-grow:1;color:#374151;margin-bottom:1rem;line-height:1.5}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;padding:0;margin:0 0 1rem}.project-tech li{font-size:.75rem;padding:.25rem .5rem;background:var(--bg-dark);border-radius:999px}.project-button-row{display:flex;justify-content:space-between}.project-button{align-self:flex-start;padding:.5rem 1rem;border-radius:8px;border:none;background:var(--bg-dark);color:var(--text-primary);font-size:.875rem;cursor:pointer}.project-button:hover{background:#020617}.github-button{align-self:flex-start;padding:.5rem 1rem;border-radius:8px;border:none;background-color:var(--bg-dark);color:var(--text-primary);font-size:.875rem;cursor:pointer}.weather-search{margin-bottom:2rem}.search-container{display:flex;gap:1rem;max-width:500px}.zipcode-input{flex:1;padding:.875rem 1.25rem;border-radius:12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:1rem;transition:all .3s;font-family:inherit}.zipcode-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.zipcode-input::placeholder{color:var(--text-secondary);opacity:.6}.search-button{padding:.875rem 2rem;border-radius:12px;border:none;background-color:var(--primary);color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit;white-space:nowrap}.search-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.search-button:active{transform:translateY(0)}.error-message{color:#ff6b6b;margin-top:.75rem;font-size:.95rem;padding:.75rem 1rem;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:8px;max-width:500px}.no-data-message{display:flex;align-items:center;justify-content:center;min-height:300px;font-size:1.125rem;color:var(--text-secondary);text-align:center}.weather-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.25rem;color:var(--text-secondary)}.weather.row{display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto}.weather-current{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid var(--border);border-radius:20px;padding:3rem;display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center;position:relative;overflow:hidden}.weather-current:before{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(102,126,234,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}.weather-current-loc{text-align:left}.curr-location-name{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.weather-current-loc p:last-child{font-size:1.125rem;color:var(--text-secondary)}.weather-current-temp{display:flex;align-items:center;justify-content:center;gap:1rem;position:relative;z-index:1}.weather-current-temp img{width:80px;height:80px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.curr-location-tempf{font-size:4rem;font-weight:900;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.curr-location-tempUnit{font-size:2rem;color:var(--text-secondary);align-self:flex-start;margin-top:.5rem}.weather-current-feel{text-align:right}.curr-feel{font-size:1.125rem;color:var(--text-secondary);padding:.75rem 1.25rem;background:#ffffff0d;border-radius:12px;display:inline-block}.weather-forecast{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.weather-forecast>div{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.weather-forecast>div:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:0 10px 30px #667eea33}.weather-forecast-date{font-size:1.125rem;font-weight:600;color:var(--text-primary);text-align:center;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.weather-forecast-temp{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-secondary)}.weather-forecast-temp img{width:64px;height:64px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.weather-forecast-precip{color:var(--primary);font-weight:600;font-size:1.125rem}.weather-forecast-feel{display:flex;justify-content:space-around;gap:1rem;margin-top:auto}.weather-forecast-hi-tempf,.weather-forecast-lo-tempf{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;padding:.5rem 1rem;border-radius:8px;background:#ffffff08}.weather-forecast-hi-tempf{color:#ff6b6b}.weather-forecast-lo-tempf{color:#4ecdc4}.weather-forecast-hi-tempf svg,.weather-forecast-lo-tempf svg{font-size:1rem}.weather-forecase-temp-unit{font-size:.875rem;color:var(--text-secondary);margin-left:.25rem}@media(max-width:1024px){.weather-current{grid-template-columns:1fr;text-align:center;gap:2rem}.weather-current-loc,.weather-current-feel{text-align:center}.curr-feel{display:inline-block}}:root{--correct: #538d4e;--almost: #b59f3b;--disable: #3a3a3c;--absent: #3a3a3c;--key-evaluated-text: #f8f8f8;--font-size: 2rem;--key-width: 3rem;--key-height: 4rem;--stat-color: #444}.wordle-container{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;border:1px solid #DDD;padding:1rem;width:100%}.wordle-header{width:100%;display:flex;position:relative;align-items:center;height:2.25rem}.wordle-title{position:absolute;left:50%;transform:translate(-50%);margin:0;font-size:var(--font-size)}.wordle-stats{margin-left:auto}.wordle-game{display:flex;flex-direction:column;align-items:center;width:100%}.wordle-board{width:20rem;height:23.5rem;border:1px solid black;display:flex;flex-direction:column;padding:0;margin-bottom:1.5rem}.wordle-board-row{flex:33%;display:flex;flex-direction:row;margin:5px;gap:.5rem}.wordle-letter{flex:33%;height:100%;border:1px solid grey;display:grid;place-items:center;font-size:var(--font-size);padding:.25rem;line-height:1rem;font-weight:600;color:#fff;font-family:Arial,Helvetica,sans-serif}.letter-correct{background-color:var(--correct)}.letter-present{background-color:var(--almost)}.letter-absent{background-color:var(--absent)}.letter-filled{border-color:#878a8c}.wordle-keyboard{display:flex;flex-direction:column;gap:.5rem;width:100%;height:14rem;max-width:32rem;margin:0 auto}.keyboard-row{display:flex;width:100%;touch-action:manipulation;justify-content:center;gap:.5rem}.key{width:2.65rem;height:3.625rem;border-radius:.25rem;display:grid;place-items:center;font-size:.875rem;font-weight:700;background-color:gray;color:#fff;font-family:Arial,Helvetica,sans-serif;cursor:pointer;border:none;transition:background-color .1s}.key:hover{opacity:.9}.key-big{flex:1.5;max-width:65px;font-size:.75rem}.key-correct{background-color:var(--correct)}.key-present{background-color:var(--almost)}.key-absent{background-color:var(--absent)}.wordle-game-over{display:flex;flex-direction:column;align-items:center}.wordle-reset{font-size:1.25rem}.reset-button{color:#fff;padding:.85rem;font-weight:500;padding:.5rem}.reset-button-won{color:#fff;background-color:var(--correct);padding:1rem;font-weight:500}.reset-button-lost{color:#fff;padding:1rem;background-color:var(--almost);font-weight:500}.stats-overlay{position:absolute;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stats-modal{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;color:var(--stat-color);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.stats-close-x{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1rem;cursor:pointer;color:#111;line-height:1}.stats-close-x:hover{border:1px solid #222}.stats-modal h2{margin-top:0;text-align:center;margin-bottom:1.5rem}.stats-modal h3{margin-top:1rem;text-align:center;margin-bottom:1.5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stat{text-align:center}.stat-value{font-size:1.5rem;font-weight:600;color:var(--stat-color)}.stat-label{font-size:.75rem;color:#666;text-transform:uppercase;margin-top:.25rem}.stats-distribution{display:flex;flex-direction:column;gap:.5rem}.distribution-row{display:flex;align-items:center;gap:.5rem}.guess-number{font-weight:700;min-width:1.5rem;text-align:center}.bar-container{flex:1;height:1.5rem;display:flex}.bar{background-color:#d3d6da;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;transition:width .3s ease;min-height:1.5rem;min-width:2rem}.bar .has-count{background-color:var(--correct);font-size:.875rem}.additional-stats{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #ddd;text-align:center}.additional-stats p{margin:.5rem 0}.streak-indicator{color:var(--correct);font-weight:700}.stats-close-btn{margin-top:1.5rem;width:100%;padding:.75rem;background:#6aaa64;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:700;cursor:pointer}.stats-close-btn:hover{background-color:var(--correct)}@media(max-width:768px){.wordle-keyboard{max-width:100%;padding:0 .5rem}.keyboard-row{gap:.2rem}.key{flex:1;min-width:0;width:auto;max-width:2.5rem;height:3.25rem;font-size:.75rem;margin:0;border-radius:.2rem}.key-big{flex:1.5;width:auto;max-width:3.4rem}}@media(max-width:576px){.wordle-keyboard{padding:0 .25rem}.keyboard-row{gap:.15rem}.key{max-width:1.875rem;height:2.875rem;font-size:.7rem;border-radius:.15rem}.key-big{max-width:2.8rem;font-size:.6rem}}@media(max-width:425px){.key{max-width:1.625rem;height:2.625rem;font-size:.65rem}.key-big{max-width:2.5rem;font-size:.55rem}.wordle-board{width:18rem;height:21.5rem}.stats-modal{padding:1rem}.stats-grid{gap:.875rem}.stat-value,.guess-number{font-size:1.25rem}.stat-label{font-size:.65rem}}@media(max-width:350px){.keyboard-row{gap:.1rem}.key{max-width:1.5rem;height:2.375;font-size:.6rem}.key-big{max-width:2.25rem;font-size:.5rem}.wordle-board{width:16rem;height:20rem}.stat-value,.guess-number{font-size:1rem}.stat-label{font-size:.5rem}}
