/* ═══════════════════════════════════════
   LOFLINE — Styles principaux
   Élevage de Chats du Bengale
═══════════════════════════════════════ */


:root {
  --sand: #C9A87C; --sand-light: #E8D5B7; --sand-pale: #F5EDD8; --sand-bg: #FAF5EC;
  --amber: #D4820A; --amber-light: #F0A830;
  --dark: #1A1510; --dark-mid: #2D2218; --charcoal: #3D3228;
  --text: #2A1F12; --text-muted: #6B5A44; --white: #FEFCF8;
  --border: rgba(201,168,124,0.3); --green: #2A5C3F; --green-light: #A8D5B5;
  --red: #5C2A2A; --red-light: #D5A8A8;
}
*{margin:0;padding:0;box-sizing:border-box;} html{scroll-behavior:smooth;}
body{font-family:'Cormorant Garamond',serif;background:var(--sand-bg);color:var(--text);overflow-x:hidden;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(26,21,16,0.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(201,168,124,0.2);padding:0 40px;display:flex;align-items:center;justify-content:space-between;height:70px;}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;cursor:pointer;}
.nav-logo img{height:44px;width:44px;border-radius:50%;object-fit:cover;}
.nav-logo span{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--sand-light);letter-spacing:.1em;}
.nav-links{display:flex;align-items:center;gap:0;list-style:none;}
.nav-links a{color:rgba(232,213,183,.7);text-decoration:none;font-family:'Cormorant Garamond',serif;font-size:.8rem;font-weight:500;letter-spacing:.08em;padding:8px 16px;transition:color .3s;text-transform:uppercase;cursor:pointer;}
.nav-links a:hover{color:var(--amber-light);}
.nav-links a.active{color:var(--sand-light);}
.nav-admin-btn{border:1px solid rgba(201,168,124,.4)!important;color:var(--sand)!important;border-radius:3px;}
.nav-admin-btn:hover{background:var(--sand)!important;color:var(--dark)!important;}

/* BADGE CHATONS RESTANTS */
.nav-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--amber);color:var(--dark);font-size:.65rem;font-family:'Cinzel',serif;font-weight:700;margin-left:6px;vertical-align:middle;}

/* ── SECTIONS ── */
.page-section{display:none;} .page-section.active{display:block;}

/* ── HERO ── */
#accueil{padding-top:70px;}
.hero-wrap{background:linear-gradient(160deg,#1A1510 0%,#2D2218 40%,#3D3228 100%);position:relative;overflow:hidden;}
.hero-texture{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 70% 40%,rgba(201,168,124,.12),transparent 60%),radial-gradient(ellipse 40% 60% at 20% 80%,rgba(212,130,10,.08),transparent 50%);pointer-events:none;}
.hero-pattern{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9A87C' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;opacity:.5;}
.hero-content{display:flex;align-items:center;justify-content:space-between;min-height:calc(100vh - 70px);max-width:1200px;margin:0 auto;padding:60px 40px;gap:60px;position:relative;z-index:1;}
.hero-text{flex:1;}
.hero-badge{display:inline-block;border:1px solid rgba(201,168,124,.4);color:var(--sand);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;padding:6px 16px;margin-bottom:32px;font-family:'Cinzel',serif;animation:fadeInUp .8s ease both;}
.hero-title{font-family:'Cinzel',serif;font-size:clamp(3rem,6vw,5.5rem);color:var(--sand-light);line-height:1.05;font-weight:700;margin-bottom:8px;animation:fadeInUp .8s ease .1s both;}
.hero-subtitle{font-family:'Playfair Display',serif;font-size:clamp(1.2rem,2.5vw,1.8rem);color:var(--amber-light);font-style:italic;margin-bottom:32px;animation:fadeInUp .8s ease .2s both;}
.hero-desc{font-size:1.15rem;color:rgba(232,213,183,.7);line-height:1.8;max-width:500px;margin-bottom:48px;font-weight:300;animation:fadeInUp .8s ease .3s both;}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;animation:fadeInUp .8s ease .4s both;}
.hero-visual{flex:0 0 420px;display:flex;align-items:center;justify-content:center;animation:fadeInUp .8s ease .2s both;}
.hero-circle{width:380px;height:380px;border-radius:50%;background:radial-gradient(circle at 40% 35%,rgba(212,130,10,.15),rgba(201,168,124,.08),transparent 70%);border:1px solid rgba(201,168,124,.15);display:flex;align-items:center;justify-content:center;animation:pulse-ring 4s ease-in-out infinite;}
.hero-logo-img{width:300px;height:300px;border-radius:50%;object-fit:cover;filter:drop-shadow(0 20px 60px rgba(212,130,10,.3));}

/* ── SLIDESHOW ── */
.slideshow{position:relative;overflow:hidden;height:500px;background:var(--dark);}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;display:flex;align-items:center;justify-content:center;font-size:8rem;}
.slide.active{opacity:1;}
.slide-caption{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);text-align:center;color:var(--sand-light);}
.slide-caption h3{font-family:'Playfair Display',serif;font-size:1.6rem;font-style:italic;}
.slide-caption p{font-size:.85rem;color:rgba(232,213,183,.5);margin-top:4px;letter-spacing:.1em;font-family:'Cinzel',serif;text-transform:uppercase;}
.slide-dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px;}
.slide-dot{width:8px;height:8px;border-radius:50%;background:rgba(201,168,124,.3);border:none;cursor:pointer;transition:background .3s;}
.slide-dot.active{background:var(--amber);}
.slide-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 20px;pointer-events:none;}
.slide-arrow{pointer-events:all;background:rgba(26,21,16,.6);border:1px solid rgba(201,168,124,.3);color:var(--sand);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.slide-arrow:hover{background:var(--amber);color:var(--dark);}

/* ── STATS BAR ── */
.stats-bar{background:var(--dark);border-top:1px solid rgba(201,168,124,.15);border-bottom:1px solid rgba(201,168,124,.15);}
.stats-bar-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-around;padding:40px;}
.stat-item{text-align:center;}
.stat-num{font-family:'Cinzel',serif;font-size:2.2rem;color:var(--amber-light);font-weight:700;display:block;}
.stat-label{font-size:.8rem;color:rgba(232,213,183,.5);letter-spacing:.15em;text-transform:uppercase;margin-top:4px;}

/* ── COMPTEUR LIVE ── */
.live-counter{background:linear-gradient(135deg,var(--amber),#B56A08);padding:3px 12px;border-radius:20px;display:inline-flex;align-items:center;gap:6px;font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.1em;color:var(--dark);font-weight:700;}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--dark);animation:blink 1.5s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}

/* ── SECTION UTILS ── */
.section-inner{max-width:1200px;margin:0 auto;padding:100px 40px;}
.section-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:20px;}
.eyebrow-line{width:40px;height:1px;background:var(--amber);}
.eyebrow-text{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--amber);}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);color:var(--dark);line-height:1.2;margin-bottom:24px;}
.section-title span{color:var(--amber);font-style:italic;}

/* ── BTNs ── */
.btn-primary{background:var(--sand);color:var(--dark);border:none;padding:14px 36px;font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;}
.btn-primary:hover{background:var(--amber-light);transform:translateY(-2px);}
.btn-secondary{background:transparent;color:var(--sand-light);border:1px solid rgba(201,168,124,.4);padding:14px 36px;font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;}
.btn-secondary:hover{border-color:var(--sand);color:var(--sand);}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-text p{font-size:1.15rem;line-height:1.9;color:var(--text-muted);margin-bottom:20px;font-weight:300;}
.about-features{display:flex;flex-direction:column;gap:16px;margin-top:32px;}
.feature-item{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--white);border:1px solid var(--border);border-left:3px solid var(--amber);}
.feature-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px;}
.feature-title{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.1em;color:var(--dark);margin-bottom:4px;}
.feature-desc{font-size:.95rem;color:var(--text-muted);line-height:1.6;font-weight:300;}
.about-img-placeholder{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,#C9A87C22,#D4820A11);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:relative;overflow:hidden;}

/* ── TÉMOIGNAGES ── */
.testimonials-section{background:linear-gradient(135deg,#1A1510,#2D2218);padding:80px 0;}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:50px;}
.testimonial-card{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,124,.12);padding:32px;position:relative;}
.testimonial-card::before{content:'"';position:absolute;top:16px;right:20px;font-family:'Playfair Display',serif;font-size:4rem;color:rgba(201,168,124,.15);line-height:1;}
.testimonial-stars{color:var(--amber-light);font-size:1rem;margin-bottom:16px;letter-spacing:3px;}
.testimonial-text{color:rgba(232,213,183,.65);font-size:1rem;line-height:1.8;font-weight:300;margin-bottom:20px;font-style:italic;}
.testimonial-author{display:flex;align-items:center;gap:12px;border-top:1px solid rgba(201,168,124,.1);padding-top:16px;}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.testimonial-name{font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.1em;color:var(--sand-light);}
.testimonial-chaton{font-size:.8rem;color:rgba(201,168,124,.4);margin-top:2px;}

/* ── FAQ ── */
.faq-section{background:var(--sand-pale);}
.faq-list{display:flex;flex-direction:column;gap:2px;margin-top:50px;}
.faq-item{background:var(--white);border:1px solid var(--border);overflow:hidden;}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 28px;cursor:pointer;font-family:'Cinzel',serif;font-size:.85rem;letter-spacing:.05em;color:var(--dark);transition:background .2s;}
.faq-q:hover{background:var(--sand-pale);}
.faq-icon{color:var(--amber);font-size:1.2rem;transition:transform .3s;flex-shrink:0;margin-left:16px;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;}
.faq-a.open{max-height:300px;}
.faq-a-inner{padding:0 28px 22px;color:var(--text-muted);font-size:1rem;line-height:1.8;font-weight:300;}
.faq-item.open .faq-icon{transform:rotate(45deg);}

/* ── CHATS ── */
#chats{background:var(--dark);padding-top:70px;}
#chats .section-title{color:var(--sand-light);}
#chats .section-title span{color:var(--amber-light);}
.gender-tabs{display:flex;gap:0;margin-bottom:60px;border-bottom:1px solid rgba(201,168,124,.2);}
.tab-btn{background:none;border:none;font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(232,213,183,.4);padding:14px 32px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s;}
.tab-btn.active{color:var(--sand-light);border-color:var(--amber);}
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2px;}
.cat-card{background:var(--dark-mid);position:relative;overflow:hidden;cursor:pointer;transition:transform .3s;border:1px solid rgba(201,168,124,.08);}
.cat-card:hover{transform:scale(1.01);}
.cat-card:hover .cat-overlay{opacity:1;}
.cat-img-placeholder{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,#2D2218 0%,#3D3228 50%,#2D2218 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;font-size:4rem;color:rgba(201,168,124,.2);}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,21,16,.95) 0%,rgba(26,21,16,.4) 50%,transparent 100%);opacity:.7;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;}
.cat-name{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--sand-light);font-weight:700;}
.cat-breed{font-size:.8rem;letter-spacing:.1em;color:var(--amber-light);text-transform:uppercase;font-family:'Cinzel',serif;margin-top:4px;}
.cat-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.cat-tag{background:rgba(201,168,124,.15);border:1px solid rgba(201,168,124,.3);color:var(--sand-light);font-size:.7rem;padding:3px 10px;letter-spacing:.1em;}

/* ── PORTÉES ── */
.portees-section{background:rgba(0,0,0,.3);border-top:1px solid rgba(201,168,124,.1);padding:60px 0;}
.portees-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:40px;}
.portee-card{border:1px solid rgba(201,168,124,.12);padding:24px;position:relative;overflow:hidden;}
.portee-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--amber);}
.portee-status{display:inline-block;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;padding:3px 10px;margin-bottom:12px;}
.status-attendue{background:rgba(212,130,10,.15);color:var(--amber-light);}
.status-nee{background:rgba(42,92,63,.3);color:var(--green-light);}
.portee-parents{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--sand-light);margin-bottom:6px;}
.portee-date{font-size:.85rem;color:rgba(232,213,183,.45);font-family:'Cinzel',serif;letter-spacing:.05em;}
.portee-details{font-size:.9rem;color:rgba(232,213,183,.5);margin-top:10px;line-height:1.6;font-weight:300;}

/* ── CHATONS ── */
#chatons{background:var(--sand-pale);padding-top:70px;}
.chatons-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:50px;}
.chatons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;}
.chaton-card{background:var(--white);border:1px solid var(--border);overflow:hidden;transition:box-shadow .3s,transform .3s;position:relative;}
.chaton-card:hover{box-shadow:0 20px 60px rgba(201,168,124,.2);transform:translateY(-4px);}
.chaton-badge{position:absolute;top:16px;right:16px;z-index:2;padding:4px 12px;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;}
.badge-dispo{background:#2A5C3F;color:#A8D5B5;}
.badge-reserve{background:#5C2A2A;color:#D5A8A8;}
.chaton-img-wrap{width:100%;aspect-ratio:4/3;overflow:hidden;position:relative;cursor:pointer;}
.chaton-img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#E8D5B7,#F5EDD8);display:flex;align-items:center;justify-content:center;font-size:5rem;}
.chaton-body{padding:24px;}
.chaton-name{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--dark);font-weight:700;}
.chaton-meta{display:flex;gap:16px;margin:10px 0 16px;font-size:.85rem;color:var(--text-muted);}
.chaton-price{font-family:'Cinzel',serif;font-size:1.4rem;color:var(--amber);font-weight:700;margin-bottom:16px;}
.chaton-price small{font-size:.75rem;color:var(--text-muted);font-family:'Cormorant Garamond',serif;font-weight:400;margin-left:8px;}
.chaton-details{font-size:.9rem;color:var(--text-muted);line-height:1.7;margin-bottom:20px;font-weight:300;}
.chaton-actions{display:flex;gap:10px;}
.btn-chaton{flex:1;background:var(--dark);color:var(--sand-light);border:none;padding:13px;font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.btn-chaton:hover{background:var(--amber);color:var(--dark);}
.btn-chaton:disabled{background:#ccc;color:#999;cursor:not-allowed;}
.btn-fiche{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:13px 16px;font-family:'Cinzel',serif;font-size:.75rem;cursor:pointer;transition:all .3s;}
.btn-fiche:hover{border-color:var(--sand);color:var(--dark);}

/* ── PHOTOS ── */
#photos{background:var(--white);padding-top:70px;}
.photo-masonry{columns:3;column-gap:12px;}
.photo-item{break-inside:avoid;margin-bottom:12px;overflow:hidden;position:relative;cursor:pointer;}
.photo-item:hover .photo-hover{opacity:1;}
.photo-placeholder{width:100%;background:linear-gradient(135deg,#E8D5B7,#C9A87C22);display:flex;align-items:center;justify-content:center;font-size:3rem;color:rgba(201,168,124,.4);transition:transform .4s;}
.photo-item:hover .photo-placeholder{transform:scale(1.05);}
.photo-hover{position:absolute;inset:0;background:rgba(26,21,16,.5);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;color:white;font-size:1.5rem;gap:8px;}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(10,8,5,.97);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.lightbox.show{opacity:1;pointer-events:all;}
.lightbox-content{position:relative;max-width:80vw;max-height:80vh;text-align:center;}
.lightbox-img{width:400px;height:400px;background:linear-gradient(135deg,#2D2218,#3D3228);display:flex;align-items:center;justify-content:center;font-size:8rem;border:1px solid rgba(201,168,124,.1);}
.lightbox-caption{color:rgba(232,213,183,.6);font-size:.85rem;margin-top:12px;font-family:'Cinzel',serif;letter-spacing:.1em;}
.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:rgba(232,213,183,.5);font-size:1.5rem;cursor:pointer;transition:color .2s;}
.lightbox-close:hover{color:var(--sand);}
.lightbox-nav{display:flex;gap:12px;justify-content:center;margin-top:20px;}
.lb-btn{background:rgba(255,255,255,.05);border:1px solid rgba(201,168,124,.2);color:var(--sand);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.lb-btn:hover{background:var(--amber);color:var(--dark);}

/* ── CONTACT ── */
#contact{background:linear-gradient(160deg,#1A1510,#2D2218);padding-top:70px;}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start;}
.contact-info h3{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--sand-light);margin-bottom:24px;}
.contact-info p{color:rgba(232,213,183,.55);font-size:1rem;line-height:1.8;margin-bottom:32px;font-weight:300;}
.contact-detail{display:flex;align-items:center;gap:14px;margin-bottom:16px;color:rgba(232,213,183,.7);font-size:1rem;}
.contact-icon{width:36px;height:36px;border:1px solid rgba(201,168,124,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;}
.contact-form-wrap{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,124,.12);padding:40px;}
.contact-form-title{font-family:'Cinzel',serif;font-size:.85rem;letter-spacing:.15em;color:var(--sand);text-transform:uppercase;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid rgba(201,168,124,.1);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group.full{grid-column:1/-1;}
.form-group label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(232,213,183,.45);font-family:'Cinzel',serif;}
.form-control{background:rgba(255,255,255,.05);border:1px solid rgba(201,168,124,.2);color:var(--sand-light);padding:11px 14px;font-family:'Cormorant Garamond',serif;font-size:1rem;outline:none;transition:border-color .2s;width:100%;}
.form-control:focus{border-color:var(--amber);}
.form-control option{background:var(--dark-mid);}
textarea.form-control{resize:vertical;min-height:100px;}
.form-actions{display:flex;gap:12px;margin-top:20px;}
.btn-save{background:var(--sand);color:var(--dark);border:none;padding:12px 28px;font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.btn-save:hover{background:var(--amber-light);}
.btn-cancel{background:transparent;border:1px solid rgba(201,168,124,.2);color:rgba(232,213,183,.5);padding:12px 28px;font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.btn-cancel:hover{border-color:var(--sand);color:var(--sand);}

/* ── EMAIL NOTIFICATION POPUP ── */
.notif-popup{position:fixed;bottom:90px;right:30px;z-index:9998;width:320px;background:var(--dark-mid);border:1px solid rgba(201,168,124,.25);padding:20px;transform:translateX(380px);transition:transform .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 20px 60px rgba(0,0,0,.5);}
.notif-popup.show{transform:translateX(0);}
.notif-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.notif-icon{width:32px;height:32px;background:rgba(212,130,10,.2);border:1px solid rgba(212,130,10,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;}
.notif-title{font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.1em;color:var(--sand);text-transform:uppercase;}
.notif-body{font-size:.9rem;color:rgba(232,213,183,.6);line-height:1.6;font-weight:300;}
.notif-time{font-size:.75rem;color:rgba(201,168,124,.35);margin-top:8px;font-family:'Cinzel',serif;}
.notif-close{position:absolute;top:10px;right:12px;background:none;border:none;color:rgba(232,213,183,.3);cursor:pointer;font-size:.9rem;}

/* ── CHAT WIDGET ── */
.chat-widget{position:fixed;bottom:30px;right:30px;z-index:9997;}
.chat-bubble{width:56px;height:56px;border-radius:50%;background:var(--sand);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 8px 30px rgba(201,168,124,.4);transition:all .3s;}
.chat-bubble:hover{background:var(--amber-light);transform:scale(1.1);}
.chat-bubble .unread{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:#e74c3c;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:white;font-family:'Cinzel',serif;font-weight:700;}
.chat-window{position:absolute;bottom:68px;right:0;width:340px;height:480px;background:var(--dark-mid);border:1px solid rgba(201,168,124,.2);display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.5);transform-origin:bottom right;transform:scale(0);opacity:0;transition:all .3s cubic-bezier(.175,.885,.32,1.275);}
.chat-window.open{transform:scale(1);opacity:1;}
.chat-head{background:rgba(201,168,124,.1);border-bottom:1px solid rgba(201,168,124,.1);padding:16px 20px;display:flex;align-items:center;gap:12px;}
.chat-head-avatar{width:36px;height:36px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.chat-head-info .name{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.08em;color:var(--sand-light);}
.chat-head-info .online{font-size:.75rem;color:var(--green-light);display:flex;align-items:center;gap:5px;}
.chat-head-info .online::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green-light);display:inline-block;}
.chat-close{margin-left:auto;background:none;border:none;color:rgba(232,213,183,.4);cursor:pointer;font-size:1rem;transition:color .2s;}
.chat-close:hover{color:var(--sand);}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;}
.chat-messages::-webkit-scrollbar{width:4px;}
.chat-messages::-webkit-scrollbar-thumb{background:rgba(201,168,124,.2);border-radius:2px;}
.msg{max-width:80%;padding:10px 14px;font-size:.9rem;line-height:1.5;font-weight:300;}
.msg-in{background:rgba(201,168,124,.1);border:1px solid rgba(201,168,124,.1);color:rgba(232,213,183,.8);align-self:flex-start;border-radius:0 8px 8px 8px;}
.msg-out{background:var(--sand);color:var(--dark);align-self:flex-end;border-radius:8px 0 8px 8px;}
.msg-time{font-size:.65rem;color:rgba(201,168,124,.35);margin-top:4px;font-family:'Cinzel',serif;}
.chat-typing{display:none;align-self:flex-start;color:rgba(201,168,124,.5);font-size:.8rem;padding:8px 14px;background:rgba(201,168,124,.05);border-radius:0 8px 8px 8px;}
.chat-typing.show{display:block;}
.chat-input-wrap{padding:12px;border-top:1px solid rgba(201,168,124,.1);display:flex;gap:8px;}
.chat-input{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(201,168,124,.2);color:var(--sand-light);padding:10px 14px;font-family:'Cormorant Garamond',serif;font-size:.95rem;outline:none;}
.chat-input::placeholder{color:rgba(201,168,124,.3);}
.chat-send{background:var(--sand);border:none;color:var(--dark);padding:10px 14px;cursor:pointer;font-size:1rem;transition:background .2s;}
.chat-send:hover{background:var(--amber-light);}

/* ── ADMIN ── */
#admin{background:var(--dark);min-height:100vh;padding-top:70px;}
.login-screen{min-height:calc(100vh - 70px);background:var(--dark);display:flex;align-items:center;justify-content:center;}
.login-box{width:380px;background:rgba(255,255,255,.03);border:1px solid rgba(201,168,124,.2);padding:48px 40px;text-align:center;}
.login-logo{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--sand-light);margin-bottom:8px;letter-spacing:.12em;}
.login-sub{font-size:.8rem;color:rgba(201,168,124,.4);letter-spacing:.1em;margin-bottom:36px;}
.btn-login{width:100%;background:var(--sand);color:var(--dark);border:none;padding:13px;font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;margin-top:8px;}
.btn-login:hover{background:var(--amber-light);}
.login-err{color:#e74c3c;font-size:.85rem;margin-top:12px;min-height:20px;}
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 70px);}
.admin-sidebar{background:rgba(0,0,0,.4);border-right:1px solid rgba(201,168,124,.1);padding:40px 0;display:flex;flex-direction:column;}
.admin-sidebar-title{font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.2em;color:rgba(201,168,124,.4);text-transform:uppercase;padding:0 24px 16px;border-bottom:1px solid rgba(201,168,124,.1);margin-bottom:12px;}
.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;color:rgba(232,213,183,.5);cursor:pointer;transition:all .2s;font-size:.85rem;font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:.05em;border-right:2px solid transparent;}
.admin-nav-item:hover{background:rgba(201,168,124,.05);color:var(--sand);}
.admin-nav-item.active{background:rgba(201,168,124,.1);color:var(--sand-light);border-right-color:var(--amber);}
.admin-nav-icon{font-size:1rem;width:20px;}
.admin-main{padding:50px 60px;overflow-y:auto;}
.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid rgba(201,168,124,.15);}
.admin-panel{display:none;} .admin-panel.active{display:block;}
.admin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:40px;}
.admin-card{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,124,.12);padding:24px;}
.admin-card-num{font-family:'Cinzel',serif;font-size:2rem;color:var(--amber-light);font-weight:700;}
.admin-card-label{font-size:.75rem;color:rgba(232,213,183,.4);text-transform:uppercase;letter-spacing:.1em;margin-top:4px;}
.admin-form{background:rgba(255,255,255,.03);border:1px solid rgba(201,168,124,.12);padding:32px;margin-bottom:24px;}
.admin-form-title{font-family:'Cinzel',serif;font-size:.85rem;letter-spacing:.15em;color:var(--sand);text-transform:uppercase;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(201,168,124,.1);}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table th{text-align:left;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(201,168,124,.5);padding:12px 16px;border-bottom:1px solid rgba(201,168,124,.1);}
.admin-table td{padding:14px 16px;border-bottom:1px solid rgba(201,168,124,.06);color:rgba(232,213,183,.7);font-size:.95rem;}
.admin-table tr:hover td{background:rgba(201,168,124,.04);}
.table-actions{display:flex;gap:8px;}
.btn-icon{background:none;border:1px solid rgba(201,168,124,.15);color:rgba(232,213,183,.5);padding:5px 10px;cursor:pointer;font-size:.75rem;transition:all .2s;font-family:'Cinzel',serif;}
.btn-icon:hover{border-color:var(--amber);color:var(--amber-light);}
.btn-icon.danger:hover{border-color:#c0392b;color:#e74c3c;}

/* ── FICHE CHATON MODALE ── */
.modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(26,21,16,.97);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.modal-overlay.show{opacity:1;pointer-events:all;}
.modal{background:var(--dark-mid);border:1px solid rgba(201,168,124,.2);width:90%;max-width:680px;max-height:90vh;overflow-y:auto;transform:scale(.9);transition:transform .3s;}
.modal-overlay.show .modal{transform:scale(1);}
.modal-top{display:grid;grid-template-columns:220px 1fr;min-height:280px;}
.modal-img{background:linear-gradient(135deg,#2D2218,#3D3228);display:flex;align-items:center;justify-content:center;font-size:6rem;}
.modal-info{padding:32px;}
.modal-close-btn{position:absolute;top:16px;right:16px;background:rgba(26,21,16,.7);border:1px solid rgba(201,168,124,.2);color:var(--sand);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.modal-close-btn:hover{background:var(--amber);color:var(--dark);}
.modal-name{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--sand-light);font-weight:700;margin-bottom:4px;}
.modal-breed-tag{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.15em;color:var(--amber);text-transform:uppercase;margin-bottom:20px;}
.modal-specs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;}
.modal-spec{background:rgba(255,255,255,.03);border:1px solid rgba(201,168,124,.08);padding:12px;}
.modal-spec label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(201,168,124,.4);display:block;margin-bottom:4px;font-family:'Cinzel',serif;}
.modal-spec span{color:var(--sand-light);font-size:.95rem;}
.modal-body{padding:28px 32px 32px;border-top:1px solid rgba(201,168,124,.08);}
.modal-desc{color:rgba(232,213,183,.6);font-size:1rem;line-height:1.8;font-weight:300;margin-bottom:24px;}
.modal-price-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.modal-price{font-family:'Cinzel',serif;font-size:1.6rem;color:var(--amber);font-weight:700;}

/* ── CAT MODAL (reproducteurs) ── */
.cat-modal{max-width:520px;}
.cat-modal p{color:rgba(232,213,183,.6);font-size:1rem;line-height:1.8;font-weight:300;margin-bottom:20px;}
.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;}
.modal-info-item label{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(201,168,124,.4);display:block;margin-bottom:4px;font-family:'Cinzel',serif;}
.modal-info-item span{color:var(--sand-light);font-size:1rem;}

/* ── RÉSERVATION MODAL ── */
.reservation-modal{max-width:560px;}
.resa-step{display:none;} .resa-step.active{display:block;}
.resa-steps-indicator{display:flex;gap:0;margin-bottom:28px;}
.resa-step-dot{flex:1;height:3px;background:rgba(201,168,124,.15);position:relative;transition:background .4s;}
.resa-step-dot.done{background:var(--amber);}
.resa-step-dot.active{background:var(--sand);}
.resa-summary{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,124,.1);padding:16px 20px;margin-bottom:20px;}
.resa-summary-name{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--sand-light);}
.resa-summary-price{font-family:'Cinzel',serif;color:var(--amber);font-size:.9rem;margin-top:4px;}
.acompte-box{background:rgba(212,130,10,.08);border:1px solid rgba(212,130,10,.2);padding:16px 20px;margin:16px 0;}
.acompte-box p{color:rgba(232,213,183,.65);font-size:.9rem;line-height:1.7;font-weight:300;}
.acompte-montant{font-family:'Cinzel',serif;font-size:1.4rem;color:var(--amber-light);font-weight:700;display:block;margin-top:8px;}

/* ── FOOTER ── */
footer{background:var(--dark);border-top:1px solid rgba(201,168,124,.15);padding:60px 40px 30px;}
.footer-inner{max-width:1200px;margin:0 auto;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:50px;}
.footer-desc{font-size:.95rem;color:rgba(232,213,183,.4);line-height:1.8;font-weight:300;margin-top:16px;}
.footer-col-title{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sand);margin-bottom:20px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{color:rgba(232,213,183,.4);text-decoration:none;font-size:.9rem;transition:color .2s;cursor:pointer;}
.footer-links a:hover{color:var(--sand);}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(201,168,124,.1);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(232,213,183,.25);}

/* ── TOAST ── */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);z-index:99999;background:var(--dark);border:1px solid var(--amber);color:var(--sand-light);padding:14px 28px;font-family:'Cormorant Garamond',serif;font-size:1rem;opacity:0;transition:all .4s;white-space:nowrap;}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;}

/* ── PERSO TABS ── */
.perso-panel{display:none;} .perso-panel.active{display:block;}
.perso-tab{
  background:none;border:none;border-bottom:2px solid transparent;
  color:rgba(232,213,183,.4);font-family:'Cinzel',serif;font-size:.75rem;
  letter-spacing:.12em;text-transform:uppercase;padding:12px 20px;
  cursor:pointer;margin-bottom:-1px;transition:all .2s;
}
.perso-tab:hover{color:var(--sand);}
.perso-tab.active{color:var(--sand-light);border-bottom-color:var(--amber);}

/* Color picker */
.color-pick{width:36px;height:36px;border:1px solid rgba(201,168,124,.2);background:none;cursor:pointer;padding:2px;border-radius:2px;}
.color-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.color-row label{font-size:.78rem;color:rgba(232,213,183,.5);font-family:'Cormorant Garamond',serif;}
.color-hex{font-family:'Cinzel',serif;font-size:.7rem;color:rgba(201,168,124,.5);min-width:60px;}

/* Toggle switch */
.toggle-track{width:40px;height:22px;border-radius:11px;background:rgba(201,168,124,.2);border:1px solid rgba(201,168,124,.2);position:relative;cursor:pointer;transition:background .3s;}
.toggle-track.on{background:var(--amber);border-color:var(--amber);}
.toggle-track::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:white;top:2px;left:2px;transition:transform .3s;}
.toggle-track.on::after{transform:translateX(18px);}

/* ── ANIMATIONS ── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
@keyframes pulse-ring{0%,100%{box-shadow:0 0 0 0 rgba(201,168,124,.1);}50%{box-shadow:0 0 0 20px rgba(201,168,124,0);}}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-content{flex-direction:column;text-align:center;}
  .hero-visual{flex:none;}
  .about-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .admin-layout{grid-template-columns:1fr;}
  .admin-sidebar{display:none;}
  .photo-masonry{columns:2;}
  .form-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .modal-top{grid-template-columns:1fr;}
}
