.leaflet-cluster-anim .leaflet-marker-icon,.leaflet-cluster-anim .leaflet-marker-shadow{-webkit-transition:-webkit-transform .3s ease-out,opacity .3s ease-in;-moz-transition:-moz-transform .3s ease-out,opacity .3s ease-in;-o-transition:-o-transform .3s ease-out,opacity .3s ease-in;transition:transform .3s ease-out,opacity .3s ease-in}.leaflet-cluster-spider-leg{-webkit-transition:-webkit-stroke-dashoffset .3s ease-out,-webkit-stroke-opacity .3s ease-in;-moz-transition:-moz-stroke-dashoffset .3s ease-out,-moz-stroke-opacity .3s ease-in;-o-transition:-o-stroke-dashoffset .3s ease-out,-o-stroke-opacity .3s ease-in;transition:stroke-dashoffset .3s ease-out,stroke-opacity .3s ease-in}.marker-cluster-small{background-color:#b5e28c99}.marker-cluster-small div{background-color:#6ecc3999}.marker-cluster-medium{background-color:#f1d35799}.marker-cluster-medium div{background-color:#f0c20c99}.marker-cluster-large{background-color:#fd9c7399}.marker-cluster-large div{background-color:#f1801799}.leaflet-oldie .marker-cluster-small{background-color:#b5e28c}.leaflet-oldie .marker-cluster-small div{background-color:#6ecc39}.leaflet-oldie .marker-cluster-medium{background-color:#f1d357}.leaflet-oldie .marker-cluster-medium div{background-color:#f0c20c}.leaflet-oldie .marker-cluster-large{background-color:#fd9c73}.leaflet-oldie .marker-cluster-large div{background-color:#f18017}.marker-cluster{background-clip:padding-box;border-radius:20px}.marker-cluster div{width:30px;height:30px;margin-left:5px;margin-top:5px;text-align:center;border-radius:15px;font:12px Helvetica Neue,Arial,Helvetica,sans-serif}.marker-cluster span{line-height:30px}:root{--color-primary: #0077B6;--color-primary-dark: #005f8f;--color-primary-light: #90e0ef;--color-secondary: #48CAE4;--color-secondary-dark: #00B4D8;--color-accent: #F77F00;--color-accent-dark: #d96d00;--color-sand: #F8F5F0;--color-sand-dark: #EDE8E0;--color-white: #ffffff;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-danger: #dc2626;--color-danger-light: #fef2f2;--color-success: #16a34a;--color-success-light: #f0fdf4;--color-warning: #f59e0b;--font-display: "Playfair Display", Georgia, serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--header-height: 64px;--max-width: 1280px;--sidebar-width: 320px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--color-gray-800);background-color:var(--color-sand);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.25;color:var(--color-gray-900)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.text-center{text-align:center}.italic{font-style:italic}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;padding-top:var(--header-height)}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-gray-200);z-index:1000;display:flex;align-items:center}.header__inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.header__logo{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-primary);display:flex;align-items:center;gap:.5rem}.header__logo:hover{color:var(--color-primary-dark)}.header__logo-icon{font-size:1.75rem}.header__nav{display:flex;align-items:center;gap:2rem}.header__nav-links{display:flex;align-items:center;gap:1.5rem}.header__nav-link{font-weight:500;color:var(--color-gray-600);padding:.5rem 0;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.header__nav-link:hover,.header__nav-link--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.header__auth{display:flex;align-items:center;gap:.75rem}.header__user-name{font-weight:500;color:var(--color-gray-700)}.header__hamburger{display:none;flex-direction:column;gap:5px;padding:4px}.header__hamburger span{display:block;width:24px;height:2px;background:var(--color-gray-700);transition:all var(--transition-fast)}.header__mobile-menu{display:none;position:fixed;top:var(--header-height);left:0;right:0;background:var(--color-white);border-bottom:1px solid var(--color-gray-200);padding:1rem 1.5rem;flex-direction:column;gap:.75rem;z-index:999}.header__mobile-menu--open{display:flex}@media(max-width:768px){.header__nav-links,.header__auth{display:none}.header__hamburger{display:flex}.header__mobile-menu .header__nav-link,.header__mobile-menu .btn{display:block;width:100%;text-align:left;padding:.75rem 0;border-bottom:none}}.footer{background:var(--color-gray-800);color:var(--color-gray-400);padding:2rem 0;text-align:center;font-size:.875rem}.footer a{color:var(--color-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-weight:600;font-size:.9375rem;border-radius:var(--radius-md);transition:all var(--transition-fast);line-height:1.4;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:var(--color-white)}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark);color:var(--color-white)}.btn--accent{background:var(--color-accent);color:var(--color-white)}.btn--accent:hover:not(:disabled){background:var(--color-accent-dark);color:var(--color-white)}.btn--outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn--outline:hover:not(:disabled){background:var(--color-primary);color:var(--color-white)}.btn--ghost{background:transparent;color:var(--color-gray-600)}.btn--ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-800)}.btn--danger{background:var(--color-danger);color:var(--color-white)}.btn--danger:hover:not(:disabled){background:#b91c1c;color:var(--color-white)}.btn--sm{padding:.375rem .75rem;font-size:.8125rem}.btn--lg{padding:.875rem 2rem;font-size:1.0625rem}.btn--icon{padding:.5rem;border-radius:var(--radius-full)}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-weight:500;font-size:.875rem;color:var(--color-gray-700);margin-bottom:.375rem}.form-input,.form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--color-white);color:var(--color-gray-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0077b626}.form-input--error{border-color:var(--color-danger)}.form-input--error:focus{box-shadow:0 0 0 3px #dc262626}.form-error{font-size:.8125rem;color:var(--color-danger);margin-top:.25rem}.form-textarea{resize:vertical;min-height:100px}.card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card__image{width:100%;height:200px;object-fit:cover;background:var(--color-gray-100)}.card__image-placeholder{width:100%;height:200px;background:linear-gradient(135deg,var(--color-primary-light),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--color-white)}.card__body{padding:1.25rem}.card__scientific-name{font-family:var(--font-display);font-style:italic;font-size:1.125rem;color:var(--color-gray-900);margin-bottom:.25rem}.card__common-name{font-size:.875rem;color:var(--color-gray-500);margin-bottom:.5rem}.card__meta{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem}.card__family{font-size:.8125rem;color:var(--color-primary);font-weight:500}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge--lc{background:#d1fae5;color:#065f46}.badge--nt{background:#fef3c7;color:#92400e}.badge--vu{background:#ffedd5;color:#9a3412}.badge--en{background:#fee2e2;color:#991b1b}.badge--cr{background:#fce7f3;color:#9d174d}.badge--dd{background:var(--color-gray-100);color:var(--color-gray-600)}.badge--ne{background:var(--color-gray-100);color:var(--color-gray-500)}.species-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1.5rem 0}.species-grid__sentinel{grid-column:1 / -1;display:flex;justify-content:center;padding:2rem 0}.filters{display:flex;flex-wrap:wrap;gap:1rem;padding:1.25rem 1.5rem;background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:.5rem}.filters__field{flex:1;min-width:200px}.filters__search{flex:2;min-width:280px}@media(max-width:640px){.filters{flex-direction:column}.filters__field,.filters__search{min-width:100%}}.favorite-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);transition:all var(--transition-fast);font-size:1.25rem;color:var(--color-gray-400)}.favorite-btn:hover{background:var(--color-danger-light);color:var(--color-danger)}.favorite-btn--active{color:var(--color-danger)}.hero{position:relative;min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient(135deg,#023e8a,#0077b6 40%,#48cae4);overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 80%,rgba(144,224,239,.3) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(0,180,216,.2) 0%,transparent 50%);pointer-events:none}.hero__content{position:relative;z-index:1;max-width:800px;padding:2rem 1.5rem}.hero__title{font-family:var(--font-display);font-size:4rem;font-weight:700;color:var(--color-white);margin-bottom:1rem;line-height:1.1}.hero__subtitle{font-size:1.25rem;color:#ffffffe6;margin-bottom:2.5rem;line-height:1.6;max-width:600px;margin-left:auto;margin-right:auto}.hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero__wave{position:absolute;bottom:-1px;left:0;right:0;color:var(--color-sand)}@media(max-width:640px){.hero__title{font-size:2.5rem}.hero__subtitle{font-size:1.0625rem}}.features{padding:5rem 0}.features__title{text-align:center;font-size:2.25rem;margin-bottom:3rem;color:var(--color-gray-900)}.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{text-align:center;padding:2.5rem 2rem;background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal)}.feature-card:hover{box-shadow:var(--shadow-md)}.feature-card__icon{font-size:2.5rem;margin-bottom:1rem}.feature-card__title{font-family:var(--font-display);font-size:1.25rem;margin-bottom:.75rem;color:var(--color-gray-900)}.feature-card__desc{font-size:.9375rem;color:var(--color-gray-500);line-height:1.6}.page-section{padding:2rem 0}.page-section__title{font-size:2rem;margin-bottom:1.5rem}.species-detail{max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem}.species-detail__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem}.species-detail__title{font-family:var(--font-display);font-size:2.5rem;font-style:italic;color:var(--color-gray-900);margin-bottom:.25rem}.species-detail__common-name{font-size:1.125rem;color:var(--color-gray-500)}.species-detail__gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:2rem}.species-detail__gallery img{width:100%;height:280px;object-fit:cover;border-radius:var(--radius-lg)}.species-detail__gallery-placeholder{height:320px;background:linear-gradient(135deg,var(--color-primary-light),var(--color-secondary));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:5rem;color:var(--color-white)}.species-detail__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.species-detail__info-card{background:var(--color-white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.species-detail__info-label{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-400);margin-bottom:.375rem}.species-detail__info-value{font-size:1.0625rem;color:var(--color-gray-800);font-weight:500}.species-detail__tabs{display:flex;border-bottom:2px solid var(--color-gray-200);margin-bottom:1.5rem}.species-detail__tab{padding:.75rem 1.5rem;font-weight:600;color:var(--color-gray-500);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast)}.species-detail__tab:hover{color:var(--color-primary)}.species-detail__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.species-detail__content{background:var(--color-white);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);line-height:1.8;color:var(--color-gray-700);font-size:1.0625rem;margin-bottom:2rem}.species-detail__mini-map{height:350px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.map-page{display:flex;height:calc(100vh - var(--header-height))}.map-page__sidebar{width:var(--sidebar-width);background:var(--color-white);border-right:1px solid var(--color-gray-200);padding:1.5rem;overflow-y:auto;flex-shrink:0}.map-page__sidebar-title{font-family:var(--font-display);font-size:1.25rem;margin-bottom:1.25rem;color:var(--color-gray-900)}.map-page__map{flex:1}.map-page__map .leaflet-container{width:100%;height:100%}@media(max-width:768px){.map-page{flex-direction:column}.map-page__sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--color-gray-200)}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height) - 80px);padding:2rem 1.5rem}.auth-card{width:100%;max-width:440px;background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2.5rem}.auth-card__title{font-family:var(--font-display);font-size:1.75rem;text-align:center;margin-bottom:.5rem;color:var(--color-gray-900)}.auth-card__subtitle{text-align:center;color:var(--color-gray-500);margin-bottom:2rem;font-size:.9375rem}.auth-card__footer{text-align:center;margin-top:1.5rem;font-size:.9375rem;color:var(--color-gray-500)}.profile-page{max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem}.profile-page__title{font-family:var(--font-display);font-size:2rem;margin-bottom:1.5rem}.profile-tabs{display:flex;border-bottom:2px solid var(--color-gray-200);margin-bottom:2rem}.profile-tabs__tab{padding:.75rem 1.5rem;font-weight:600;color:var(--color-gray-500);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast)}.profile-tabs__tab:hover{color:var(--color-primary)}.profile-tabs__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.sighting-list{display:flex;flex-direction:column;gap:1rem}.sighting-item{background:var(--color-white);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1rem}.sighting-item__info{flex:1}.sighting-item__species{font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--color-gray-900);margin-bottom:.25rem}.sighting-item__meta{font-size:.875rem;color:var(--color-gray-500)}.spinner{display:inline-block;width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner--sm{width:20px;height:20px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;padding:4rem 0}.error-message{background:var(--color-danger-light);border:1px solid #fecaca;border-radius:var(--radius-md);padding:1rem 1.25rem;color:var(--color-danger);font-size:.9375rem;margin-bottom:1rem}.success-message{background:var(--color-success-light);border:1px solid #bbf7d0;border-radius:var(--radius-md);padding:1rem 1.25rem;color:var(--color-success);font-size:.9375rem;margin-bottom:1rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--color-gray-400)}.empty-state__icon{font-size:3rem;margin-bottom:1rem}.empty-state__text{font-size:1.125rem}.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-content{margin:1rem 1.25rem!important;font-family:var(--font-sans)!important;font-size:.9375rem!important;line-height:1.5!important}.sighting-popup__species{font-family:var(--font-display);font-style:italic;font-weight:600;font-size:1rem;margin-bottom:.375rem;color:var(--color-gray-900)}.sighting-popup__detail{font-size:.8125rem;color:var(--color-gray-500);margin-bottom:.25rem}.sighting-popup__link{display:inline-block;margin-top:.5rem;font-size:.8125rem;font-weight:600;color:var(--color-primary)}.marker-cluster-small{background-color:#48cae466!important}.marker-cluster-small div{background-color:var(--color-secondary)!important;color:var(--color-white)!important;font-weight:600!important}.marker-cluster-medium{background-color:#0077b666!important}.marker-cluster-medium div{background-color:var(--color-primary)!important;color:var(--color-white)!important;font-weight:600!important}.marker-cluster-large{background-color:#023e8a66!important}.marker-cluster-large div{background-color:#023e8a!important;color:var(--color-white)!important;font-weight:600!important}
