:root{--color-text-light: #ffffff;--color-text-dark: #000000;--color-primary: #213547;--color-secondary: #666666;--color-background: #f5f5f5;--color-accent: #33aaff;--color-accent-dark: #0561a2;--shadow-sm: 0 2px 4px 0 rgb(0 0 0 / 10%);--transition-fast: .2s ease;--font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}#root{max-width:1280px;margin:0 auto;padding:2rem;height:calc(100vh - 64px)}body{height:100vh;margin:0;font-family:var(--font-family);background-color:var(--color-background);color:var(--color-primary)}button{font-family:inherit;border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1rem;font-weight:500;background-color:var(--color-text-light);cursor:pointer;transition:border-color var(--transition-fast)}button:hover{border-color:var(--color-accent)}.app{height:calc(100vh - 40px);display:flex;position:relative;flex-direction:column;background-color:var(--color-background)}.app__preloader{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background-color:var(--color-background);z-index:3}.app__header{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:var(--color-text-light);padding:20px;text-align:center;box-shadow:var(--shadow-sm)}.app__header h1{margin:0;font-size:var(--font-size-xl);font-weight:700;text-shadow:2px 2px 4px rgb(0 0 0 / 20%)}.app__content{flex:1;max-width:1280px;margin:0 auto;width:100%}.app__footer{background-color:var(--color-primary);color:var(--color-text-light);text-align:center;padding:15px;margin-top:auto}.app__footer p{margin:0;font-size:var(--font-size-sm)}@media (max-width: 544px) and (min-width: 320px){.app__header{padding:10px}.app__content{padding:0 2px}.app__footer{padding:8px}}@media (min-width: 545px) and (max-width: 1024px){.app__header{padding:15px}.app__content{padding:0 8px}.app__footer{padding:10px}}.header{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);padding:5px;box-shadow:var(--shadow-sm);position:relative;top:0;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}.header__user{color:var(--color-text-light);font-size:1rem}.header__container{max-width:1280px;margin:0 auto;padding:0 20px;display:flex;flex:1;flex-direction:row;align-items:center;justify-content:space-between;gap:10px}.header__title{color:var(--color-text-light);margin:0 auto 10px 0;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;text-shadow:2px 2px 4px rgb(0 0 0 / 20%);white-space:nowrap}.header__auth{display:flex;align-self:center;gap:10px}.header__filters{display:flex;gap:10px;align-items:center}.header__filter{padding:5px 10px;font-size:1rem;border:1px solid var(--color-border);border-radius:5px;background-color:var(--color-background);color:var(--color-text);cursor:pointer}.header__filter:focus{outline:none;border-color:var(--color-accent)}.header__filter option{background-color:var(--color-background);color:var(--color-text)}@media (max-width: 544px) and (min-width: 320px){.header__container{flex-direction:column;gap:5px;padding:0 5px}.header__title{font-size:1.2rem;margin:0}}@media (min-width: 545px) and (max-width: 1024px){.header__container{gap:10px;padding:0 10px;flex-wrap:wrap}.header__title{font-size:1.5rem;margin:0}.header__auth{margin:auto}}.navigation{margin-left:auto;align-self:center}.navigation__list{list-style:none;margin:0;padding:0;display:flex;gap:20px}.navigation__item{position:relative}.navigation__link{color:var(--color-text-light);text-decoration:none;font-size:var(--font-size-lg);padding:8px 16px;border-radius:20px;transition-property:background-color;transition-duration:var(--transition-normal);transition-timing-function:ease;position:relative}.navigation__link:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:var(--color-text-light);transition-property:width;transition-duration:var(--transition-normal);transition-timing-function:ease;transform:translate(-50%)}.navigation__link:hover:before,.navigation__link:focus:before{width:80%}.navigation__link:focus-visible{outline:2px solid var(--color-text-light);outline-offset:2px}.navigation__link_active{background-color:#fff3}.navigation__link_active:before{width:80%}@media (max-width: 544px) and (min-width: 320px){.navigation{margin:0}.navigation__list{flex-direction:column;gap:10px}.navigation__link{font-size:1rem;align-self:center;padding:8px}}@media (min-width: 545px) and (max-width: 1024px){.navigation{margin:0}.navigation__list{gap:12px}.navigation__link{font-size:1.1rem;padding:8px 12px}}.search-bar{display:flex;gap:10px}.search-bar__input{flex:1;padding:10px;border:1px solid #ccc;border-radius:5px}.search-bar__button{padding:10px 20px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer}.search-bar__button:hover{background-color:#0056b3}@media (max-width: 544px) and (min-width: 320px){.search-bar{flex-direction:column;gap:6px}.search-bar__input{font-size:.95rem;padding:8px}.search-bar__button{width:100%;padding:10px}}@media (min-width: 545px) and (max-width: 1024px){.search-bar{gap:8px}.search-bar__input{font-size:1rem;padding:9px}.search-bar__button{padding:10px 16px}}.button{padding:10px 20px;font-size:16px;color:#fff;background-color:#007bff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s ease}.button:hover{background-color:#0056b3}.button--disabled{background-color:#d3d3d3;cursor:not-allowed;color:#a9a9a9;pointer-events:none;transition:none}.button--disabled:hover{background-color:#e0e0e0}@media (max-width: 544px) and (min-width: 320px){.button{width:100%;font-size:.95rem;padding:8px 0}}@media (min-width: 545px) and (max-width: 1024px){.button{font-size:1rem;padding:10px}}.select{position:relative;width:100%;padding:10px;font-size:1rem;border:1px solid #ccc;border-radius:4px;background-color:#fff;color:#333;outline:none;transition:border-color .3s}.select:focus{border-color:#007bff}.select option{padding:10px}.select__dropdown{position:absolute;width:100%;max-height:300px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:4px;margin-top:4px;z-index:10;box-shadow:0 2px 8px #00000014}.select__option{padding:10px;cursor:pointer;transition:background .2s}.select__option:hover{background:#f0f0f0}.select__option--selected{background:#e6f0ff;font-weight:700}.select__selected{-webkit-user-select:none;user-select:none}.select__option--type-fire:hover{background:#ffb366}.select__option--type-water:hover{background:#8ecfff}.select__option--type-grass:hover{background:#b7e7a0}.select__option--type-electric:hover{background:#fff59d}.select__option--type-psychic:hover{background:#ffb6c1}.select__option--type-ice:hover{background:#b3eaff}.select__option--type-dragon:hover{background:#cba4ff}.select__option--type-dark:hover{background:#bdbdbd}.select__option--type-fairy:hover{background:#fce4ec}.select__option--type-poison:hover{background:#e1bee7}.select__option--type-bug:hover{background:#dcedc8}.select__option--type-fighting:hover{background:#ffccbc}.select__option--type-flying:hover{background:#e3f2fd}.select__option--type-ghost:hover{background:#d1c4e9}.select__option--type-ground:hover{background:#ffe0b2}.select__option--type-rock:hover{background:#e0cda9}.select__option--type-steel:hover{background:#cfd8dc}.select__option--type-normal:hover{background:#f5f5f5}.select__option--type-todos:hover{background:#e0f7fa}@media (max-width: 544px) and (min-width: 320px){.select{font-size:.9rem;padding:8px}}@media (min-width: 545px) and (max-width: 1024px){.select{font-size:1rem;padding:9px}}.auth-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;z-index:1000;overflow:hidden}body.modal-open{overflow:hidden}.auth-modal__content{background:#fff;border-radius:18px;padding:32px 28px 24px;box-shadow:0 8px 32px #00000038,0 1.5px 8px #e3350d14;width:400px;max-height:500px;position:relative;display:flex;flex-direction:column;align-items:center;border:1.5px solid #e3350d22;animation:modalIn .25s cubic-bezier(.4,2,.6,1) both}@keyframes modalIn{0%{transform:scale(.85) translateY(40px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.auth-modal__close{position:absolute;top:10px;right:16px;background:none;border:none;padding:0;font-size:2rem;color:#0561a2;cursor:pointer;transition:color .2s}.auth-modal__close:hover{color:#4791c7}.auth-modal__form{display:flex;flex-direction:column;gap:18px;width:100%;margin-top:18px}.auth-modal__form input{padding:12px 14px;border-radius:8px;border:1.5px solid #0561a2;font-size:1.08rem;background:#f8f8f8;transition:border .2s}.auth-modal__form input:focus{border:1.5px solid #0561a2;outline:none;background:#fff}.auth-modal__submit{background:linear-gradient(90deg,#0561a2 60%,#3af);color:#fff;border:none;border-radius:8px;padding:12px 0;font-size:1.13rem;font-weight:700;cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px #e3350d14}.auth-modal__submit:disabled{background:#ccc;cursor:not-allowed}.auth-modal__error{color:#e3350d;background:#ffeaea;border-radius:6px;padding:8px 12px;font-size:.98rem;margin-bottom:4px;text-align:center;border:1px solid #e3350d33}.auth-modal__switch{margin-top:18px;font-size:1.01rem;text-align:center}.auth-modal__link{background:none;border:none;color:#0561a2;cursor:pointer;text-decoration:underline;font-size:1rem;margin-left:4px;font-weight:500;transition:color .2s}.auth-modal__link:hover{color:#1374b9}@media (max-width: 544px) and (min-width: 320px){.auth-modal__content{padding:16px 8px 12px}}@media (min-width: 545px) and (max-width: 1024px){.auth-modal__content{padding:24px 16px 16px}}.main{height:calc(100vh - 200px);background-color:var(--color-background)}.main__content{max-width:1280px;margin:0 auto;padding:40px 20px;overflow:auto;height:calc(100vh - 303px)}.main__preloader{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background-color:var(--color-background)}.main__preloader-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;background:#fff;display:flex;align-items:center;justify-content:center;opacity:1}@media (max-width: 544px) and (min-width: 320px){.main__content{padding:10px 2px}}@media (min-width: 545px) and (max-width: 1024px){.main__content{padding:20px 8px}}.pokemon-container{padding:20px;position:relative;min-height:100%}.pokemon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px;align-items:start}.pokemon-loading,.popup-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:1}.pokemon-loading{background-color:var(--color-text-light)}.pokemon-error{text-align:center;color:var(--color-accent);padding:20px;border:1px solid currentColor;border-radius:8px;margin:20px auto;max-width:600px}.load-more-button{display:block;margin:30px auto;padding:12px 24px;background:var(--color-accent);color:var(--color-text-light);border:none;border-radius:25px;font-size:var(--font-size-lg);cursor:pointer;transition-property:transform;transition-duration:var(--transition-normal);transition-timing-function:ease}.load-more-button:hover{transform:translateY(-2px)}.load-more-button:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}.load-more-button:active{transform:translateY(0)}@media (max-width: 544px) and (min-width: 320px){.pokemon-grid{grid-template-columns:1fr;gap:10px}.pokemon-container{padding:10px}}@media (min-width: 545px) and (max-width: 1024px){.pokemon-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px}.pokemon-container{padding:15px}}.pokemon-card{background-color:var(--color-text-light);border-radius:20px;padding:20px;text-align:center;cursor:pointer;position:relative;transform:translateZ(0);transition:transform var(--transition-normal),box-shadow var(--transition-normal);pointer-events:auto}.pokemon-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}.pokemon-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.pokemon-ball{width:200px;height:200px;margin:0 auto;position:relative;display:flex;justify-content:center;align-items:center;transition:transform var(--transition-slow)}.pokemon-ball:before{content:"";position:absolute;width:20px;height:20px;background-color:var(--color-text-light);border:4px solid var(--color-text-dark);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.pokemon-ball:after{content:"";position:absolute;width:100%;height:4px;background-color:var(--color-text-dark);top:50%;transform:translateY(-50%)}.pokemon-ball.open{transform:scale(.8)}.card-image-container{width:180px;height:180px;margin:0 auto;position:relative;display:flex;justify-content:center;align-items:center}.pokemon-image{width:150px;height:150px;object-fit:contain;transition:transform var(--transition-normal);filter:drop-shadow(0 4px 6px rgb(0 0 0 / 10%))}.pokemon-ball.open .pokemon-image{transform:scale(1.1)}.pokemon-name{margin:15px 0 5px;text-transform:capitalize;font-size:1.2rem;color:var(--color-primary);font-weight:600}.pokemon-number{color:var(--color-secondary);font-size:var(--font-size-sm);display:block}.favorite-button{position:absolute;top:10px;right:10px;width:40px;height:40px;padding:8px;background:none;border:none;cursor:pointer;z-index:2;transition:transform var(--transition-fast);border-radius:50%}.favorite-button:hover{transform:scale(1.1)}.favorite-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.favorite-button svg{width:24px;height:24px;fill:none;stroke:var(--color-accent);stroke-width:2;transition:fill var(--transition-normal)}.favorite-button.active svg{fill:var(--color-accent)}@keyframes favoriteAnimation{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.favorite-button.active svg{animation:favoriteAnimation .3s ease-in-out}@media (max-width: 544px) and (min-width: 320px){.pokemon-card{padding:10px}.pokemon-ball{width:120px;height:120px}}@media (min-width: 545px) and (max-width: 1024px){.pokemon-card{padding:15px}.pokemon-ball{width:150px;height:150px}}.pokeball-preloader{width:80px;height:80px;background-color:#fff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);overflow:hidden;border:3px solid var(--color-text-dark);animation-name:shake;animation-duration:1.25s;animation-timing-function:cubic-bezier(.36,.07,.19,.97);animation-iteration-count:infinite;z-index:1}.pokeball-preloader:before{content:"";position:absolute;top:0;right:0;bottom:50%;left:0;background-color:var(--color-accent);border-bottom:3px solid var(--color-text-dark)}.pokeball-preloader:after{content:"";position:absolute;width:20px;height:20px;background-color:var(--color-text-light);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);border:3px solid var(--color-text-dark);box-shadow:var(--shadow-sm)}@keyframes shake{0%{transform:translateZ(0) rotate(0)}20%{transform:translate3d(-10px,0,0) rotate(-20deg)}30%{transform:translate3d(10px,0,0) rotate(20deg)}50%{transform:translate3d(-10px,0,0) rotate(-10deg)}60%{transform:translate3d(10px,0,0) rotate(10deg)}to{transform:translateZ(0) rotate(0)}}@media (max-width: 544px) and (min-width: 320px){.pokeball-preloader{width:50px;height:50px}}@media (min-width: 545px) and (max-width: 1024px){.pokeball-preloader{width:65px;height:65px}}.not-found{text-align:center;padding:20px}.not-found__image{max-width:100%;height:auto;margin-bottom:20px}.not-found__text{font-size:1.5rem;color:#333;margin-bottom:20px}.not-found__button{font-size:1rem;padding:10px 20px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer}.not-found__button:hover{background-color:#0056b3}@media (max-width: 544px) and (min-width: 320px){.not-found__text{font-size:1.1rem}.not-found__button{width:100%;padding:8px 0}}@media (min-width: 545px) and (max-width: 1024px){.not-found__text{font-size:1.3rem}.not-found__button{padding:10px 12px}}.popup-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:1;display:flex;justify-content:center;align-items:center;max-width:1280px;z-index:3;pointer-events:auto;height:calc(100vh - 70px)}.popup-content{background-color:#fff;border-radius:20px;padding:10px;position:relative;width:100%;max-width:1000px;max-height:85vh;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 4px 20px #000;opacity:1}.popup-close{position:absolute;top:10px;right:10px;width:32px;height:32px;padding:0;background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:1.5rem}.popup-loading{display:flex;justify-content:center;align-items:center;height:100%;opacity:.8}.pokeball-animation{display:flex;justify-content:center;align-items:center;width:100%;height:100%;background:radial-gradient(circle,red 50%,#fff 50%);border-radius:50%}.pokemon-details{display:flex;align-items:center;padding:20px 0 10px}.pokemon-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.pokemon-header h2{font-size:2rem;margin:0;text-transform:capitalize}.pokemon-header span{font-size:1.2rem;color:#888}.popup-image-container{display:flex;justify-content:center;align-items:center;width:180px;height:180px;margin:0 auto}.pokemon-detail-image{width:100%;height:100%;object-fit:contain}.pokemon-info{width:100%;display:flex;flex-direction:column;gap:18px}.pokemon-types{display:flex;gap:8px;justify-content:center;margin-bottom:8px}.type-badge{padding:4px 12px;border-radius:12px;color:#fff;font-size:.95rem;text-transform:capitalize;font-weight:600;background:#aaa;box-shadow:0 1px 4px #00000014}.type-badge.fire{background:#ee8130}.type-badge.water{background:#6390f0}.type-badge.grass{background:#7ac74c}.type-badge.electric{background:#f7d02c;color:#333}.type-badge.ice{background:#96d9d6;color:#333}.type-badge.fighting{background:#c22e28}.type-badge.poison{background:#a33ea1}.type-badge.ground{background:#e2bf65;color:#333}.type-badge.flying{background:#a98ff3}.type-badge.psychic{background:#f95587}.type-badge.bug{background:#a6b91a}.type-badge.rock{background:#b6a136;color:#333}.type-badge.ghost{background:#735797}.type-badge.dragon{background:#6f35fc}.type-badge.dark{background:#705746}.type-badge.steel{background:#b7b7ce;color:#333}.type-badge.fairy{background:#d685ad}.pokemon-stats{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.stat-row{display:flex;align-items:center;gap:10px}.stat-name{width:80px;text-transform:capitalize;font-size:1rem;color:#444}.stat-bar-container{flex:1;background:#eee;border-radius:8px;height:16px;overflow:hidden;margin:0 6px}.stat-bar{height:100%;border-radius:8px;background:linear-gradient(90deg,#4caf50 60%,#81c784);transition:width .5s cubic-bezier(.4,0,.2,1)}.stat-value{width:32px;text-align:right;font-size:1rem;color:#222}.pokemon-abilities{margin-top:8px}.pokemon-abilities h3{font-size:1.1rem;margin:0 0 4px;color:#555}.abilities-list{display:flex;flex-wrap:wrap;gap:8px}.ability-badge{background:#f1c40f;color:#222;border-radius:10px;padding:3px 10px;font-size:.95rem;font-weight:500;text-transform:capitalize;box-shadow:0 1px 2px #00000012}.popup-nav{display:flex;margin:0;background-color:#0ff}.prev{margin-right:10px}.next{margin-left:10px}@media (max-width: 544px) and (min-width: 320px){.popup-content{max-width:70vw;max-height:60vh;padding:6px;border-radius:12px;overflow:auto}.popup-overlay{left:0;max-width:100vw;height:100vh;padding:0;flex-direction:column}.pokemon-details{flex-direction:column;padding:10px 0 5px}.popup-image-container{width:120px;height:50px}.pokemon-detail-image{width:100%;height:100%}.pokemon-header h2{font-size:1.2rem}.pokemon-header span{font-size:1rem}.pokemon-info{gap:10px}.type-badge{font-size:.85rem;padding:3px 8px}.stat-name{width:60px;font-size:.9rem}.stat-value{font-size:.9rem}.ability-badge{font-size:.85rem;padding:2px 7px}.prev{margin:0 0 10px}.next{margin:10px 0 0}}@media (min-width: 545px) and (max-width: 1024px){.popup-content{max-width:80vw;padding:8px;border-radius:16px}.popup-overlay{left:0;max-width:100vw;height:100vh;padding:0;flex-direction:column}.pokemon-details{padding:15px 0 8px}.popup-image-container{width:150px;height:150px}.pokemon-header h2{font-size:1.5rem}.pokemon-header span{font-size:1.1rem}.type-badge{font-size:.92rem;padding:4px 10px}.stat-name{width:70px;font-size:.97rem}.stat-value{font-size:.97rem}.ability-badge{font-size:.92rem;padding:3px 8px}.prev{margin:0 0 10px}.next{margin:10px 0 0}}.footer{background-color:var(--color-primary);padding:20px 0;margin-top:auto;position:relative;z-index:0}.footer__container{max-width:1280px;margin:0 auto;padding:0 20px;display:flex;justify-content:center;align-items:center}.footer__text{color:var(--color-text-light);margin:0;font-size:var(--font-size-sm);line-height:1.5}@media (max-width: 544px) and (min-width: 320px){.footer__container{flex-direction:column;padding:0 5px}.footer__text{font-size:.9rem}}@media (min-width: 545px) and (max-width: 1024px){.footer__container{padding:0 10px}.footer__text{font-size:1rem}}
