.dogs-page{color:#2c3e50;background-color:#fff}.dogs-hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px 30px;text-align:center}.dogs-hero__title{font-size:24px;font-weight:700;color:#fff;margin:0 0 8px;line-height:1.3}.dogs-hero__subtitle{font-size:15px;color:#ffffffe6;margin:0;line-height:1.5}.dogs-filters{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:16px 20px;position:sticky;top:60px;z-index:30;box-shadow:0 2px 8px #0000000f}.dogs-filters__container{max-width:1200px;margin:0 auto}.dogs-filters__row{display:flex;flex-direction:column;gap:12px}.dogs-filters__group{flex:1}.dogs-filters__label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#667eea;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.dogs-filters__label svg{width:14px;height:14px;flex-shrink:0}.dogs-filters__input{width:100%;padding:10px 14px;border:1px solid #e5e7eb;border-radius:10px;font-size:15px;color:#2c3e50;background-color:#f8f9fa;transition:all .2s ease;outline:none;font-family:inherit}.dogs-filters__input:focus{border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea26}.dogs-filters__input::placeholder{color:#9ca3af}.dogs-filters__select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.dogs-filters__toggle{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s ease;font-family:inherit}.dogs-filters__toggle svg{width:16px;height:16px}.dogs-filters__toggle:hover,.dogs-filters__toggle--active{background-color:#667eea;border-color:#667eea;color:#fff}.dogs-filters__extended{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid #f3f4f6}.dogs-filters__radio-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dogs-filters__radio-label{font-size:14px;font-weight:600;color:#4b5563}.dogs-filters__radio{display:flex;align-items:center;gap:4px;font-size:14px;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.dogs-filters__radio input[type=radio]{width:16px;height:16px;accent-color:#667eea;cursor:pointer}.dogs-filters__checkbox{display:flex;align-items:center;gap:8px;font-size:14px;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.dogs-filters__checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.dogs-filters__clear{margin-left:auto;padding:6px 16px;background:none;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;font-weight:500;color:#9ca3af;cursor:pointer;transition:all .2s ease;font-family:inherit}.dogs-filters__clear:hover{border-color:#ef4444;color:#ef4444}.dogs-results{padding:20px 20px 40px;background-color:#f8f9fa;min-height:400px}.dogs-results__container{max-width:1200px;margin:0 auto}.dogs-results__bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.dogs-results__count{font-size:14px;color:#6b7280;margin:0}.dogs-results__count strong{color:#2c3e50}.dogs-results__sort{display:flex;gap:6px}.dogs-results__sort-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid #e5e7eb;border-radius:20px;background-color:#fff;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;font-family:inherit}.dogs-results__sort-btn svg{width:14px;height:14px}.dogs-results__sort-btn:hover{border-color:#667eea;color:#667eea}.dogs-results__sort-btn--active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.dogs-results__sort-btn--active:hover{color:#fff;border-color:transparent}.dogs-grid{display:grid;grid-template-columns:1fr;gap:16px;transition:opacity .2s ease}.dogs-grid--loading{opacity:.5;pointer-events:none}.dog-card{display:flex;flex-direction:column;background-color:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s ease;text-decoration:none;color:inherit}.dog-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.dog-card__image{height:200px;background-size:cover;background-position:center;position:relative;background-color:#e2e8f0}.dog-card__badges{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px}.dog-card__badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;line-height:1;color:#fff}.dog-card__badge--male{background:linear-gradient(135deg,#3b82f6,#2563eb)}.dog-card__badge--female{background:linear-gradient(135deg,#ec4899,#db2777)}.dog-card__badge--stud{background:linear-gradient(135deg,#f59e0b,#d97706)}.dog-card__badge--available{background:linear-gradient(135deg,#10b981,#059669)}.dog-card__badge--champion{background:linear-gradient(135deg,#eab308,#ca8a04)}.dog-card__content{padding:16px;display:flex;flex-direction:column;flex:1}.dog-card__title{font-size:17px;font-weight:700;color:#2c3e50;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dog-card__breed{font-size:14px;color:#667eea;font-weight:500;margin:0 0 8px}.dog-card__meta{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;margin-bottom:8px}.dog-card__age{display:flex;align-items:center;gap:4px}.dog-card__age svg{width:14px;height:14px;flex-shrink:0;color:#9ca3af}.dog-card__color{color:#9ca3af}.dog-card__kennel{display:flex;align-items:center;gap:6px;font-size:13px;color:#4b5563;font-weight:500;margin-bottom:8px}.dog-card__kennel svg{width:14px;height:14px;flex-shrink:0;color:#9ca3af}.dog-card__location{display:flex;align-items:center;gap:6px;font-size:13px;line-height:1.4;margin-top:auto}.dog-card__flag{width:18px;height:13px;object-fit:cover;border-radius:2px;flex-shrink:0}.dog-card__country{color:#2c3e50;font-weight:600}.dog-card__place{color:#7f8c8d}.dog-card__button{display:block;width:100%;margin-top:16px;padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;text-decoration:none;border-radius:8px;font-size:14px;font-weight:600;transition:all .3s ease}.dog-card:hover .dog-card__button{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.dogs-results__empty{text-align:center;padding:60px 20px}.dogs-results__empty svg{width:48px;height:48px;color:#d1d5db;margin-bottom:16px}.dogs-results__empty p{font-size:16px;color:#6b7280;margin-bottom:20px}.dogs-results__empty-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.dogs-results__empty-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.dogs-results__pagination{margin-top:32px;display:flex;justify-content:center}.dogs-results__pagination nav{display:flex;align-items:center;gap:4px}.dogs-results__pagination span[aria-current=page] span,.dogs-results__pagination a{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease}.dogs-results__pagination a{color:#6b7280;background-color:#fff;border:1px solid #e5e7eb}.dogs-results__pagination a:hover{border-color:#667eea;color:#667eea}.dogs-results__pagination span[aria-current=page] span{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid transparent}.dogs-results__pagination span[aria-disabled=true] span{opacity:.4;cursor:not-allowed}@media(min-width:540px){.dogs-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.dogs-hero{padding:60px 40px 40px}.dogs-hero__title{font-size:36px}.dogs-hero__subtitle{font-size:18px}.dogs-filters{padding:20px 40px;top:70px}.dogs-filters__row{flex-direction:row;align-items:flex-end}.dogs-results{padding:24px 40px 60px}.dogs-results__sort-btn span{display:inline}.dogs-grid{grid-template-columns:repeat(2,1fr);gap:20px}}@media(min-width:1024px){.dogs-grid{grid-template-columns:repeat(3,1fr);gap:24px}.dog-card__image{height:220px}}
