.accueil-root{width:100vw;height:100vh;background-image:url(/accueil.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;justify-content:center;align-items:center}.accueil-content{width:100%;height:100%;position:relative}.accueil-entry-buttons{position:absolute;left:50%;bottom:40vh;display:flex;gap:18px;transform:translate(-50%)}.accueil-entry-buttons button{min-width:190px;padding:15px 24px;border:1px solid rgba(145,230,165,.9);border-radius:999px;background:linear-gradient(180deg,#48d663,#0f742b);color:#fff;font-size:21px;font-weight:800;text-transform:uppercase;cursor:pointer;box-shadow:inset 0 2px #ffffff7a,inset 0 -5px #005f2061,0 12px 24px #00000059;transition:transform .16s ease,filter .16s ease}.accueil-entry-buttons button:hover{filter:brightness(1.08);transform:translateY(-2px)}.accueil-auth-overlay{position:fixed;inset:0;z-index:20;display:flex;justify-content:center;align-items:center;padding:24px;background:#0405186b}.accueil-auth-card{position:relative;width:min(92vw,430px);padding:28px 28px 24px;border:1px solid rgba(126,150,255,.62);border-radius:22px;background:linear-gradient(180deg,#27207bf5,#08072afa),#08082df0;box-shadow:0 20px 55px #00000094}.accueil-auth-close{position:absolute;top:10px;right:13px;width:34px;height:34px;border:0;border-radius:50%;background:#ffffff1f;color:#fff;font-size:26px;line-height:1;cursor:pointer}.accueil-auth-close:hover{background:#ffffff38}.accueil-auth-form{display:flex;flex-direction:column;gap:10px;text-align:left}.accueil-auth-form h2{margin:0 0 12px;color:#fff;font-size:28px;font-weight:600;text-align:center}.accueil-auth-form label{color:#fff;font-size:15px;font-weight:800}.accueil-auth-form input{width:100%;box-sizing:border-box;padding:13px 15px;border:0;border-radius:9px;background:#fff;color:#111;font-size:17px;outline:none}.accueil-auth-form input:focus{box-shadow:0 0 0 3px #4bb1ff75}.accueil-auth-form button[type=submit]{align-self:center;min-width:230px;margin-top:14px;padding:14px 22px;border:0;border-radius:999px;background:linear-gradient(180deg,#46beff,#126fd2);color:#fff;font-size:18px;font-weight:900;text-transform:uppercase;cursor:pointer;box-shadow:inset 0 2px #ffffff6b,inset 0 -5px #003e8259,0 10px 18px #00000052}.accueil-auth-form button[type=submit]:hover:not(:disabled){filter:brightness(1.08)}.accueil-auth-form button[type=submit]:disabled{cursor:not-allowed;opacity:.75}.accueil-auth-message,.accueil-auth-error{margin:16px 0 0;padding:11px 13px;border-radius:10px;font-size:15px;font-weight:800;text-align:center}.accueil-auth-message{background:#1e964b3d;color:#c9ffd9;border:1px solid rgba(118,255,166,.38)}.accueil-auth-error{background:#aa1e2d42;color:#ffd1d1;border:1px solid rgba(255,118,118,.42)}.accueil-contact-line{margin:12px 0 0;color:#cfe2ff;font-size:14px;font-weight:800;text-align:center}.accueil-contact-line a{color:#ffe27a;font-weight:900;text-decoration:none}.accueil-contact-line a:hover{text-decoration:underline}.salon-wrapper{min-height:100vh;padding:15px;position:relative;background-image:url(/salon_star.png);background-size:cover;background-position:center;display:flex;justify-content:center}.salon-grid{width:100%;max-width:1240px;display:grid;grid-template-columns:280px 1fr 220px;gap:20px;margin-top:35px}.panel{background:#00144661;border-radius:18px;padding:18px;box-shadow:0 0 14px #0096ff73,0 0 28px #0096ff40,inset 0 0 10px #0078ff33;display:flex;flex-direction:column}.panel-side{height:78vh}.panel-center{height:88vh;position:relative;overflow:hidden}.panel-side,.panel-center{margin-top:-15px}.panel-title{font-size:1.7rem;font-weight:700;color:#fff;text-align:center;margin-bottom:15px;text-shadow:0 0 8px black}.tables-list{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding-right:5px}.table-card{padding:18px 16px;margin-bottom:18px;min-height:188px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-start;background:#001e50a6;border-radius:16px;border:1px solid rgba(120,180,255,.25);box-shadow:inset 0 0 10px #78b4ff40,0 0 14px #0096ff59,0 0 28px #0096ff2e}.table-title{font-size:1.4rem;color:#fff}.table-info{font-size:1.1rem;color:#d6e3ff}.table-info.mode{opacity:.95;font-weight:700}.btn-join{width:100%;box-sizing:border-box;flex-shrink:0;margin-top:12px;padding:8px 14px;font-size:1.1rem;border-radius:10px;background:#1b6cf8;color:#fff;border:none;cursor:pointer}.table-info.mode{display:flex;align-items:center;gap:10px}.table-mode-label{white-space:nowrap}.table-mode-select{flex:1;min-width:170px;max-width:100%;height:34px;padding:0 10px;border-radius:10px;border:1px solid rgba(120,180,255,.25);background:#00236ed9;color:#eaf6ff;font-size:.95rem;font-weight:700;box-sizing:border-box;outline:none;cursor:pointer}.players-list{display:flex;flex-direction:column;gap:12px}.player-card{display:flex;align-items:center;gap:10px;padding:6px 12px;margin-bottom:10px;border-radius:16px;background:#001e508c;box-shadow:inset 0 0 8px #78b4ff40,0 0 10px #5096ff59}.player-avatar{width:38px;height:38px;object-fit:cover;border-radius:50%}.player-name{color:#eaf6ff;font-size:15px;font-weight:500}.chat-box{flex:1;min-height:0;overflow-y:auto;background:#00287840;border-radius:18px;padding:8px 18px 18px;margin-bottom:12px}.chat-message{font-size:1.25rem;margin-bottom:6px}.chat-user{font-weight:700;color:#88caff;margin-right:6px}.chat-text{color:#fff}.chat-input-zone{display:flex;align-items:center;gap:12px;height:42px;margin-bottom:8px}.chat-input{flex:1;height:42px;padding:0 14px;margin:0;border-radius:10px;background:#00236ef2;color:#fff;border:none;font-size:1.05rem;line-height:normal;appearance:none;-webkit-appearance:none;box-sizing:border-box;display:block;box-shadow:0 0 10px #0096ff99}.chat-send{height:42px;padding:0 18px;margin:0;border-radius:10px;background:#1b6cf8;border:none;color:#fff;font-size:1.05rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;appearance:none;-webkit-appearance:none;box-sizing:border-box;box-shadow:0 0 10px #0096ff99}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:#64b4ff66;border-radius:10px}.table-info.mode{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}.table-card{overflow:visible}.table-mode-dropdown{position:relative;display:inline-block}.table-mode-trigger{height:34px;padding:0 12px;border-radius:10px;border:1px solid rgba(120,180,255,.18);background:#00236e8c;color:#eaf6ffe0;font-size:.93rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.table-mode-trigger .caret{opacity:.75}.table-mode-trigger .caret{opacity:.9}.table-mode-menu{position:absolute;bottom:calc(100% + 6px);left:0;width:170px;background:#001e50f2;border:1px solid rgba(120,180,255,.25);border-radius:12px;padding:6px;box-shadow:0 0 18px #0096ff40;z-index:9999}.table-mode-menu button{width:100%;text-align:left;padding:8px 10px;border:none;border-radius:10px;background:transparent;color:#eaf6ff;font-weight:700;cursor:pointer}.table-mode-menu button:hover{background:#1b6cf859}.table-mode-chosen{margin-top:6px;color:#d6e3ff;font-weight:700}.table-mode-menu-portal{position:fixed;z-index:999999;background:#001e50f7;border:1px solid rgba(120,180,255,.25);border-radius:12px;padding:6px;box-shadow:0 0 18px #0096ff40,inset 0 0 10px #78b4ff2e;display:flex;flex-direction:column;gap:6px}.table-mode-menu-portal button{width:100%;display:block;text-align:left;padding:10px 12px;border:none;border-radius:10px;background:#00236e8c;color:#eaf6ff;font-weight:800;font-size:.95rem;cursor:pointer}.table-mode-menu-portal button:hover{background:#1b6cf873}.table-seated-players{min-height:38px;margin-top:8px;margin-bottom:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 10px}.table-seated-player.empty{grid-column:1 / -1;color:#fff9;font-weight:600}.table-seated-player{font-size:14px;font-weight:700;color:#fff;line-height:1.2;text-align:left;text-shadow:0 1px 2px rgba(0,0,0,.35);padding-left:2px}.table-seated-player.empty{color:#fff9;font-weight:600}.salon-chat-emojis{position:absolute;left:18px;right:18px;bottom:72px;z-index:20;display:flex;flex-wrap:wrap;gap:8px;max-height:150px;overflow-y:auto;padding:10px;margin:0;border:1px solid rgba(120,180,255,.24);border-radius:14px;background:#001446f5;box-shadow:0 10px 28px #00000059}.salon-chat-emoji-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(120,180,255,.32);border-radius:10px;background:#00236e9e;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.salon-chat-emoji-btn:hover{transform:translateY(-1px);border-color:#78b4ffa6;box-shadow:0 4px 10px #00000038}.salon-chat-emoji-btn-img{width:24px;height:24px;object-fit:contain;display:block}.chat-emoji-toggle{width:44px;min-width:44px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(120,180,255,.32);border-radius:10px;background:#00236ef2;color:#fff;font-size:21px;cursor:pointer;box-shadow:0 0 10px #0096ff73}.chat-emoji-toggle:hover{border-color:#78b4ffb3;filter:brightness(1.08)}.salon-chat-custom-emoji-wrap{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;margin:0 3px;animation:salonChatEmojiPop .52s ease-out;transform-origin:center}.salon-chat-custom-emoji{width:40px;height:40px;object-fit:contain;display:block}@keyframes salonChatEmojiPop{0%{transform:scale(.35) translateY(10px) rotate(-8deg);opacity:0}45%{transform:scale(1.18) translateY(-4px) rotate(4deg);opacity:1}70%{transform:scale(.96) translateY(0) rotate(-2deg);opacity:1}to{transform:scale(1) translateY(0) rotate(0);opacity:1}}.btn-create-table{width:100%;box-sizing:border-box;margin:0 auto 12px;padding:10px 12px;border:1px solid rgba(120,180,255,.36);border-radius:12px;background:linear-gradient(180deg,#2572fffa,#1359d7fa);color:#fff;font-weight:800;font-size:.98rem;cursor:pointer;box-shadow:0 0 12px #0096ff59}.btn-create-table:hover:not(:disabled){filter:brightness(1.08);border-color:#a0cdffb3}.tables-ready-info{width:100%;box-sizing:border-box;margin:0 auto 12px;padding:10px 12px;border:1px solid rgba(120,180,255,.3);border-radius:12px;background:#00236eb8;color:#ffffffeb;font-weight:800;font-size:.98rem;text-align:center;box-shadow:0 0 10px #0096ff38}.table-card-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-top:10px}.table-card-actions .btn-join{margin-top:0}.btn-watch{width:100%;box-sizing:border-box;flex-shrink:0;padding:8px 14px;font-size:1.1rem;border-radius:10px;background:#00236ec7;color:#eaf6ff;border:1px solid rgba(120,180,255,.35);cursor:pointer}.btn-watch:hover{filter:brightness(1.08);border-color:#a0cdffb3}.table-card-actions .btn-join,.table-card-actions .btn-watch{min-width:0;padding-left:8px;padding-right:8px;font-size:1rem;white-space:nowrap}.salon-admin-btn{white-space:nowrap;gap:8px;align-items:center;display:inline-flex;position:absolute;top:18px;left:18px;z-index:25;padding:8px 14px;border-radius:999px;border:1px solid rgba(150,210,255,.85);background:linear-gradient(180deg,#2f7cff,#1f58c8);color:#fff;font-weight:900;cursor:pointer;box-shadow:0 8px 18px #00000052}.salon-admin-btn:hover{filter:brightness(1.08)}.salon-admin-pending-dot{display:inline-block;flex:0 0 12px;box-sizing:border-box;width:12px;height:12px;min-width:12px;min-height:12px;border-radius:999px;background:#ff3b3b;border:2px solid #ffffff;box-shadow:0 0 0 2px #ff3b3b59,0 0 10px #ff3b3bd9}.player-name.role-admin,.chat-message.role-admin .chat-user,.chat-message.role-admin .chat-text{color:#55dd6c;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.55)}.player-name.role-moderator,.chat-message.role-moderator .chat-user,.chat-message.role-moderator .chat-text{color:#ffe27a;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.55)}.profil-modal-bg{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:9999}.profil-modal{width:min(420px,92vw);background:#0f121ceb;border:1px solid rgba(255,255,255,.18);box-shadow:0 20px 60px #0000008c;border-radius:16px;padding:22px 20px;text-align:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.profil-title{margin:0 0 14px;font-size:22px;color:#fff;letter-spacing:.2px}.profil-avatar{width:120px;height:120px;object-fit:cover;border-radius:50%;border:3px solid rgba(255,255,255,.25);box-shadow:0 10px 25px #0006;margin:6px auto 10px;display:block}.profil-pseudo{margin:0 0 16px;font-size:16px;color:#ffffffe6}.upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;cursor:pointer;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);color:#fffffff2;font-weight:600;margin-bottom:14px}.upload-btn:hover{background:#ffffff24}.upload-btn input{display:none}.close-btn{width:100%;padding:11px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fffffff2;font-weight:700;cursor:pointer}.close-btn:hover{background:#ffffff1f}.tablechat-container{height:100%;min-height:0;display:flex;flex-direction:column;position:relative;overflow:hidden;color:#fff;font-family:Orbitron,sans-serif}.tablechat-title{text-align:center;margin-bottom:10px;padding-bottom:6px;font-size:14px;letter-spacing:2px;text-transform:uppercase;color:#fff;border-bottom:1px solid rgba(220,180,120,.3)}.tablechat-messages{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:6px;padding-bottom:16px}.tablechat-line{font-size:18px;margin-bottom:10px;word-break:break-word;overflow-wrap:anywhere}.tablechat-inputzone{display:flex;gap:10px;width:100%;box-sizing:border-box;margin-top:auto}.tablechat-input{flex:1;min-width:0;width:100%;padding:10px;background:#3c000073;border:1px solid rgba(160,60,60,.6);border-radius:10px;color:#fff;font-family:Orbitron,sans-serif;font-size:16px;box-sizing:border-box}.tablechat-input::placeholder{color:#ffdcdcb3;white-space:nowrap}.tablechat-button{padding:10px 14px;background:linear-gradient(180deg,#7a1f1f,#5a1414);border-radius:10px;border:none;color:#fff;font-size:16px;font-family:Orbitron,sans-serif;cursor:pointer;flex-shrink:0}.tablechat-input:focus{outline:none;border-color:#dcb478e6;box-shadow:0 0 10px #b43c3c99,inset 0 0 6px #ffdcb440}.tablechat-messages::-webkit-scrollbar{width:8px}.tablechat-messages::-webkit-scrollbar-track{background:#3c000040;border-radius:8px}.tablechat-messages::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#7a1f1f,#5a1414);border-radius:8px}.tablechat-messages::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#8f2a2a,#6b1a1a)}.tablechat-messages{scrollbar-width:thin;scrollbar-color:#7a1f1f rgba(60,0,0,.25)}.tablechat-messages{padding-top:4px;padding-right:6px;padding-bottom:12px}.tablechat-line{font-size:16px;line-height:1.45;margin-bottom:8px;color:#fff5f5f5;word-break:break-word;overflow-wrap:anywhere}.tablechat-line.me{color:#fff}.tablechat-line.system{font-size:13px;font-weight:700;color:#ffdcaae0;opacity:.95}.tablechat-author{color:#fff;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.35)}.tablechat-emojis{display:flex;flex-wrap:wrap;gap:8px;padding:10px 0 12px;margin-top:6px;border-top:1px solid rgba(220,180,120,.18)}.tablechat-emoji-btn{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(220,180,120,.28);border-radius:10px;background:#5a14146b;color:#fff;font-size:20px;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.tablechat-emoji-btn:hover{transform:translateY(-1px);border-color:#dcb4788c;box-shadow:0 4px 10px #00000038}.tablechat-inputzone{margin-top:0;padding-top:2px}.tablechat-button:hover{filter:brightness(1.06)}.tablechat-line.other{color:#fff5f5eb}.tablechat-custom-emoji-wrap{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;margin:0 3px;animation:tablechatEmojiPop .52s ease-out;transform-origin:center}.tablechat-custom-emoji{width:40px;height:40px;object-fit:contain;display:block}@keyframes tablechatEmojiPop{0%{transform:scale(.35) translateY(10px) rotate(-8deg);opacity:0}45%{transform:scale(1.18) translateY(-4px) rotate(4deg);opacity:1}70%{transform:scale(.96) translateY(0) rotate(-2deg);opacity:1}to{transform:scale(1) translateY(0) rotate(0);opacity:1}}.tablechat-emoji-btn-img{width:24px;height:24px;object-fit:contain;display:block}.tablechat-emoji-btn{display:inline-flex;align-items:center;justify-content:center}.tablechat-emoji-toggle{width:44px;min-width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(220,180,120,.28);border-radius:10px;background:#5a14146b;color:#fff;font-size:22px;cursor:pointer;flex-shrink:0}.tablechat-emoji-toggle:hover{border-color:#dcb4788c}.tablechat-line.role-admin,.tablechat-line.role-admin .tablechat-author{color:#55dd6c;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.55)}.tablechat-line.role-moderator,.tablechat-line.role-moderator .tablechat-author{color:#ffe27a;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.55)}.table-page{width:100%;height:100vh;background-image:url(/table_background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;overflow:hidden}.table-back-btn{position:absolute;top:20px;left:20px;padding:8px 16px;border-radius:20px;border:1px solid rgba(220,180,120,.8);background:linear-gradient(180deg,#7a1f1f,#5a1414);color:#fff;font-weight:600;cursor:pointer;box-shadow:0 0 10px #b4282899;z-index:10}.table-layout{width:100%;height:100%;display:flex;justify-content:center;align-items:center;padding:3%;box-sizing:border-box}.table-zone{flex:0 0 67%;display:flex;justify-content:center;align-items:center}.table-board{position:relative;width:720px;height:720px}.table-image{position:absolute;inset:0;z-index:1;background-image:url(/table_vero.png);background-size:contain;background-repeat:no-repeat;background-position:center}.player-seat{position:absolute;display:flex;flex-direction:column;align-items:center;gap:6px;z-index:6}.player-seat.top{top:10px;left:50%;transform:translate(-50%)}.player-seat.bottom{bottom:10px;left:50%;transform:translate(-50%)}.player-seat.left{left:10px;top:50%;transform:translateY(-50%)}.player-seat.right{right:10px;top:50%;transform:translateY(-50%)}.table-page .player-avatar{width:52px;height:52px;display:block;flex-shrink:0;object-fit:cover;object-position:center;border-radius:50%;border:2px solid #c83b3b;background:#7a1f1f;box-shadow:0 0 0 2px #0009,0 0 8px #c83c3cb3}.table-page .player-pseudo{position:absolute;padding:4px 10px;border-radius:999px;background:#280812c7;border:1px solid rgba(255,255,255,.12);color:#fff;font-size:12px;font-weight:700;line-height:1;white-space:nowrap;pointer-events:none;z-index:6;box-shadow:0 4px 10px #0000002e}.table-page .player-pseudo.role-admin{color:#55dd6c}.table-page .player-pseudo.role-moderator{color:#ffe27a}.table-page .player-seat.top .player-pseudo{top:-28px;left:50%;transform:translate(-50%)}.table-page .player-seat.bottom .player-pseudo{top:58px;left:50%;transform:translate(-50%)}.table-page .player-seat.left .player-pseudo{top:26px;left:60px;transform:translateY(-50%)}.table-page .player-seat.right .player-pseudo{top:26px;right:60px;transform:translateY(-50%)}.player-bottom{position:absolute;bottom:70px;left:50%;transform:translate(-50%);display:flex;gap:0;padding:0;border-radius:0;background:transparent;box-shadow:none;z-index:5}.card{width:90px;height:130px;background:transparent;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#000;box-shadow:0 6px 14px #00000073}.card-img{transition:transform .12s ease}.card:hover .card-img{transform:translateY(-14px)}.atout-panel{position:absolute;top:calc(50% + 50px);left:50%;transform:translate(-50%,-50%);background:#140a0ad9;padding:20px 26px;border-radius:18px;box-shadow:0 0 0 1px #dcb47859,0 10px 25px #0009;z-index:20;text-align:center}.atout-title{color:#f0e6d2;font-weight:600;margin-bottom:14px}.atout-actions{display:flex;gap:14px;justify-content:center}.atout-btn{padding:8px 16px;border-radius:14px;border:none;cursor:pointer;font-weight:600}.atout-btn.take,.atout-btn.pass{background:#7a1f1f;color:#fff}.atout-btn:disabled{opacity:.45;cursor:not-allowed}.table-chat-zone{flex:0 0 27%;height:720px;margin-left:3%;background:#3c00008c;border-radius:20px;padding:20px;box-sizing:border-box;box-shadow:0 0 0 1px #dcb47859,0 0 20px #a01e1e99}.atout-card{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);width:68px;height:100px;border-radius:10px;background:#1e0a0ad9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;box-shadow:0 0 0 1px #dcb47866,0 8px 18px #0009;z-index:6}.atout-card .label{font-size:12px;color:#e8cfa5;opacity:.8}.atout-card .symbol{font-size:28px}.pli-card{position:absolute;width:80px;height:116px;background:#fff;border-radius:14px;font-weight:800;font-size:18px;color:#111;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 3px #dcb478e6,0 14px 28px #000000bf;z-index:20}.pli-joueur1{bottom:32%;left:50%;transform:translate(-50%)}.pli-joueur2{top:26%;left:50%;transform:translate(-50%)}.pli-joueur3{top:50%;right:22%;transform:translateY(-50%)}.pli-joueur4{top:50%;left:22%;transform:translateY(-50%)}.player-seat.active .player-avatar{box-shadow:0 0 0 4px #c82828,0 0 20px #c82828e6,0 0 36px #c82828bf,0 0 56px #c828288c}.active-dot{position:absolute;top:-10px;right:-10px;width:14px;height:14px;background:#c62828;border-radius:50%;box-shadow:0 0 0 2px #3c0000e6,0 0 12px #c62828bf;z-index:10}@keyframes pli-appear{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1.2)}}.pli-card{animation:pli-appear .18s ease-out}.atout-suit-btn{width:56px;height:56px;padding:0;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px #dcb47899,0 6px 14px #00000073}.atout-suit-symbol{width:30px;height:30px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:900;line-height:1;box-shadow:inset 0 0 0 1px #0000002e}.atout-suit-symbol.hearts,.atout-suit-symbol.diamonds{color:#c01818}.atout-suit-symbol.spades,.atout-suit-symbol.clubs{color:#111}.score-overlay.score-pill{position:absolute;top:-60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:14px;color:#fff;pointer-events:none;z-index:50}.score-side{font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;opacity:1}.score-pill-box{padding:4px 14px;min-width:84px;border-radius:999px;border:1.5px solid rgba(255,200,120,.85);background:linear-gradient(180deg,#ffbe7826,#b4501440);color:#fff;font-size:18px;font-weight:700;letter-spacing:.4px;text-align:center;box-shadow:0 0 0 1px #ffaa5a40,inset 0 1px 2px #ffffff40}.score-sep{margin:0 6px;opacity:.75}.atout-indicator{position:absolute;font-size:22px;font-weight:800;line-height:1;background:#fff;border-radius:999px;padding:4px 7px;box-shadow:0 2px 6px #0000002e,0 0 0 1px #781e1e1a;pointer-events:none}.atout-indicator.hearts,.atout-indicator.diamonds{color:#c01818}.atout-indicator.spades,.atout-indicator.clubs{color:#111}.atout-indicator.SA,.atout-indicator.TA{font-size:13px;font-weight:900;letter-spacing:0;padding:6px;min-width:26px;text-align:center}.atout-indicator.bottom{right:-46px;top:50%;transform:translateY(-50%)}.atout-indicator.top{left:-46px;top:28%;transform:translateY(-50%)}.atout-indicator.left,.atout-indicator.right{top:-48px;left:50%;transform:translate(-50%)}.new-game-btn{position:absolute;top:100px;left:50%;transform:translate(-50%);padding:8px 20px;border-radius:999px;background:#ffffff1f;color:#fff;font-size:14px;font-weight:600;border:1px solid rgba(255,200,120,.7);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 0 0 1px #ffaa5a40,0 8px 20px #00000073;z-index:40}.new-game-btn:hover{background:#ffffff2e}.card-back{width:60px;height:auto;-webkit-user-select:none;user-select:none;pointer-events:none}.back-cards{display:flex;align-items:center;justify-content:center;margin-top:6px}.back-cards-top{margin-top:8px}.back-cards-left{margin-top:8px;transform:translate(14px)}.back-cards-right{margin-top:8px;transform:translate(-14px)}.back-stack{position:relative;width:64px;height:64px}.back-stack .card-back{position:absolute;top:0;left:0}.back-count{margin-left:6px;font-weight:700;font-size:12px;opacity:.9}.card-img{width:100%;height:100%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.atout-card{background:transparent;padding:0;border-radius:0;box-shadow:none;width:100px;height:145px}.contree-panel{position:absolute;left:50%;top:310px;transform:translate(-50%);padding:10px 12px;border-radius:14px;background:#00143773;border:1px solid rgba(120,180,255,.18);box-shadow:0 0 14px #0096ff2e;color:#eaf6ffeb;min-width:240px;z-index:70;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.contree-title{font-weight:800;margin-bottom:6px}.contree-row{display:flex;justify-content:space-between;margin-bottom:10px;font-weight:700}.contree-actions{display:flex;gap:8px}.contree-btn{flex:1;height:34px;border-radius:10px;border:1px solid rgba(120,180,255,.25);background:#00236ed9;color:#eaf6ff;font-weight:800;cursor:pointer}.contree-btn:disabled{opacity:.45;cursor:not-allowed}.atout-panel.contree-encheres-panel{background:#0000002e!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;border:1px solid rgba(255,255,255,.2)!important;top:320px!important;color:#ffffffeb!important;width:520px!important;max-width:90vw!important;padding:14px 18px!important}.atout-panel.contree-encheres-panel:before,.atout-panel.contree-encheres-panel:after{content:none!important;display:none!important}.atout-panel.contree-encheres-panel .atout-title,.atout-panel.contree-encheres-panel .atout-actions{background:transparent!important}.atout-panel.contree-encheres-panel .atout-btn.pass{background:#7a1f1f!important;color:#fff!important}.contree-panel-inline{margin:10px auto 6px;padding:10px 12px;border-radius:14px;background:#00000024;border:1px solid rgba(255,255,255,.18);color:#ffffffeb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);width:92%}.contree-panel-inline .contree-btn{background:#7a1f1f!important;color:#fff!important;border:1px solid rgba(255,255,255,.18)!important;border-radius:12px!important;font-weight:900!important}.contree-panel-inline .contree-btn:hover:not(:disabled){filter:brightness(1.08)}.contree-panel-inline .contree-btn:disabled{background:#00000040!important;color:#ffffff73!important;border:1px solid rgba(255,255,255,.1)!important;opacity:1!important}.table-page[data-mode=classic] .atout-panel{background:#0000001f!important;backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 0 0 1px #ffffff0f,0 8px 18px #0006!important;color:#ffffffeb!important}.table-page[data-mode=classic][data-state=ANNOUNCE_ATOUT_TOUR_2] .atout-card{top:34%}.table-page[data-mode=classic][data-state=ANNOUNCE_ATOUT_TOUR_1] .atout-card{top:36%}.table-page[data-mode=classic] .atout-btn.pass{background:#7a1f1f;color:#fff}.table-page[data-mode=contree] .contree-panel-inline{background:#ffffff14;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.table-page[data-mode=contree] .contree-panel-inline,.table-page[data-mode=contree] .contree-panel-inline span{color:#ffffffeb}.table-page[data-mode=contree] .contree-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);color:#fffffff2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.table-page[data-mode=contree] .contree-btn:disabled{background:#ffffff0d;border-color:#ffffff1a;color:#ffffff8c;opacity:1}.atout-panel,.contree-encheres-panel{-webkit-user-select:none;user-select:none}.dealer-badge{position:absolute;top:-10px;left:-10px;width:22px;height:22px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px;background:#ffffffd9;color:#000;box-shadow:0 2px 8px #00000059}.table-page[data-mode=moderne] .atout-panel,.table-page[data-mode=moderne] .atout-panel--glass{background:#50121c8c;border:1px solid rgba(255,255,255,.18);box-shadow:0 12px 30px #00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.table-page[data-mode=moderne] .atout-title{color:#fffffff2}.table-page[data-mode=moderne][data-state=ANNOUNCE_ATOUT_TOUR_1] .atout-card{top:36%}.table-page[data-mode=moderne][data-state=ANNOUNCE_ATOUT_TOUR_2] .atout-card{top:34%}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{overscroll-behavior:none}.table-mode-pill{position:absolute;top:64px;left:20px;padding:6px 14px;border-radius:999px;background:#280a0a8c;color:#f0e6d2;border:1px solid rgba(220,180,120,.45);font-size:13px;font-weight:700;box-shadow:0 0 0 1px #ffaa5a2e,0 6px 14px #00000059;z-index:10;pointer-events:none}.last-trick-btn{position:absolute;top:102px;left:20px;z-index:12;padding:6px 13px;border-radius:999px;border:1px solid rgba(220,180,120,.45);background:#280a0a8c;color:#f0e6d2;font-size:12px;font-weight:800;cursor:pointer;box-shadow:0 0 0 1px #ffaa5a24,0 6px 14px #0000004d}.last-trick-btn:hover,.last-trick-btn.active{filter:brightness(1.12);border-color:#ffeb96bf}.last-trick-mini-table{position:absolute;top:136px;left:20px;z-index:12;width:clamp(152px,11.5vw,176px);height:clamp(132px,10vw,156px);border:1px solid rgba(220,180,120,.35);border-radius:12px;background:#280a0a94;box-shadow:0 0 0 1px #ffaa5a1a,0 6px 14px #00000047;pointer-events:none}.last-trick-mini-card{position:absolute}.last-trick-mini-card.pli-joueur1{bottom:10px;left:50%;transform:translate(-50%)}.last-trick-mini-card.pli-joueur2{top:10px;left:50%;transform:translate(-50%)}.last-trick-mini-card.pli-joueur3{top:50%;right:12px;transform:translateY(-50%)}.last-trick-mini-card.pli-joueur4{top:50%;left:12px;transform:translateY(-50%)}.last-trick-mini-img{display:block;width:clamp(46px,3.4vw,56px);height:auto;border-radius:4px;box-shadow:0 2px 7px #00000061}.start-with-bots-btn{position:absolute;top:72px;left:46%;transform:translate(-50%);z-index:35;padding:9px 16px;border:1px solid rgba(255,220,120,.5);border-radius:999px;background:linear-gradient(180deg,#7a0b27f5,#5f081ef5);color:#fff7d1;font-size:.95rem;font-weight:900;cursor:pointer;box-shadow:0 8px 18px #00000047}.start-with-bots-btn:hover{filter:brightness(1.08);border-color:#ffeb96bf}.admin-root{height:100vh;min-height:100vh;overflow-y:auto;padding:36px 36px 90px;box-sizing:border-box;background:radial-gradient(circle at top,rgba(38,92,180,.5),transparent 38%),linear-gradient(180deg,#061138,#020617);color:#fff}.admin-card{width:min(1100px,94vw);margin:0 auto;padding:28px;border-radius:24px;border:1px solid rgba(120,180,255,.28);background:#00164bd1;box-shadow:0 20px 55px #00000073,inset 0 0 16px #78b4ff1f}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px}.admin-header h1{margin:0;font-size:34px}.admin-header p{margin:8px 0 0;color:#cfe2ff;font-weight:700}.admin-back-btn,.admin-error-actions button,.admin-approve-btn,.admin-reject-btn,.admin-ban-btn,.admin-unban-btn,.admin-promote-btn,.admin-demote-btn{border:0;border-radius:999px;color:#fff;font-weight:900;cursor:pointer}.admin-back-btn{padding:11px 18px;background:linear-gradient(180deg,#2f7cff,#1f58c8)}.admin-user-line,.admin-info,.admin-empty,.admin-message,.admin-error{margin:14px 0;padding:14px 16px;border-radius:14px;font-weight:800}.admin-user-line,.admin-info,.admin-empty{background:#00236e9e;border:1px solid rgba(120,180,255,.22)}.admin-message{background:#1e964b40;border:1px solid rgba(118,255,166,.38);color:#c9ffd9}.admin-message-danger,.admin-error{background:#aa1e2d47;border:1px solid rgba(255,118,118,.42);color:#ffd1d1}.admin-error-actions{margin-top:14px}.admin-error-actions button{padding:10px 16px;background:linear-gradient(180deg,#2f7cff,#1f58c8)}.admin-section h2{margin:24px 0 14px;font-size:24px}.admin-users-list{display:flex;flex-direction:column;gap:12px}.admin-user-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:16px;background:#00236e9e;border:1px solid rgba(120,180,255,.22)}.admin-user-main{min-width:0}.admin-user-pseudo{font-size:20px;font-weight:900}.admin-user-email{margin-top:4px;color:#cfe2ff;font-weight:700}.admin-user-extra{margin-top:6px;color:#ffd1d1;font-size:13px;font-weight:800}.admin-user-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.admin-approve-btn,.admin-reject-btn,.admin-ban-btn,.admin-unban-btn,.admin-promote-btn,.admin-demote-btn{padding:10px 16px}.admin-approve-btn,.admin-ban-btn{background:linear-gradient(180deg,#48d663,#0f742b);color:#fff;border:1px solid rgba(150,255,175,.65)}.admin-reject-btn,.admin-unban-btn{background:linear-gradient(180deg,#d94848,#8f1717);color:#fff;border:1px solid rgba(255,170,170,.65)}.admin-contact-line{margin-top:8px;color:#cfe2ff;font-weight:800}.admin-contact-line a{color:#ffe27a;font-weight:900;text-decoration:none}.admin-contact-line a:hover{text-decoration:underline}.admin-promote-btn{background:linear-gradient(180deg,#ffe27a,#c69222);color:#1b1300}.admin-demote-btn{background:linear-gradient(180deg,#7f96c8,#3d568f)}.admin-user-pseudo.role-moderator{color:#ffe27a;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.55)}
