/* =========================================================================
 * DOGGYKAT CRM — Feuille de style application
 * Charte couleurs DoggyKat
 * ========================================================================= */

*{margin:0;padding:0;box-sizing:border-box;}

/* ── VARIABLES — uniquement les couleurs de la charte DoggyKat ───────── */
:root{
  /* Charte officielle DoggyKat */
  --beige:   #E1BEA4;
  --beige-2: #F0EDE8;
  --gris:    #66605a;
  --gris-2:  #BABBBC;
  --rouge:   #A60209;
  --noir:    #000000;
  --blanc:   #FFFFFF;
  --vert:    #198754;

  /* Dérivés calculés depuis la charte — pas de couleur hors-charte */
  --beige-3: #FAF7F4;          /* beige très clair pour fonds de ligne */
  --gris-3:  #F4F2EE;          /* gris très clair pour badges neutres  */
  --vert-2:  #e8f5ee;          /* vert très clair pour badges succès   */
  --orange:  #d97706;          /* alerte — ton chaud proche du beige   */
  --orange-2:#fef3c7;          /* fond alerte clair                    */

  --radius: 14px;
  --shadow: 0 2px 12px rgba(0,0,0,.07);
}

html,body{
  font-family: Calibri,'Candara','Segoe UI','Helvetica Neue',Helvetica,Arial,sans-serif;
  background: linear-gradient(rgba(255,255,255,.55),rgba(255,255,255,.55)),
              url('img/fond_body.webp') center/cover no-repeat fixed;
  color: var(--gris);
  min-height: 100vh;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
body::-webkit-scrollbar{display:none;}

/* ── LAYOUT ────────────────────────────────────────────────────────────── */
.app-shell{display:flex;min-height:100vh;}

/* Sidebar */
.sidebar{
  width:230px;flex-shrink:0;
  background:var(--blanc);
  border-right:1px solid var(--beige);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;
  box-shadow:2px 0 8px rgba(0,0,0,.06);
  z-index:100;
  transition:transform .3s;
}
.sidebar-logo{
  padding:20px 16px 16px;
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--beige-2);
}
.sidebar-logo img{height:80px;width:80px;object-fit:contain;}
.sidebar-logo span{font-weight:700;font-variant:small-caps;font-size:18px;color:var(--gris);}

.nav-menu{flex:1;padding:12px 8px;overflow-y:auto;}
.nav-section-title{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--gris-2);padding:12px 10px 4px;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;margin-bottom:2px;
  text-decoration:none;color:var(--gris);font-size:14px;font-weight:600;
  transition:background .15s,color .15s;cursor:pointer;
}
.nav-item:hover{background:var(--beige-2);color:var(--gris);}
.nav-item.active{background:var(--beige);color:var(--blanc);}
.nav-item.active .nav-icon{filter:brightness(10);}
.nav-icon{width:18px;height:18px;flex-shrink:0;font-size:16px;text-align:center;}
.nav-badge{margin-left:auto;background:var(--rouge);color:#fff;border-radius:10px;font-size:10px;padding:1px 6px;font-weight:700;}

.sidebar-footer{
  padding:14px 12px;border-top:1px solid var(--beige-2);
  font-size:12px;color:var(--gris-2);text-align:center;
}

/* Main */
.main-content{
  margin-left:230px;flex:1;
  display:flex;flex-direction:column;min-height:100vh;
}

/* Topbar */
.topbar{
  background:var(--beige);border-bottom:1px solid var(--beige);
  padding:0 28px;height:56px;
  display:grid;grid-template-columns:44px 1fr auto;align-items:center;
  position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  gap:8px;
}
@keyframes ticker{
  0%   { transform:translateX(110%); }
  100% { transform:translateX(-110%); }
}
.topbar-title{
  font-size:18px;font-weight:700;font-variant:small-caps;color:var(--blanc);
  white-space:nowrap;display:inline-block;
  animation:ticker 8s linear infinite;
}
.topbar-title.paused{
  animation-play-state:paused;
}
.topbar-actions{display:flex;align-items:center;gap:12px;color:var(--blanc);}
.topbar-actions span{color:var(--blanc)!important;}

/* Page content */
.page{display:none;padding:24px 28px;flex:1;}
.page.active{display:block;}

/* ── BOUTONS ──────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:10px;border:none;
  font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;
  transition:opacity .15s,transform .1s;text-decoration:none;
}
.btn:hover{opacity:.88;transform:translateY(-1px);}
.btn:active{transform:translateY(0);}
.btn-primary  {background:var(--beige);color:var(--blanc);}
.btn-secondary{background:var(--beige-2);color:var(--gris);border:1px solid var(--beige);}
.btn-danger   {background:#fee2e2;color:var(--rouge);}
.btn-success  {background:var(--vert-2);color:var(--vert);}
.btn-sm{padding:5px 10px;font-size:12px;border-radius:7px;}

/* ── CARDS ────────────────────────────────────────────────────────────── */
.card{
  background:var(--blanc);border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--beige-2);
  padding:20px;margin-bottom:20px;
}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid var(--beige-2);
}
.card-title{font-size:15px;font-weight:700;font-variant:small-caps;color:var(--gris);}

/* ── STAT CARDS (dashboard) ─────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.stat-card{
  background:var(--blanc);border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--beige-2);
  padding:18px 20px;display:flex;align-items:center;gap:14px;
}
.stat-icon{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;
}
.stat-icon.beige {background:var(--beige-2);}
.stat-icon.vert  {background:var(--vert-2);}
.stat-icon.rouge {background:#fee2e2;}
.stat-icon.orange{background:var(--orange-2);}
.stat-value{font-size:26px;font-weight:700;color:var(--gris);line-height:1;}
.stat-label{font-size:12px;color:var(--gris-2);margin-top:3px;}

/* ── TABLES ───────────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead tr{background:var(--beige);color:var(--blanc);}
thead th{padding:10px 14px;text-align:left;font-weight:700;font-variant:small-caps;font-size:13px;}
thead th:first-child{border-radius:8px 0 0 8px;}
thead th:last-child {border-radius:0 8px 8px 0;}
tbody tr{border-bottom:1px solid var(--beige-2);transition:background .1s;}
tbody tr:hover{background:var(--beige-3);}
tbody tr:last-child{border-bottom:none;}
td{padding:10px 14px;vertical-align:middle;}

/* ── BADGES ───────────────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;
}
.badge-green {background:var(--vert-2);color:var(--vert);}
.badge-red   {background:#fee2e2;color:var(--rouge);}
.badge-orange{background:var(--orange-2);color:var(--orange);}
.badge-grey  {background:var(--gris-3);color:var(--gris);}
.badge-beige {background:var(--beige-2);color:var(--gris);}

/* ── FORMS ────────────────────────────────────────────────────────────── */
.form-grid  {display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.form-full  {grid-column:1/-1;}
.form-group {display:flex;flex-direction:column;gap:5px;}
.form-group label{font-size:12px;font-weight:700;color:var(--gris);text-transform:uppercase;letter-spacing:.04em;}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;padding:9px 12px;
  border:1.5px solid var(--beige-2);border-radius:8px;
  font-family:inherit;font-size:13px;color:var(--gris);
  background:var(--blanc);transition:border-color .15s;outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--beige);}
.form-group textarea{resize:vertical;min-height:70px;}

/* ── MODAL ────────────────────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:500;
  align-items:center;justify-content:center;
  padding:16px;
}
.modal-overlay.open{display:flex;}
.modal{
  background:var(--blanc);border-radius:16px;
  width:100%;max-width:500px;max-height:90vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  display:flex;flex-direction:column;
}
/* Titre centré — croix rouge positionnée en absolu */
.modal-header{
  display:flex;align-items:center;justify-content:center;
  padding:15px 50px 15px 22px;
  background:var(--beige);border-radius:16px 16px 0 0;
  flex-shrink:0;position:relative;
}
.modal-title{
  font-size:15px;font-weight:700;font-variant:small-caps;
  color:var(--blanc);text-align:center;flex:1;
}
.modal-close{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:var(--rouge);border:none;border-radius:50%;
  width:26px;height:26px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:15px;cursor:pointer;line-height:1;padding:0;
  transition:opacity .15s;
}
.modal-close:hover{opacity:.8;}
.modal-body{padding:22px;flex:1;overflow-y:auto;}
/* Footer clair — boutons gris */
.modal-footer{
  padding:14px 22px;
  background:var(--beige-3);border-top:1px solid var(--beige-2);
  border-radius:0 0 16px 16px;
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;flex-shrink:0;
}
.modal-footer-actions{display:flex;gap:10px;}
.modal-footer .btn-secondary{
  background:var(--gris-3);color:var(--gris);border:1px solid var(--beige-2);
}
.modal-footer .btn-secondary:hover{background:var(--beige-2);}
.modal-footer .btn-primary{
  background:var(--gris);color:var(--blanc);border-color:var(--gris);
}
.modal-footer .btn-primary:hover{background:#554f4a;}
/* Bouton Retour dans le footer */
.btn-back{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 14px;border-radius:10px;
  border:1px solid var(--beige-2);
  background:var(--blanc);color:var(--gris);
  font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;
  transition:background .15s;
}
.btn-back:hover{background:var(--beige-2);}

/* ── ANIMAL THUMBS (table clients) ─────────────────────────── */
.animal-thumbs{display:inline-flex;flex-wrap:wrap;gap:10px;align-items:flex-start;}
.animal-thumb-wrap{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  cursor:pointer;transition:transform .15s;
  max-width:64px;
}
.animal-thumb-wrap:hover{transform:translateY(-2px);}
.animal-thumb-wrap:hover .animal-thumb{box-shadow:0 3px 8px rgba(0,0,0,.18);}
.animal-thumb{
  width:48px;height:48px;border-radius:50%;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--beige-2);border:2px solid var(--blanc);
  font-size:24px;transition:box-shadow .15s;
  vertical-align:middle;flex-shrink:0;
}
.animal-thumb img{width:100%;height:100%;object-fit:cover;}
.animal-thumb-name{
  font-size:11px;font-weight:600;color:var(--gris);
  text-align:center;line-height:1.1;
  max-width:64px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
/* Bouton "+" pour ajouter un animal depuis la table clients */
.animal-thumb--add{
  background:transparent;
  border:2px dashed var(--beige);
  color:var(--beige);
  font-size:28px;font-weight:300;line-height:1;
  padding-bottom:4px;
}
.animal-thumb-wrap.animal-thumb-add:hover .animal-thumb--add{
  background:var(--beige);color:var(--blanc);
  border-style:solid;
}

/* ── ARCHIVE ────────────────────────────────────────────────── */
.btn-archive{
  background:var(--gris-3);color:var(--gris-2);
  border:1px solid var(--beige-2);
}
.btn-archive:hover{background:var(--beige-2);color:var(--gris);}
.row-archived{opacity:.65;}
.row-archived:hover{opacity:1;background:#faf7f4!important;}

/* ── CONTRAT MINI (fiche animal) ────────────────────────────── */
.contrat-mini-card{
  background:var(--beige-3);border:1px solid var(--beige-2);
  border-radius:10px;padding:14px;margin-top:10px;
}
.facture-mini{
  background:var(--vert-2);border:1px solid #c3e6cb;
  border-radius:8px;padding:10px 14px;margin-top:8px;font-size:12px;
}
.facture-mini.impaye{background:#fee2e2;border-color:#fca5a5;}

/* ── ACCORDÉON TARIFS ─────────────────────────────────────────────────── */
.accord-item{
  background:var(--blanc);border-radius:var(--radius);
  border:1px solid var(--beige-2);box-shadow:var(--shadow);
  margin-bottom:10px;overflow:hidden;
}
.accord-toggle{
  width:100%;background:none;border:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;cursor:pointer;font-family:inherit;
}
.accord-toggle:hover{background:var(--beige-3);}
.accord-label{font-size:14px;font-weight:700;font-variant:small-caps;color:var(--gris);}
.accord-icon {font-size:18px;color:var(--gris-2);transition:transform .2s;}
.accord-item.open .accord-icon{transform:rotate(180deg);}
.accord-body{display:none;padding:0 18px 18px;}
.accord-item.open .accord-body{display:block;}

/* Tarif table dans l'accordéon */
.tarif-table{width:100%;border-collapse:collapse;font-size:13px;border-radius:8px;overflow:hidden;}
.tarif-table thead tr{background:var(--beige);}
.tarif-table thead th{padding:8px 12px;color:var(--blanc);font-weight:700;text-align:center;}
.tarif-table tbody td{padding:8px 12px;text-align:center;border-bottom:1px solid var(--beige-2);}
.tarif-table tbody tr:last-child td{border-bottom:none;}
.tarif-table tbody tr:nth-child(even){background:var(--beige-3);}
.note-tarif{font-size:11px;color:var(--gris-2);font-style:italic;margin-top:10px;padding:8px;background:var(--beige-3);border-radius:6px;}

/* ── ONGLETS ESPÈCES ─────────────────────────────────────────────────── */
.tabs{display:flex;gap:8px;margin-bottom:20px;}
.tab-btn{
  padding:8px 20px;border-radius:10px;border:1.5px solid var(--beige-2);
  background:var(--blanc);font-family:inherit;font-size:13px;font-weight:700;
  cursor:pointer;color:var(--gris);transition:all .15s;
}
.tab-btn:hover{background:var(--beige-2);}
.tab-btn.active{background:var(--beige);color:var(--blanc);border-color:var(--beige);}
.tab-content{display:none;}
.tab-content.active{display:block;}

/* ── AGENDA ──────────────────────────────────────────────────────────── */
.agenda-list{display:flex;flex-direction:column;gap:8px;}
.agenda-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:10px;
  background:var(--beige-3);border:1px solid var(--beige-2);
}
.agenda-time{font-size:11px;font-weight:700;color:var(--beige);min-width:40px;text-align:center;background:var(--gris);border-radius:6px;padding:2px 5px;}
.agenda-info{flex:1;}
.agenda-client   {font-size:13px;font-weight:700;color:var(--gris);}
.agenda-prestation{font-size:12px;color:var(--gris-2);}

/* ── FICHE CLIENT ─────────────────────────────────────────────────────── */
.client-avatar{
  width:56px;height:56px;border-radius:50%;
  background:var(--beige);display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;color:var(--blanc);flex-shrink:0;
}
.info-row  {display:flex;gap:6px;align-items:center;font-size:13px;margin-bottom:6px;}
.info-label{font-weight:700;color:var(--gris-2);min-width:80px;font-size:12px;text-transform:uppercase;}

/* ── PAGE HEADER ─────────────────────────────────────────────────────── */
.page-header    {display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.page-title-wrap{display:flex;align-items:center;gap:10px;}
.page-h1        {font-size:20px;font-weight:700;font-variant:small-caps;color:var(--gris);}
.page-subtitle  {font-size:12px;color:var(--gris-2);}

/* ── ANIMAUX — grille de cartes ────────────────────────────────────────── */
.animal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;justify-items:center;}
.animal-card{
  background:var(--blanc);border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--beige-2);
  padding:14px 10px;cursor:pointer;transition:transform .15s,box-shadow .15s;text-align:center;
  position:relative;width:100%;display:flex;flex-direction:column;align-items:center;
}
.animal-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.1);}
.animal-card-actions{
  position:absolute;top:8px;right:8px;
  display:flex;gap:4px;opacity:0;transition:opacity .15s;
  z-index:2;
}
.animal-card:hover .animal-card-actions{opacity:1;}
.animal-emoji{font-size:30px;margin-bottom:7px;display:block;}
.animal-photo{width:52px;height:52px;border-radius:50%;object-fit:cover;margin:0 auto 7px;display:block;border:3px solid rgba(255,255,255,.6);}
.animal-name {font-size:13px;font-weight:700;}
.animal-race {font-size:11px;margin-top:2px;opacity:.75;}
.animal-owner{font-size:10px;margin-top:4px;font-weight:700;}

/* Variantes de couleur par espèce — fond coloré, textes blancs */
.animal-card--chien{background:var(--beige);border-color:var(--beige);}
.animal-card--chien .animal-name,
.animal-card--chien .animal-race,
.animal-card--chien .animal-owner{color:var(--blanc);}

.animal-card--chat{background:var(--gris);border-color:var(--gris);}
.animal-card--chat .animal-name,
.animal-card--chat .animal-race,
.animal-card--chat .animal-owner{color:var(--blanc);}

.animal-card--nac{background:var(--beige-2);border-color:var(--beige);}
.animal-card--nac .animal-name,
.animal-card--nac .animal-race,
.animal-card--nac .animal-owner{color:var(--gris);}

/* Mini cartes animaux (modales) */
.animal-mini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:12px;justify-items:center;}
.animal-mini-card{
  background:var(--beige-3);border-radius:10px;border:1px solid var(--beige-2);
  padding:14px 10px;text-align:center;cursor:pointer;transition:all .15s;
  width:100%;display:flex;flex-direction:column;align-items:center;
}
.animal-mini-card:hover{background:var(--beige);transform:translateY(-2px);}
.animal-mini-card:hover .mini-name{color:var(--blanc);}
.animal-mini-card .mini-emoji{font-size:28px;margin-bottom:6px;}
.animal-mini-card img.mini-photo{width:48px;height:48px;border-radius:50%;object-fit:cover;margin:0 auto 6px;display:block;}
.animal-mini-card .mini-name{font-size:12px;font-weight:700;color:var(--gris);}

/* Saisie tarif (mode édition) */
.tarif-input{width:90px;padding:4px 8px;border:1.5px solid var(--beige);border-radius:6px;font-family:inherit;font-size:13px;font-weight:700;color:var(--gris);text-align:center;}

/* ── BREADCRUMB ───────────────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gris-2);margin-bottom:16px;}
.breadcrumb a{color:var(--beige);text-decoration:none;font-weight:600;}
.breadcrumb a:hover{text-decoration:underline;}

/* ── ÉTAT VIDE ────────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:48px 20px;color:var(--gris-2);}
.empty-state .es-icon{font-size:48px;margin-bottom:12px;}
.empty-state p{font-size:14px;}

/* ── TOAST ────────────────────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  background:var(--gris);color:#fff;
  padding:12px 20px;border-radius:12px;font-size:13px;font-weight:600;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
  opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .2s,transform .2s;
}
#toast.show   {opacity:1;transform:translateY(0);}
#toast.success{background:var(--vert);}
#toast.error  {background:var(--rouge);}

/* ── BOUTON MENU MOBILE ──────────────────────────────────────────────── */
.menu-toggle{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.3);cursor:pointer;font-size:18px;color:var(--blanc);
}

/* ── PAGE FOOTER ─────────────────────────────────────────────────────── */
.page-footer-bar{
  background:var(--beige);color:var(--blanc);
  padding:10px 28px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:13px;font-weight:600;
  margin-top:auto;
  flex-shrink:0;
}
.page-footer-bar .footer-count{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.2);
  padding:4px 12px;border-radius:20px;
  font-size:12px;
}
.page-footer-bar .footer-app{font-size:12px;opacity:.8;}

/* ── RESPONSIVE ───────────────────────────────────────────────────────── */
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .form-grid,
  .form-grid-3{grid-template-columns:1fr;}
  .form-full{grid-column:auto;}
}
@media(max-width:680px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .main-content{margin-left:0;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .page{padding:16px;}
  .topbar{padding:0 14px;}
  .menu-toggle{visibility:visible!important;}
}
@media(min-width:681px){
  .menu-toggle{visibility:hidden;}
}

/* ── PAGE HEADER title ───────────────────────────────────────────────── */
/* Centre le titre dans la page-header (topbar) */
.page-h1{font-size:20px;font-weight:700;font-variant:small-caps;color:var(--gris);}

/* ── RESPONSIVE footer ───────────────────────────────────────────────── */
@media(max-width:680px){
  .main-content{margin-left:0;}
  .page-footer-bar{padding:8px 14px;font-size:12px;flex-direction:column;gap:4px;text-align:center;}
}
