.home-page{color:#444;background-color:#fafafa;font-family:sans-serif}.hero{color:#fff;text-align:center;background:linear-gradient(135deg,#0f6e56 0%,#1d9e75 100%);padding:60px 20px;position:relative;overflow:hidden}.hero:before{content:"";filter:brightness(.45)saturate(1.15);z-index:0;background-image:url(https://images.unsplash.com/photo-1601758174114-e711c0cbaa69?w=1400&h=700&fit=crop);background-position:50% 40%;background-size:cover;position:absolute;inset:0}.hero>*{z-index:1;position:relative}.hero h1{text-shadow:0 2px 14px #0006;margin-bottom:16px;font-size:1.7rem;font-weight:700;line-height:1.3}.hero p{opacity:.9;margin:0 auto 28px;font-size:1rem;line-height:1.6}.hero-buttons{flex-direction:column;align-items:center;gap:10px;display:flex}.btn-white{color:#0f6e56;text-align:center;background:#fff;border-radius:8px;width:100%;max-width:280px;padding:12px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:opacity .2s}.btn-white:hover{opacity:.85}.btn-outline-white{color:#fff;text-align:center;background:0 0;border:2px solid #fff;border-radius:8px;width:100%;max-width:280px;padding:12px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s}.btn-outline-white:hover{background:#ffffff26}.stats{background:#fff;border-bottom:1px solid #e5e7eb;grid-template-columns:repeat(3,1fr);gap:16px;padding:32px 20px;display:grid}.stat-card{text-align:center;padding:8px 0}.stat-number{color:#1d9e75;font-size:1.8rem;font-weight:700}.stat-label{color:#888;margin-top:4px;font-size:13px}.how-it-works{text-align:center;padding:48px 20px}.how-it-works h2{color:#111;margin-bottom:8px;font-size:1.5rem;font-weight:700}.section-subtitle{color:#888;margin-bottom:32px;font-size:14px}.steps{flex-direction:column;gap:16px;display:flex}.step-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px 20px}.step-icon{margin-bottom:12px;font-size:2rem}.step-card h3{color:#111;margin-bottom:8px;font-size:15px;font-weight:600}.step-card p{color:#888;font-size:14px;line-height:1.6}.why-us{text-align:center;background:#e1f5ee;padding:48px 20px}.why-us h2{color:#111;margin-bottom:8px;font-size:1.5rem;font-weight:700}.benefits{flex-direction:column;gap:14px;margin-top:32px;display:flex}.benefit-item{text-align:left;background:#fff;border-radius:10px;padding:20px}.benefit-icon{margin-bottom:10px;font-size:1.6rem}.benefit-item h4{color:#111;margin-bottom:6px;font-size:15px;font-weight:600}.benefit-item p{color:#888;font-size:13px;line-height:1.5}.cta-section{color:#fff;text-align:center;background:linear-gradient(135deg,#1d9e75 0%,#0a5c45 100%);padding:48px 20px}.cta-section h2{margin-bottom:12px;font-size:1.5rem;font-weight:700}.cta-section p{opacity:.85;margin-bottom:24px;font-size:14px;line-height:1.6}.btn-green{color:#0f6e56;background:#fff;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:opacity .2s;display:inline-block}.btn-green:hover{opacity:.88}.footer{text-align:center;color:#aaa;background:#fff;border-top:1px solid #e5e7eb;padding:20px;font-size:13px}@media (width>=640px){.hero{padding:100px 40px}.hero h1{font-size:2.6rem}.hero p{max-width:520px;font-size:1.1rem}.hero-buttons{flex-direction:row;justify-content:center}.btn-white,.btn-outline-white{width:auto}.stats{grid-template-columns:repeat(3,1fr);gap:24px;max-width:700px;margin-left:auto;margin-right:auto;padding:40px}.stat-number{font-size:2.2rem}.how-it-works{max-width:900px;margin:0 auto;padding:72px 40px}.how-it-works h2{font-size:2rem}.section-subtitle{margin-bottom:40px;font-size:15px}.steps{flex-direction:row;justify-content:center;gap:24px}.step-card{flex:1;max-width:260px}.why-us{padding:72px 40px}.why-us h2{font-size:2rem}.benefits{flex-direction:row;justify-content:center;gap:20px;max-width:860px;margin:32px auto 0}.benefit-item{flex:1;max-width:260px}.cta-section{padding:80px 40px}.cta-section h2{font-size:2rem}.cta-section p{margin-bottom:32px;font-size:16px}}.animaux-page{background:#fafafa;min-height:100vh;font-family:sans-serif}.animaux-header{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:160px;padding:40px 20px 32px;display:flex;position:relative;overflow:hidden}.animaux-header:before{content:"";filter:brightness(.55)saturate(1.1);z-index:0;background-image:url(https://images.unsplash.com/photo-1576201836106-db1758fd1c97?w=1400&h=400&fit=crop);background-position:50% 55%;background-size:cover;position:absolute;inset:0}.animaux-header>*{z-index:2;position:relative}.animaux-header h1{text-shadow:0 2px 12px #00000059;letter-spacing:-.3px;margin-bottom:10px;font-size:1.9rem;font-weight:800}.animaux-header p{opacity:.92;text-shadow:0 1px 6px #0000004d;font-size:15px}.animaux-filtres{background:#fff;border-bottom:1px solid #f0f0f0;flex-direction:column;gap:12px;padding:16px;display:flex}.animaux-container{padding:16px}.animaux-grille{grid-template-columns:1fr;gap:16px;display:grid}.animal-card{color:inherit;cursor:pointer;background:#fff;border:1px solid #f0f0f0;border-radius:14px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden;box-shadow:0 2px 8px #0000000d}.animal-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.animal-photo-wrapper{position:relative}.animal-photo{object-fit:cover;width:100%;height:200px;display:block}.animal-statut{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:10px;right:10px}.animal-infos{padding:16px}.animal-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.animal-nom{color:#111;font-size:1.15rem;font-weight:700}.animal-espece{font-size:1.3rem}.animal-race{color:#999;margin-bottom:10px;font-size:13px}.animal-description{color:#555;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:14px;font-size:14px;line-height:1.55;display:-webkit-box;overflow:hidden}.animal-footer{justify-content:space-between;align-items:center;gap:8px;display:flex}.animal-asso{color:#aaa;font-size:12px}.animal-btn{color:#1d9e75;white-space:nowrap;background:#edf9f4;border:1px solid #9fe1cb;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.animal-btn:hover{background:#d4f2e7}@media (width>=640px){.animaux-header{min-height:200px;padding:52px 40px 44px}.animaux-header h1{font-size:2.6rem}.animaux-filtres{flex-flow:wrap;align-items:center;padding:16px 32px}.recherche-input{width:260px}.animaux-container{max-width:1200px;margin:0 auto;padding:24px 32px}.animaux-grille{grid-template-columns:repeat(2,1fr);gap:20px}}@media (width>=960px){.animaux-grille{grid-template-columns:repeat(3,1fr)}}.associations-page{background:#fafafa;min-height:100vh;font-family:sans-serif}.associations-header{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:160px;padding:40px 20px 32px;display:flex;position:relative;overflow:hidden}.associations-header:before{content:"";filter:brightness(.5)saturate(1.1);z-index:0;background-image:url(https://images.unsplash.com/photo-1560807707-8cc77767d783?w=1400&h=400&fit=crop);background-position:50% 40%;background-size:cover;position:absolute;inset:0}.associations-header>*{z-index:2;position:relative}.associations-header h1{text-shadow:0 2px 12px #00000059;letter-spacing:-.3px;margin-bottom:10px;font-size:1.9rem;font-weight:800}.associations-header p{opacity:.92;text-shadow:0 1px 6px #0000004d;font-size:15px}.associations-filtres{background:#fff;border-bottom:1px solid #f0f0f0;flex-direction:column;gap:12px;padding:16px;display:flex}.recherche-input{color:#333;box-sizing:border-box;border:1px solid #e5e5e5;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .2s}.recherche-input:focus{border-color:#1d9e75}.filtres-groupe{flex-wrap:wrap;gap:8px;display:flex}.filtre-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #e5e5e5;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s}.filtre-btn:hover{color:#1d9e75;border-color:#1d9e75}.filtre-btn.actif{color:#fff;background:#1d9e75;border-color:#1d9e75}.associations-container{padding:16px}.aucun-resultat{text-align:center;color:#aaa;padding:60px 20px}.aucun-resultat-icon{margin-bottom:12px;font-size:2.5rem}.aucun-resultat p{font-size:15px}.associations-grille{grid-template-columns:1fr;gap:16px;display:grid}.asso-card{color:inherit;cursor:pointer;background:#fff;border:1px solid #f0f0f0;border-radius:14px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden;box-shadow:0 2px 8px #0000000d}.asso-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.asso-photo-wrapper{position:relative}.asso-photo{object-fit:cover;width:100%;height:180px;display:block}.asso-photo-placeholder{background:linear-gradient(135deg,#1d9e75 0%,#0f6e56 100%);justify-content:center;align-items:center;width:100%;height:180px;font-size:48px;display:flex}.asso-dept{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:10px;right:10px}.asso-infos{padding:16px}.asso-nom{color:#111;margin-bottom:6px;font-size:1.1rem;font-weight:700}.asso-ville{color:#999;margin-bottom:10px;font-size:13px}.asso-description{color:#555;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:14px;font-size:14px;line-height:1.55;display:-webkit-box;overflow:hidden}.asso-stats{gap:12px;margin-bottom:14px;display:flex}.asso-stat{color:#777;background:#f6f6f6;border-radius:8px;align-items:center;gap:4px;padding:4px 10px;font-size:13px;display:flex}.asso-footer{justify-content:space-between;align-items:center;gap:8px;display:flex}.asso-contact{color:#aaa;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.asso-btn{color:#1d9e75;white-space:nowrap;background:#edf9f4;border:1px solid #9fe1cb;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.asso-btn:hover{background:#d4f2e7}@media (width>=640px){.associations-header{min-height:200px;padding:52px 40px 44px}.associations-header h1{font-size:2.6rem}.associations-filtres{flex-flow:wrap;align-items:center;padding:16px 32px}.recherche-input{width:260px}.associations-container{max-width:1200px;margin:0 auto;padding:24px 32px}.associations-grille{grid-template-columns:repeat(2,1fr);gap:20px}}@media (width>=960px){.associations-grille{grid-template-columns:repeat(3,1fr)}}.detail-page{background:#fafafa;min-height:100vh;font-family:sans-serif}.detail-header{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:180px;padding:40px 20px 32px;display:flex;position:relative;overflow:hidden}.detail-header:before{content:"";filter:brightness(.45)saturate(1.1);z-index:0;background-position:50% 40%;background-size:cover;position:absolute;inset:0}.detail-header-placeholder{background:linear-gradient(135deg,#1d9e75 0%,#0f6e56 100%)}.detail-header>*{z-index:2;position:relative}.detail-header h1{text-shadow:0 2px 12px #0006;margin-bottom:8px;font-size:1.8rem;font-weight:800}.detail-header-btn-logout{color:#fff;cursor:pointer;background:#ef444433;border:1.5px solid #fff6;border-radius:10px;padding:7px 18px;font-size:14px;font-weight:600;transition:background .2s;position:absolute;top:16px;right:16px}.detail-header-btn-logout:hover{background:#ef444473}.detail-region-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border:1px solid #fff6;border-radius:20px;padding:4px 14px;font-size:13px;font-weight:500;display:inline-block}.detail-infos{background:#fff;border-bottom:1px solid #f0f0f0;padding:20px 16px}.detail-infos-inner{max-width:900px;margin:0 auto}.detail-description{color:#555;margin-bottom:16px;font-size:15px;line-height:1.7}.detail-meta{flex-wrap:wrap;gap:10px;display:flex}.detail-meta-item{color:#666;background:#f6f6f6;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:flex}.detail-animaux{max-width:1200px;margin:0 auto;padding:24px 16px}.detail-animaux h2{color:#111;margin-bottom:4px;font-size:1.3rem;font-weight:700}.detail-animaux-subtitle{color:#aaa;margin-bottom:20px;font-size:14px}.detail-animaux-grille{grid-template-columns:1fr;gap:16px;display:grid}.detail-animal-card{background:#fff;border:1px solid #f0f0f0;border-radius:14px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 2px 8px #0000000d}.detail-animal-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.detail-animal-photo-wrapper{position:relative}.detail-animal-photo{object-fit:cover;width:100%;height:180px;display:block}.detail-animal-statut{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:10px;right:10px}.statut-dispo{color:#0f6e56;background:#edf9f4;border:1px solid #9fe1cb}.statut-accueil{color:#b07800;background:#fff8e6;border:1px solid #fcd97a}.detail-animal-infos{padding:14px}.detail-animal-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.detail-animal-nom{color:#111;font-size:1.05rem;font-weight:700}.detail-animal-espece{font-size:1.2rem}.detail-animal-race{color:#999;margin-bottom:8px;font-size:13px}.detail-animal-description{color:#555;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:14px;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}.btn-demande{color:#fff;cursor:pointer;background:#1d9e75;border:none;border-radius:10px;width:100%;padding:10px;font-size:14px;font-weight:600;transition:background .15s}.btn-demande:hover{background:#0f6e56}.demande-locked{color:#888;background:#f6f6f6;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;display:flex}.demande-locked a{color:#1d9e75;white-space:nowrap;font-weight:600;text-decoration:none}.demande-locked a:hover{text-decoration:underline}.demande-statut-benevole{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.offre-statut-mini{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.btn-demande-annuler-mini{color:#92400e;cursor:pointer;background:0 0;border:1.5px solid #f59e0b;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600;transition:background .15s}.btn-demande-annuler-mini:hover{background:#fef3c7}.btn-demande-annuler-mini:disabled{opacity:.6;cursor:not-allowed}.detail-demandes{border-top:1px solid #f0f0f0;max-width:1200px;margin:0 auto;padding:8px 16px 40px}.detail-demandes-header{align-items:center;gap:12px;margin-bottom:6px;display:flex}.detail-demandes-header h2{color:#111;margin:0;font-size:1.3rem;font-weight:700}.detail-demandes-badge{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.detail-demandes-liste{flex-direction:column;gap:12px;margin-top:8px;display:flex}.detail-demande-item{background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;align-items:center;gap:14px;padding:14px;display:flex;box-shadow:0 2px 8px #0000000a}.detail-demande-photo{object-fit:cover;border-radius:10px;flex-shrink:0;width:64px;height:64px}.detail-demande-infos{flex:1;min-width:0}.detail-demande-benevole{color:#111;margin:0 0 4px;font-size:15px;font-weight:700}.detail-demande-meta{color:#777;margin:1px 0;font-size:12px}.detail-demande-animal{color:#555;margin-top:6px;font-size:13px}.detail-demande-animal a{color:#1d9e75;font-weight:600;text-decoration:none}.detail-demande-animal a:hover{text-decoration:underline}.detail-demande-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.offre-statut{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.detail-demande-btns{gap:8px;display:flex}.btn-accepter{color:#fff;cursor:pointer;background:#1d9e75;border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s}.btn-accepter:hover{background:#0f6e56}.btn-accepter:disabled{opacity:.6;cursor:not-allowed}.btn-refuser{color:#991b1b;cursor:pointer;background:0 0;border:1.5px solid #fca5a5;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s}.btn-refuser:hover{background:#fef2f2}.btn-refuser:disabled{opacity:.6;cursor:not-allowed}.detail-not-found{text-align:center;color:#aaa;padding:80px 20px;font-size:15px}.detail-not-found a{color:#1d9e75;font-weight:600;text-decoration:none}@media (width>=640px){.detail-header{min-height:220px;padding:52px 40px 44px}.detail-header h1{font-size:2.4rem}.detail-infos{padding:24px 32px}.detail-animaux{padding:32px}.detail-animaux-grille{grid-template-columns:repeat(2,1fr);gap:20px}.detail-demandes{padding:24px 32px 48px}}@media (width>=960px){.detail-animaux-grille{grid-template-columns:repeat(3,1fr)}}.animal-detail-page{background:#fafafa;min-height:100vh;font-family:sans-serif}.animal-gallery{background:#111;width:100%;height:280px;position:relative;overflow:hidden}.animal-gallery-main{object-fit:cover;width:100%;height:100%;display:block}.animal-gallery-statut{border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;position:absolute;top:14px;right:14px}.statut-a-placer{color:#0f6e56;background:#edf9f4;border:1px solid #9fe1cb}.statut-placement-en-cours{color:#b07800;background:#fff8e6;border:1px solid #fcd97a}.statut-place{color:#25c;background:#e8f0fe;border:1px solid #b3c5f5}.statut-adopte{color:#888;background:#f3f3f3;border:1px solid #ddd}.animal-gallery-thumbs{background:#111;gap:6px;padding:8px 12px;display:flex;overflow-x:auto}.animal-gallery-thumb{object-fit:cover;cursor:pointer;opacity:.65;border:2px solid #0000;border-radius:6px;flex-shrink:0;width:56px;height:56px;transition:opacity .15s,border-color .15s}.animal-gallery-thumb.active{opacity:1;border-color:#1d9e75}.animal-gallery-thumb:hover{opacity:1}.animal-detail-body{max-width:860px;margin:0 auto;padding:20px 16px}.animal-detail-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px;display:flex}.animal-detail-nom{color:#111;font-size:1.7rem;font-weight:800;line-height:1.2}.animal-detail-espece-icon{flex-shrink:0;font-size:1.8rem}.animal-detail-tags{flex-wrap:wrap;gap:8px;margin:12px 0 20px;display:flex}.animal-tag{color:#555;background:#fff;border:1px solid #e5e5e5;border-radius:20px;padding:5px 12px;font-size:13px;font-weight:500}.animal-detail-section{margin-bottom:24px}.animal-detail-section h2{color:#111;border-bottom:1px solid #f0f0f0;margin-bottom:10px;padding-bottom:8px;font-size:1rem;font-weight:700}.animal-detail-description{color:#555;font-size:15px;line-height:1.75}.animal-asso-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;align-items:center;gap:14px;padding:14px;text-decoration:none;transition:box-shadow .2s;display:flex}.animal-asso-card:hover{box-shadow:0 4px 16px #00000014}.animal-asso-logo{object-fit:cover;border-radius:10px;flex-shrink:0;width:48px;height:48px}.animal-asso-info{flex:1;min-width:0}.animal-asso-nom{color:#111;margin-bottom:2px;font-size:14px;font-weight:700}.animal-asso-region{color:#aaa;font-size:13px}.animal-asso-arrow{color:#ccc;flex-shrink:0;font-size:16px}.animal-detail-demande{background:#fff;border-top:1px solid #f0f0f0;margin-top:8px;padding:14px 16px;position:sticky;bottom:0}.btn-demande-full{color:#fff;cursor:pointer;text-align:center;background:#1d9e75;border:none;border-radius:12px;width:100%;padding:14px;font-size:15px;font-weight:700;transition:background .15s;display:block}.btn-demande-full:hover{background:#0f6e56}.btn-demande-full:disabled{opacity:.7;cursor:not-allowed}.demande-locked-full{color:#888;text-align:center;background:#f6f6f6;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;display:flex}.demande-locked-full a{color:#1d9e75;font-weight:600;text-decoration:none}.demande-locked-full a:hover{text-decoration:underline}.demande-unavailable{color:#aaa;text-align:center;background:#f6f6f6;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;display:flex}.demande-soumise{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;flex-direction:column;gap:10px;padding:14px;display:flex}.demande-soumise-texte{color:#92400e;font-size:14px;font-weight:500}.btn-demande-annuler{color:#92400e;cursor:pointer;background:0 0;border:1.5px solid #f59e0b;border-radius:8px;align-self:flex-start;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.btn-demande-annuler:hover{background:#fef3c7}.btn-demande-annuler:disabled{opacity:.6;cursor:not-allowed}.demande-acceptee{color:#166534;text-align:center;background:#f0fdf4;border:1px solid #86efac;border-radius:12px;justify-content:center;align-items:center;padding:14px;font-size:14px;font-weight:500;display:flex}.demande-refusee{color:#991b1b;text-align:center;background:#fef2f2;border:1px solid #fca5a5;border-radius:12px;justify-content:center;align-items:center;padding:14px;font-size:14px;font-weight:500;display:flex}.animal-not-found{text-align:center;color:#aaa;padding:80px 20px;font-size:15px}.animal-not-found a{color:#1d9e75;font-weight:600;text-decoration:none}@media (width>=640px){.animal-gallery-thumb{width:70px;height:70px}.animal-detail-nom{font-size:2rem}.animal-detail-demande{border-top:none;margin-top:0;padding:0;position:static}}@media (width>=860px){.animal-detail-page{background:#fafafa;padding:40px 32px}.animal-detail-card{background:#fff;border:1px solid #e5e5e5;border-radius:20px;grid-template-rows:1fr auto;grid-template-columns:400px 1fr;max-width:1000px;margin:0 auto;display:grid;overflow:hidden;box-shadow:0 8px 40px #00000014}.animal-gallery{grid-area:1/1/3;height:100%;min-height:480px}.animal-gallery-main{border-radius:0}.animal-detail-body{grid-area:1/2;padding:32px 28px 20px}.animal-detail-demande{border-top:1px solid #f0f0f0;grid-area:2/2;padding:16px 28px 28px}}.register-page{background:#fafafa;min-height:100vh;padding:32px 16px 60px;font-family:sans-serif}.register-inner{max-width:560px;margin:0 auto}.register-title{color:#111;text-align:center;margin-bottom:6px;font-size:1.6rem;font-weight:800}.register-subtitle{color:#999;text-align:center;margin-bottom:28px;font-size:14px}.register-type-choix{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;display:grid}.type-card{cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e5e5;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;transition:border-color .15s,box-shadow .15s;display:flex}.type-card:hover{border-color:#9fe1cb}.type-card.selected{background:#edf9f4;border-color:#1d9e75;box-shadow:0 0 0 3px #1d9e751a}.type-card-icon{font-size:2rem}.type-card-label{color:#111;font-size:14px;font-weight:700}.type-card-desc{color:#aaa;font-size:12px;line-height:1.4}.register-form{background:#fff;border:1px solid #e5e5e5;border-radius:16px;flex-direction:column;gap:16px;padding:24px 20px;display:flex}.form-section-title{color:#aaa;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f0f0f0;margin-bottom:4px;padding-bottom:8px;font-size:12px;font-weight:700}.form-group{flex-direction:column;gap:6px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-label{color:#444;font-size:13px;font-weight:600}.form-label span{color:#ccc;margin-left:4px;font-size:12px;font-weight:400}.form-input,.form-select,.form-textarea{color:#333;box-sizing:border-box;background:#fff;border:1px solid #e5e5e5;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1d9e75;box-shadow:0 0 0 3px #1d9e751a}.form-textarea{resize:vertical;min-height:90px;line-height:1.5}.form-select{cursor:pointer}.btn-register{color:#fff;cursor:pointer;background:#1d9e75;border:none;border-radius:12px;width:100%;margin-top:4px;padding:14px;font-size:15px;font-weight:700;transition:background .15s}.btn-register:hover{background:#0f6e56}.register-login-link{text-align:center;color:#999;margin-top:20px;font-size:13px}.register-login-link a{color:#1d9e75;font-weight:600;text-decoration:none}.register-login-link a:hover{text-decoration:underline}@media (width>=640px){.register-page{padding:52px 32px 80px}.register-title{font-size:2rem}.register-form{gap:20px;padding:32px 28px}}.profil-page{background:#f7f8fc;min-height:100vh;padding:40px 20px 80px}.profil-inner{flex-direction:column;gap:32px;max-width:960px;margin:0 auto;display:flex}.profil-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 2px 16px #00000012}.profil-card-header{background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);flex-wrap:wrap;align-items:center;gap:16px;padding:24px 20px 20px;display:flex}.profil-avatar{color:#fff;background:#ffffff40;border:3px solid #ffffff80;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:28px;font-weight:700;display:flex}.profil-card-header-info{flex:1}.profil-nom{color:#fff;margin:0 0 4px;font-size:26px;font-weight:700}.profil-role{color:#fffc;margin:0;font-size:14px}.profil-btn-edit{color:#fff;cursor:pointer;background:#fff3;border:1.5px solid #ffffff80;border-radius:10px;flex-shrink:0;padding:8px 20px;font-size:14px;font-weight:600;transition:background .2s}.profil-btn-edit:hover{background:#ffffff59}.profil-btn-logout{color:#fff;cursor:pointer;background:#ef444433;border:1.5px solid #fff6;border-radius:10px;flex-shrink:0;padding:8px 20px;font-size:14px;font-weight:600;transition:background .2s}.profil-btn-logout:hover{background:#ef444473}.profil-card-body{grid-template-columns:1fr;gap:14px;padding:20px;display:grid}.profil-info-group{flex-direction:column;gap:4px;display:flex}.profil-info-group.full{grid-column:1}.profil-info-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.profil-info-value{color:#1f2937;font-size:15px}.profil-info-value.empty{color:#d1d5db;font-style:italic}.profil-form{grid-template-columns:1fr;gap:14px;padding:20px;display:grid}.profil-form-group{flex-direction:column;gap:6px;display:flex}.profil-form-group.full{grid-column:1}.profil-form-label{color:#374151;font-size:13px;font-weight:600}.profil-form-input,.profil-form-textarea,.profil-form-select{color:#1f2937;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.profil-form-input:focus,.profil-form-textarea:focus,.profil-form-select:focus{background:#fff;border-color:#6366f1;outline:none}.profil-form-textarea{resize:vertical;min-height:80px}.profil-form-select{cursor:pointer}.profil-form-actions{grid-column:1;justify-content:flex-end;gap:12px;padding-top:4px;display:flex}.profil-btn-save{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s}.profil-btn-save:hover{background:#4f46e5}.profil-btn-save:disabled{opacity:.6;cursor:not-allowed}.profil-btn-cancel{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s}.profil-btn-cancel:hover{background:#e5e7eb}.profil-form-error{color:#ef4444;background:#fef2f2;border-radius:8px;grid-column:1/-1;padding:10px 14px;font-size:14px}.profil-animaux{background:#fff;border-radius:20px;padding:20px;box-shadow:0 2px 16px #00000012}.profil-animaux h2{color:#1f2937;margin:0 0 6px;font-size:20px;font-weight:700}.profil-animaux-subtitle{color:#6b7280;margin:0 0 24px;font-size:14px}.profil-animaux-empty{text-align:center;color:#9ca3af;padding:40px 0;font-size:15px}.profil-animaux-empty span{margin-bottom:12px;font-size:40px;display:block}.profil-animaux-grille{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.profil-animal-card{background:#fff;border:1.5px solid #f3f4f6;border-radius:14px;text-decoration:none;transition:box-shadow .2s,transform .2s;display:block;overflow:hidden}.profil-animal-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.profil-animal-photo-wrapper{aspect-ratio:4/3;position:relative;overflow:hidden}.profil-animal-photo{object-fit:cover;width:100%;height:100%}.profil-animal-statut{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;position:absolute;top:8px;right:8px}.statut-a-placer{color:#166534;background:#dcfce7}.statut-placement{color:#854d0e;background:#fef9c3}.statut-place{color:#1e40af;background:#dbeafe}.statut-adopte{color:#6b21a8;background:#f3e8ff}.profil-animal-infos{padding:12px 14px 14px}.profil-animal-nom{color:#1f2937;margin:0 0 4px;font-size:15px;font-weight:700}.profil-animal-meta{color:#6b7280;margin:0;font-size:12px}.profil-demandes{background:#fff;border-radius:20px;padding:20px;box-shadow:0 2px 16px #00000012}.profil-demandes-header{align-items:center;gap:12px;margin-bottom:6px;display:flex}.profil-demandes-header h2{color:#1f2937;margin:0;font-size:20px;font-weight:700}.profil-demandes-badge{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.profil-offres-liste{flex-direction:column;gap:12px;margin-top:4px;display:flex}.profil-offre-card{background:#f9fafb;border:1.5px solid #f3f4f6;border-radius:14px;align-items:center;gap:14px;padding:12px 14px;transition:box-shadow .15s;display:flex}.profil-offre-card:hover{box-shadow:0 4px 12px #00000012}.profil-offre-photo-link{flex-shrink:0}.profil-offre-photo{object-fit:cover;border-radius:10px;width:64px;height:64px}.profil-offre-infos{flex:1;min-width:0}.profil-offre-nom{color:#1f2937;margin-bottom:2px;font-size:15px;font-weight:700;text-decoration:none;display:block}.profil-offre-nom:hover{color:#6366f1}.profil-offre-meta{color:#6b7280;margin:0;font-size:12px}.profil-offre-droite{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.profil-offre-statut{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.profil-offre-btn-annuler{color:#92400e;cursor:pointer;background:0 0;border:1.5px solid #f59e0b;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:600;transition:background .15s}.profil-offre-btn-annuler:hover{background:#fef3c7}.profil-offre-btn-annuler:disabled{opacity:.6;cursor:not-allowed}.offre-statut-soumise{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.offre-statut-acceptee{color:#166534;background:#f0fdf4;border:1px solid #86efac}.offre-statut-refusee{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}.offre-statut-annulee{color:#6b7280;background:#f3f4f6;border:1px solid #d1d5db}@media (width>=640px){.profil-card-header{flex-wrap:nowrap;gap:24px;padding:36px 32px 24px}.profil-card-body{grid-template-columns:1fr 1fr;gap:20px 32px;padding:28px 32px}.profil-form{grid-template-columns:1fr 1fr;gap:16px 24px;padding:28px 32px}.profil-info-group.full,.profil-form-group.full,.profil-form-actions{grid-column:1/-1}.profil-animaux,.profil-demandes{padding:28px 32px}}.nav-spacer{height:70px}.navbar{z-index:100;background:#fff;border-bottom:1px solid #0000;transition:border-color .3s,box-shadow .3s;position:fixed;top:0;left:0;right:0}.navbar-scrolled{border-color:#f0f0f0;box-shadow:0 4px 24px #00000012}.nav-inner{justify-content:space-between;align-items:center;height:70px;padding:0 1.25rem;display:flex}.nav-brand{cursor:pointer;flex-shrink:0;align-items:center;gap:9px;text-decoration:none;display:flex}.nav-brand-icon{background:linear-gradient(135deg,#1d9e75 0%,#0a5c45 100%);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;transition:transform .2s;display:flex;box-shadow:0 3px 10px #1d9e7566}.nav-brand:hover .nav-brand-icon{transform:rotate(-8deg)scale(1.05)}.nav-brand-name{color:#111;letter-spacing:-.3px;font-size:15px;font-weight:700}.nav-brand-name span{color:#1d9e75}.nav-links,.nav-right{display:none}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:38px;height:38px;padding:0;transition:background .15s;display:flex}.hamburger:hover{background:#f5f5f5}.hamburger span{transform-origin:50%;background:#333;border-radius:4px;width:20px;height:2px;transition:transform .25s,opacity .25s,width .25s;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;width:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{background:#fff;border-top:1px solid #0000;max-height:0;transition:max-height .3s,padding .3s;overflow:hidden}.mobile-menu-open{border-color:#f0f0f0;max-height:400px;padding:10px 12px 16px}.mobile-link{color:#555;border-radius:10px;padding:11px 14px;font-size:15px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:block}.mobile-link:hover{color:#111;background:#f7f7f7}.mobile-link.active{color:#0f6e56;background:#edf9f4;font-weight:600}.mobile-divider{background:#f0f0f0;height:1px;margin:8px 4px}.mobile-auth{flex-direction:column;gap:8px;margin-top:4px;display:flex}.mobile-btn-ghost{text-align:center;color:#444;border:1px solid #e5e5e5;border-radius:10px;padding:10px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s;display:block}.mobile-btn-ghost:hover{background:#f7f7f7}.mobile-btn-pill{text-align:center;color:#fff;background:linear-gradient(135deg,#1d9e75,#0a5c45);border-radius:10px;padding:10px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s;display:block;box-shadow:0 3px 10px #1d9e7559}.mobile-btn-pill:hover{opacity:.9}@media (width>=640px){.nav-inner{grid-template-columns:1fr auto 1fr;padding:0 2.5rem;display:grid}.hamburger,.mobile-menu{display:none}.nav-brand{grid-column:1;justify-self:start}.nav-links{background:#f7f7f7;border-radius:12px;grid-column:2;align-items:center;gap:2px;padding:4px;display:flex}.nav-link{color:#666;white-space:nowrap;border-radius:9px;padding:6px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{color:#111;background:#fff;box-shadow:0 1px 4px #00000012}.nav-link.active{color:#0f6e56;background:#fff;font-weight:600;box-shadow:0 1px 4px #00000014}.nav-right{grid-column:3;justify-self:end;align-items:center;gap:8px;display:flex}.nav-btn-ghost{color:#444;white-space:nowrap;background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:7px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:border-color .15s,background .15s}.nav-btn-ghost:hover{background:#fafafa;border-color:#ccc}.nav-btn-pill{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#1d9e75,#0a5c45);border-radius:10px;padding:7px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s,box-shadow .15s;box-shadow:0 3px 10px #1d9e7559}.nav-btn-pill:hover{opacity:.9;box-shadow:0 4px 14px #1d9e7573}.nav-avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1d9e75,#0a5c45);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 3px 10px #1d9e7559}.nav-avatar:hover{transform:scale(1.08)}}
