/* ============================================
   Yugen Black Clover — Styles
   ============================================ */

:root {
    --gold:        #27AE60;
    --gold-light:  #58D68D;
    --gold-dim:    #1E8449;
    --bg-deep:     #08070D;
    --bg-card:     #0F0D18;
    --bg-card2:    #14111F;
    --border:      rgba(39,174,96,0.18);
    --border-glow: rgba(39,174,96,0.45);
    --text:        #D8D0C8;
    --text-dim:    #7A7068;
    --text-muted:  #4A4540;
    --danger:      #C0392B;
    --success:     #27AE60;
    --radius:      6px;
    --radius-lg:   12px;
    --shadow:      0 4px 32px rgba(0,0,0,0.6);
    --glow:        0 0 24px rgba(39,174,96,0.15);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
/* ── Scrollbar ── */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg-deep); }
::-webkit-scrollbar-thumb { background: rgba(46,204,113,0.25); border-radius: 99px; border: 2px solid var(--bg-deep); }
::-webkit-scrollbar-thumb:hover { background: rgba(46,204,113,0.45); }
* { scrollbar-width: thin; scrollbar-color: rgba(46,204,113,0.25) var(--bg-deep); }

html { scroll-behavior: smooth; }

body {
    background-color: var(--bg-deep);
    color: var(--text);
    font-family: 'Segoe UI', Arial, sans-serif;
    font-size: 1.05rem;
    line-height: 1.7;
    min-height: 100vh;
    overflow-x: hidden;
}

/* ── Runes background ── */
.runes-bg { position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden; }
.runes-bg span { position:absolute;font-size:clamp(3rem,8vw,9rem);color:rgba(39,174,96,0.04);user-select:none;animation:runeFloat linear infinite; }
.runes-bg span:nth-child(1) {left:5%;top:10%;animation-duration:32s;font-size:8rem}
.runes-bg span:nth-child(2) {left:20%;top:70%;animation-duration:41s;font-size:11rem}
.runes-bg span:nth-child(3) {left:38%;top:25%;animation-duration:48s;font-size:6rem}
.runes-bg span:nth-child(4) {left:55%;top:80%;animation-duration:36s;font-size:9rem}
.runes-bg span:nth-child(5) {left:72%;top:15%;animation-duration:44s;font-size:13rem}
.runes-bg span:nth-child(6) {left:85%;top:55%;animation-duration:30s;font-size:7rem}
.runes-bg span:nth-child(7) {left:12%;top:88%;animation-duration:52s;font-size:10rem}
.runes-bg span:nth-child(8) {left:65%;top:42%;animation-duration:34s;font-size:8rem}
.runes-bg span:nth-child(9) {left:90%;top:10%;animation-duration:40s;font-size:12rem}
.runes-bg span:nth-child(10){left:45%;top:5%;animation-duration:38s;font-size:5rem}
.runes-bg span:nth-child(11){left:30%;top:50%;animation-duration:46s;font-size:14rem}
.runes-bg span:nth-child(12){left:78%;top:35%;animation-duration:29s;font-size:7rem}

@keyframes runeFloat {
    0%  { transform:translateY(0) rotate(0deg) scale(1);    opacity:.15; }
    25% { transform:translateY(-20px) rotate(5deg) scale(1.05); opacity:.5; }
    50% { transform:translateY(-40px) rotate(10deg) scale(1.1);  opacity:.7; }
    75% { transform:translateY(-20px) rotate(5deg) scale(1.05); opacity:.4; }
    100%{ transform:translateY(0) rotate(0deg) scale(1);    opacity:.15; }
}

@keyframes runeGlow {
    0%,100% { text-shadow: 0 0 0 transparent; }
    50%      { text-shadow: 0 0 20px rgba(39,174,96,0.3); }
}

/* ── Header ── */
.site-header {
    position:sticky;top:0;z-index:100;
    background:linear-gradient(to bottom,rgba(8,7,13,0.98),rgba(8,7,13,0.88));
    border-bottom:1px solid var(--border);
    backdrop-filter:blur(12px);
}
.header-inner {
    max-width:1200px;margin:0 auto;
    padding:.9rem 2rem;
    display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.logo{display:flex;align-items:center;gap:.8rem;text-decoration:none}
.logo-clover{display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0;color:var(--gold);filter:drop-shadow(0 0 8px rgba(46,204,113,0.5));animation:cloverPulse 3s ease-in-out infinite}
.logo-clover svg{display:block}
.logo-text{display:flex;flex-direction:column}
.logo-title{font-size:1.1rem;font-weight:700;color:var(--gold-light);letter-spacing:.02em;line-height:1.2}
.logo-sub{font-size:.75rem;color:var(--text-dim)}
.main-nav{display:flex;align-items:center;gap:.4rem}
.nav-link{padding:.4rem .9rem;color:var(--text-dim);text-decoration:none;font-size:.85rem;border-radius:var(--radius);transition:color .2s,background .2s}
.nav-link:hover,.nav-link.active{color:var(--gold);background:rgba(46,204,113,0.08)}
.nav-user{display:flex;align-items:center;gap:.4rem;margin-left:.8rem;padding-left:.8rem;}
.nav-user::before{content:"";display:inline-block;width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(39,174,96,0.5)' stroke-width='1.5'%3E%3Ccircle cx='12' cy='8' r='3'/%3E%3Ccircle cx='8' cy='14' r='3'/%3E%3Ccircle cx='16' cy='14' r='3'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;margin-right:.2rem;opacity:.7;}
.nav-user-icon{color:var(--text-muted)}
.user-badge{font-size:.82rem;color:var(--text-dim);text-decoration:none}
.user-badge:hover{color:var(--gold)}
.nav-logout{color:var(--text-muted);text-decoration:none;font-size:.75rem;padding:.2rem .4rem;border-radius:3px;transition:color .2s}
.nav-logout:hover{color:var(--danger)}

/* ── Main ── */
.site-main{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:2.5rem 2rem 2rem}

/* ── Page header ── */
.page-header{margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:1px solid var(--border)}
.page-title{font-size:1.6rem;font-weight:700;color:var(--gold-light);display:flex;align-items:center;gap:.5rem}
.page-subtitle{color:var(--text-dim);margin-top:.25rem;font-size:.9rem}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.2rem;margin-bottom:2rem}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.4rem 1.8rem;text-align:center;transition:border-color .25s,transform .2s}
.stat-card:hover{border-color:var(--border-glow);transform:translateY(-2px)}
.stat-icon{color:var(--gold-dim);margin-bottom:.4rem}
.stat-icon svg{display:block;margin:0 auto}
.stat-number{font-size:2.4rem;font-weight:700;color:var(--gold);line-height:1}
.stat-label{color:var(--text-dim);font-size:.85rem;margin-top:.4rem}

/* ── Cards ── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow)}

/* ── Table ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.92rem}
thead tr{background:rgba(46,204,113,0.06);border-bottom:1px solid var(--border-glow)}
th{font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--gold);padding:.85rem 1.1rem;text-align:left;white-space:nowrap}
td{padding:.8rem 1.1rem;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(46,204,113,0.03)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:99px;font-size:.78rem;font-weight:600;background:rgba(46,204,113,0.1);border:1px solid rgba(46,204,113,0.25);color:var(--gold);white-space:nowrap}
.type-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.4rem;vertical-align:middle}

/* ── Forms ── */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-group.full{grid-column:1/-1}
label{font-size:.82rem;font-weight:600;color:var(--gold);letter-spacing:.02em;display:flex;align-items:center;gap:.35rem}
input,select,textarea{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.6rem .9rem;font-family:'Segoe UI',Arial,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--gold-dim);box-shadow:0 0 0 3px rgba(46,204,113,0.1)}
textarea{resize:vertical;min-height:90px}
select option{background:var(--bg-card2)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.3rem;border:1px solid transparent;border-radius:var(--radius);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,transform .15s;text-decoration:none;font-family:'Segoe UI',Arial,sans-serif}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:rgba(46,204,113,0.15);border-color:var(--gold-dim);color:var(--gold-light)}
.btn-primary:hover{background:rgba(46,204,113,0.28);border-color:var(--gold)}
.btn-danger{background:rgba(192,57,43,0.12);border-color:rgba(192,57,43,0.35);color:#E74C3C}
.btn-danger:hover{background:rgba(192,57,43,0.25)}
.btn-sm{padding:.32rem .7rem;font-size:.78rem}

/* ── Alerts ── */
.alert{padding:.85rem 1.1rem;border-radius:var(--radius);margin-bottom:1.2rem;font-size:.88rem;display:flex;align-items:center;gap:.5rem}
.alert-success{background:rgba(39,174,96,0.1);border:1px solid rgba(39,174,96,0.3);color:#2ECC71}
.alert-error{background:rgba(192,57,43,0.1);border:1px solid rgba(192,57,43,0.3);color:#E74C3C}
.alert-info{background:rgba(41,128,185,0.1);border:1px solid rgba(41,128,185,0.3);color:#3498DB}

/* ── Filters ── */
.filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.filter-search{position:relative;flex:1;min-width:220px}
.filter-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}
.filter-search input{padding-left:34px;width:100%;height:36px}
.filter-bar select{height:36px;min-width:150px;flex-shrink:0;font-size:.83rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:0 10px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7068' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;transition:border-color .15s}
.filter-bar select:hover{border-color:rgba(46,204,113,0.3)}
.filter-bar select:focus{outline:none;border-color:var(--gold-dim);box-shadow:0 0 0 3px rgba(46,204,113,0.1)}
.filter-bar select option{background:var(--bg-card2);color:var(--text)}
.filter-bar .btn{height:36px;padding:0 14px;flex-shrink:0;font-size:.82rem}
.filter-count{font-size:.72rem;color:var(--text-muted);background:rgba(46,204,113,0.06);border:1px solid rgba(46,204,113,0.15);padding:3px 10px;border-radius:99px;white-space:nowrap}

/* ── Section title ── */
.section-title{font-size:.9rem;font-weight:700;color:var(--gold);letter-spacing:.04em;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.section-title::after{content:'';flex:1;height:1px;background:var(--border);margin-left:.5rem}

/* ── Empty state ── */
.empty-state{text-align:center;padding:3.5rem 2rem;color:var(--text-muted)}
.empty-state svg{color:rgba(46,204,113,0.15);margin:0 auto .8rem;display:block}
.empty-state p{font-size:.9rem;margin-bottom:1.2rem}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}
.login-box{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border-glow);border-radius:var(--radius-lg);padding:2.5rem 2rem;box-shadow:var(--shadow),var(--glow);text-align:center}
.login-clover{display:flex;align-items:center;justify-content:center;margin-bottom:.8rem}
.login-clover svg{color:var(--gold);filter:drop-shadow(0 0 20px rgba(46,204,113,0.5));animation:cloverPulse 3s ease-in-out infinite}
.login-title{font-size:1.5rem;font-weight:700;color:var(--gold-light);margin-bottom:.2rem}
.login-sub{color:var(--text-dim);margin-bottom:1.8rem;font-size:.88rem}
.login-form{text-align:left}
.login-form .form-group{margin-bottom:1rem}
.login-form .btn{width:100%;justify-content:center;margin-top:.4rem}

@keyframes cloverPulse{
    0%,100%{filter:drop-shadow(0 0 8px rgba(46,204,113,0.4))}
    50%{filter:drop-shadow(0 0 22px rgba(46,204,113,0.85))}
}

/* ── Pagination ── */
.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:1.2rem}
.pagination a,.pagination span{padding:.38rem .85rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;color:var(--text-dim);text-decoration:none;transition:border-color .2s,color .2s}
.pagination a:hover{border-color:var(--border-glow);color:var(--gold)}
.pagination .current{border-color:var(--gold-dim);color:var(--gold)}

/* ── Footer ── */
.site-footer{position:relative;z-index:1;border-top:1px solid var(--border);background:rgba(0,0,0,0.2)}
.footer-inner{max-width:1200px;margin:0 auto;padding:1.4rem 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-left{display:flex;align-items:center;gap:.75rem}
.footer-logo{color:var(--gold);display:flex;align-items:center}
.footer-logo svg{filter:drop-shadow(0 0 6px rgba(46,204,113,0.4))}

.footer-left{display:flex;align-items:center;gap:.75rem}
.footer-logo{color:var(--gold);display:flex;align-items:center}
.footer-logo svg{filter:drop-shadow(0 0 6px rgba(46,204,113,0.4))}
.footer-name{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.3}
.footer-sub{font-size:.72rem;color:var(--text-muted)}
.footer-right{display:flex;align-items:center;gap:.3rem}
.footer-link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border-radius:var(--radius);font-size:.78rem;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s}
.footer-link:hover{color:var(--gold);background:rgba(46,204,113,0.06)}
.footer-link svg{opacity:.6}
.footer-bottom{max-width:1200px;margin:0 auto;padding:.5rem 2rem;font-size:.7rem;color:var(--text-muted);text-align:center}
.footer-right{display:flex;align-items:center;gap:.3rem}
.footer-link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border-radius:var(--radius);font-size:.78rem;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s}
.footer-link:hover{color:var(--gold);background:rgba(46,204,113,0.06)}
.footer-link svg{opacity:.6}
.footer-bottom{max-width:1200px;margin:0 auto;padding:.5rem 2rem;font-size:.7rem;color:var(--text-muted);text-align:center}

/* ── SVG Icons ── */
svg{display:inline-block;vertical-align:middle;flex-shrink:0}
.nav-link svg,.btn svg{vertical-align:middle}
.stat-icon svg{display:block;margin:0 auto}
label svg{vertical-align:middle;margin-right:.1rem}
th svg{vertical-align:middle;opacity:.7}
.search-wrap{position:relative;flex:1;min-width:200px;display:flex;align-items:center}
.search-wrap svg{position:absolute;left:.75rem;color:var(--text-muted);pointer-events:none}
.search-wrap input{padding-left:2.2rem;width:100%}
.rotate180{transform:rotate(180deg)}
.nav-user-icon{color:var(--text-muted)}

/* ── Éditeur riche ── */
.editor-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.editor-wrap:focus-within{border-color:var(--gold-dim);box-shadow:0 0 0 3px rgba(46,204,113,0.1)}
.editor-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:2px;padding:6px 8px;background:rgba(255,255,255,0.03);border-bottom:1px solid var(--border)}
.toolbar-group{display:flex;gap:2px}
.toolbar-sep{width:1px;height:20px;background:var(--border);margin:0 4px;align-self:center}
.editor-toolbar button{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 6px;background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text-dim);font-size:.8rem;cursor:pointer;transition:background .12s,border-color .12s,color .12s;font-family:'Segoe UI',Arial,sans-serif}
.editor-toolbar button:hover{background:rgba(46,204,113,0.1);border-color:rgba(46,204,113,0.25);color:var(--gold)}
.editor-content{min-height:120px;max-height:400px;overflow-y:auto;padding:.7rem 1rem;background:rgba(255,255,255,0.04);color:var(--text);font-family:'Segoe UI',Arial,sans-serif;font-size:.95rem;line-height:1.7;outline:none}
.editor-content h2{font-size:1.15rem;font-weight:700;color:var(--gold-light);margin:.6rem 0 .3rem}
.editor-content h3{font-size:1rem;font-weight:600;color:var(--text);margin:.5rem 0 .2rem}
.editor-content p{margin:.3rem 0}
.editor-content ul,.editor-content ol{padding-left:1.4rem;margin:.3rem 0}
.editor-content li{margin:.15rem 0}

/* ── Admin tabs ── */
.admin-wrap{display:flex;flex-direction:column;gap:2rem}
.admin-section-title{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}
.admin-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.admin-tabs{display:flex;gap:4px;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:5px;margin-bottom:1.5rem}
.admin-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:'Segoe UI',Arial,sans-serif}
.admin-tab:hover{color:var(--text);background:rgba(255,255,255,0.05)}
.admin-tab.active{background:rgba(46,204,113,0.12);border-color:rgba(46,204,113,0.35);color:var(--gold)}
.admin-tab-content{display:none}
.admin-tab-content.active{display:block}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}
.admin-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.4rem;display:flex;align-items:center;gap:1rem}
.admin-stat-icon{width:40px;height:40px;border-radius:10px;background:rgba(46,204,113,0.1);border:1px solid rgba(46,204,113,0.2);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.admin-stat-num{font-size:1.6rem;font-weight:700;color:var(--gold-light)}
.admin-stat-lbl{font-size:.75rem;color:var(--text-muted)}
.membres-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.membre-list{display:flex;flex-direction:column;gap:.5rem}
.membre-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.8rem;transition:border-color .2s}
.membre-card:hover{border-color:rgba(46,204,113,0.2)}
.membre-name{font-size:.92rem;font-weight:600;color:var(--text)}
.role-pill{display:inline-block;padding:.18rem .65rem;border-radius:99px;font-size:.68rem;font-weight:700;letter-spacing:.03em;border:1px solid}
.membre-actions{display:flex;align-items:center;gap:.4rem}
.admin-forms{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.admin-form-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.4rem}
.admin-form-title{font-size:.78rem;font-weight:700;color:var(--gold);letter-spacing:.04em;margin-bottom:1rem;display:flex;align-items:center;gap:.4rem}
.admin-form-card .form-group{margin-bottom:.8rem}
.admin-form-card label{font-size:.75rem}
.types-list{display:flex;flex-direction:column;gap:.4rem}
.type-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem 1rem}
.type-row-left{display:flex;align-items:center;gap:.7rem}
.type-color-swatch{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.type-name{font-size:.88rem;color:var(--text)}
.type-count{font-size:.75rem;color:var(--text-muted);font-style:italic}
.role-group-head{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:.4rem 0;margin-top:.4rem;display:flex;align-items:center;gap:.5rem}
.role-group-head:first-child{margin-top:0}

/* ── Lignes cliquables ── */
.row-clickable:hover td{background:rgba(46,204,113,0.07)!important}

/* ── Responsive ── */
@media(max-width:768px){
    .header-inner{flex-direction:column;align-items:flex-start;gap:.7rem}
    .main-nav{flex-wrap:wrap}
    .site-main{padding:1.2rem 1rem 2rem}
    .form-grid{grid-template-columns:1fr}
    .stats-grid{grid-template-columns:1fr 1fr}
    th,td{padding:.55rem .7rem;font-size:.82rem}
    .membres-grid,.admin-forms{grid-template-columns:1fr}
}

/* ── Animations globales ── */

/* Fade-in au chargement */
@keyframes fadeInUp {
    from { opacity:0; transform:translateY(16px); }
    to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
    from { opacity:0; }
    to   { opacity:1; }
}
@keyframes countUp {
    from { opacity:0; transform:scale(.8); }
    to   { opacity:1; transform:scale(1); }
}
@keyframes slideInLeft {
    from { opacity:0; transform:translateX(-12px); }
    to   { opacity:1; transform:translateX(0); }
}
@keyframes glowPulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(39,174,96,0); }
    50%      { box-shadow: 0 0 12px 2px rgba(39,174,96,0.2); }
}

/* Apparition page principale */
.site-main > * {
    animation: fadeInUp .45s ease both;
}
.site-main > *:nth-child(1) { animation-delay: .05s; }
.site-main > *:nth-child(2) { animation-delay: .12s; }
.site-main > *:nth-child(3) { animation-delay: .18s; }
.site-main > *:nth-child(4) { animation-delay: .24s; }
.site-main > *:nth-child(5) { animation-delay: .30s; }

/* Stats — compteur pop */
.stat-card {
    animation: fadeInUp .4s ease both;
}
.stats-grid .stat-card:nth-child(1) { animation-delay: .1s; }
.stats-grid .stat-card:nth-child(2) { animation-delay: .18s; }
.stats-grid .stat-card:nth-child(3) { animation-delay: .26s; }
.stats-grid .stat-card:nth-child(4) { animation-delay: .34s; }
.stat-number {
    animation: countUp .5s cubic-bezier(.34,1.56,.64,1) both;
    animation-delay: .3s;
}

/* Hover cartes */
.stat-card {
    transition: border-color .2s, transform .2s, box-shadow .2s !important;
}
.stat-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 16px rgba(39,174,96,0.1) !important;
}

/* Hover boutons */
.btn {
    transition: background .18s, border-color .18s, transform .18s, box-shadow .18s !important;
}
.btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 16px rgba(39,174,96,0.25) !important;
}
.btn-danger:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(192,57,43,0.2) !important;
}

/* Hover lignes tableau */
.tbl-wrap tbody tr, table tbody tr {
    transition: background .12s !important;
}

/* Hover cartes .card */
.card {
    transition: border-color .2s, box-shadow .2s !important;
}
.card:hover {
    border-color: rgba(39,174,96,0.3) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.4), 0 0 12px rgba(39,174,96,0.06) !important;
}

/* Hover nav links */
.nav-link {
    transition: color .15s, background .15s, transform .15s !important;
}
.nav-link:hover {
    transform: translateY(-1px) !important;
}

/* Table rows apparition */
table tbody tr {
    animation: slideInLeft .3s ease both;
}
table tbody tr:nth-child(1) { animation-delay:.05s }
table tbody tr:nth-child(2) { animation-delay:.1s }
table tbody tr:nth-child(3) { animation-delay:.15s }
table tbody tr:nth-child(4) { animation-delay:.2s }
table tbody tr:nth-child(5) { animation-delay:.25s }
table tbody tr:nth-child(6) { animation-delay:.28s }
table tbody tr:nth-child(7) { animation-delay:.31s }
table tbody tr:nth-child(8) { animation-delay:.33s }

/* Logo header pulse amélioré */
.logo-clover {
    animation: cloverPulse 3s ease-in-out infinite !important;
    transition: filter .2s !important;
}
.logo:hover .logo-clover {
    filter: drop-shadow(0 0 14px rgba(39,174,96,0.7)) !important;
}

/* Membre cartes équipe */
.mc {
    animation: fadeInUp .4s ease both;
}

/* Réduire animations si l'utilisateur préfère moins d'animations */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}
