:root{--bg:#0a0a0f;--bg-dark:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a25;--cyan:#00f5ff;--accent-cyan:#00f5ff;--magenta:#ff00aa;--accent-magenta:#ff00aa;--yellow:#f5ff00;--accent-yellow:#f5ff00;--orange:#ff9500;--accent-orange:#ff9500;--green:#00ff88;--accent-green:#00ff88;--red:#ff4444;--accent-red:#ff4444;--gold:#ffd700;--text:#e8e8e8;--text-light:#e8e8e8;--text-secondary:#a0a0a0;--glass:rgba(255,255,255,0.05);--glass-border:rgba(255,255,255,0.1);--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:'Space Grotesk',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding:var(--safe-top) var(--safe-right) var(--safe-bottom) var(--safe-left)}button,a,input[type="submit"],select,[onclick]{touch-action:manipulation}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.3)}.scrollable{scroll-behavior:smooth}.bg-grid{position:fixed;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(0,245,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,245,255,0.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:0}.floating-orb{position:fixed;border-radius:50%;-webkit-filter:blur(80px);filter:blur(80px);opacity:0.4;pointer-events:none;z-index:0}.orb-1{width:400px;height:400px;background:var(--orange);top:-100px;right:-100px;-webkit-animation:float1 15s ease-in-out infinite;animation:float1 15s ease-in-out infinite}.orb-2{width:300px;height:300px;background:var(--cyan);bottom:-50px;left:-50px;-webkit-animation:float2 12s ease-in-out infinite;animation:float2 12s ease-in-out infinite}@-webkit-keyframes float1{0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)}50%{-webkit-transform:translate(-50px,50px) scale(1.1);transform:translate(-50px,50px) scale(1.1)}}@keyframes float1{0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)}50%{-webkit-transform:translate(-50px,50px) scale(1.1);transform:translate(-50px,50px) scale(1.1)}}@-webkit-keyframes float2{0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)}50%{-webkit-transform:translate(30px,-30px) scale(1.15);transform:translate(30px,-30px) scale(1.15)}}@keyframes float2{0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)}50%{-webkit-transform:translate(30px,-30px) scale(1.15);transform:translate(30px,-30px) scale(1.15)}}.container{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:20px}.logo{text-align:center;padding:20px 0}.logo img,.logo-img{max-width:180px;height:auto;-webkit-filter:drop-shadow(0 5px 20px rgba(255,165,0,0.4));filter:drop-shadow(0 5px 20px rgba(255,165,0,0.4));-webkit-transition:-webkit-transform 0.4s ease;transition:transform 0.4s ease}.logo img:hover,.logo-img:hover{-webkit-transform:scale(1.05);transform:scale(1.05)}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--cyan);text-decoration:none;font-size:0.9rem;margin-bottom:20px;-webkit-transition:all 0.3s;transition:all 0.3s}.back-link:hover{text-decoration:underline;-webkit-transform:translateX(-5px);transform:translateX(-5px)}h1{font-family:'Syne',sans-serif;font-weight:800}h2,h3{font-family:'Syne',sans-serif}footer{text-align:center;padding:40px 20px;padding-bottom:calc(40px + var(--safe-bottom));color:var(--text-secondary);font-size:0.9rem}footer a{color:var(--cyan);text-decoration:none}footer a:hover{text-decoration:underline}.footer-links{display:flex;justify-content:center;gap:25px;margin-top:15px;flex-wrap:wrap}.toast{position:fixed;bottom:20px;bottom:calc(20px + var(--safe-bottom));right:20px;right:calc(20px + var(--safe-right));padding:15px 25px;background:var(--green);color:var(--bg);border-radius:10px;font-weight:700;-webkit-transform:translateX(150%);transform:translateX(150%);-webkit-transition:-webkit-transform 0.3s;transition:transform 0.3s;z-index:1000}.toast.show{-webkit-transform:translateX(0);transform:translateX(0)}.toast.error{background:var(--red);color:white}.spinner,.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,0.1);border-top-color:var(--cyan);border-radius:50%;-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite;margin:0 auto 15px}@-webkit-keyframes spin{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes spin{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@-webkit-keyframes fadeInUp{from{opacity:0;-webkit-transform:translateY(40px);transform:translateY(40px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes fadeInUp{from{opacity:0;-webkit-transform:translateY(40px);transform:translateY(40px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes fadeInDown{from{opacity:0;-webkit-transform:translateY(-30px);transform:translateY(-30px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes fadeInDown{from{opacity:0;-webkit-transform:translateY(-30px);transform:translateY(-30px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes slideIn{from{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes slideIn{from{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes pulse{0%,100%{box-shadow:0 0 20px rgba(0,255,136,0.2)}50%{box-shadow:0 0 40px rgba(0,255,136,0.4)}}@keyframes pulse{0%,100%{box-shadow:0 0 20px rgba(0,255,136,0.2)}50%{box-shadow:0 0 40px rgba(0,255,136,0.4)}}@-webkit-keyframes gridMove{0%{-webkit-transform:translate(0,0);transform:translate(0,0)}100%{-webkit-transform:translate(50px,50px);transform:translate(50px,50px)}}@keyframes gridMove{0%{-webkit-transform:translate(0,0);transform:translate(0,0)}100%{-webkit-transform:translate(50px,50px);transform:translate(50px,50px)}}@media (max-width:768px){h1{font-size:2rem}.container{padding:15px}.floating-orb{display:none}}@media (max-width:480px){h1{font-size:1.6rem}.container{padding:12px}}.nav-dropdown{position:fixed;top:16px;top:calc(16px + var(--safe-top));right:16px;right:calc(16px + var(--safe-right));z-index:9999}.nav-dropdown select{padding:12px 44px 12px 20px;min-width:220px;background:linear-gradient(135deg,rgba(18,18,26,0.95),rgba(26,26,37,0.95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1.5px solid rgba(0,245,255,0.25);border-radius:14px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:600;letter-spacing:0.3px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2300f5ff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;-webkit-transition:transform 0.3s ease,opacity 0.3s ease;transition:transform 0.3s ease,opacity 0.3s ease;box-shadow:0 4px 20px rgba(0,0,0,0.4),0 0 15px rgba(0,245,255,0.08);will-change:transform,opacity}.nav-dropdown select:hover{opacity:1.05;-webkit-transform:translateY(-1px);transform:translateY(-1px)}.nav-dropdown select:focus{outline:none}.nav-dropdown select option{background:#12121a;color:var(--text);padding:12px 16px;font-size:0.95rem;font-weight:500}@media (max-width:600px){.nav-dropdown{top:10px;top:calc(10px + var(--safe-top));right:10px;right:calc(10px + var(--safe-right))}.nav-dropdown select{min-width:180px;font-size:0.9rem;padding:10px 38px 10px 16px;border-radius:12px}}.tino-iot-banner{position:fixed;top:16px;top:calc(16px + var(--safe-top));left:16px;left:calc(16px + var(--safe-left));z-index:9999;text-decoration:none;display:flex;align-items:center;gap:10px;padding:8px 16px 8px 10px;background:linear-gradient(135deg,rgba(18,18,26,0.95),rgba(26,26,37,0.95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1.5px solid rgba(0,255,136,0.3);border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,0.4),0 0 15px rgba(0,255,136,0.1);-webkit-transition:transform 0.3s ease,opacity 0.3s ease;transition:transform 0.3s ease,opacity 0.3s ease;-webkit-animation:bannerSlideIn 0.6s ease-out;animation:bannerSlideIn 0.6s ease-out;will-change:transform,opacity}.tino-iot-banner:hover{-webkit-transform:translateY(-2px);transform:translateY(-2px)}.tino-iot-banner-icon{font-size:1.5rem;line-height:1;-webkit-animation:iotPulse 2s ease-in-out infinite;animation:iotPulse 2s ease-in-out infinite}.tino-iot-banner-text{display:flex;flex-direction:column;gap:1px}.tino-iot-banner-title{font-family:'Syne',sans-serif;font-weight:800;font-size:0.8rem;letter-spacing:0.5px;background:linear-gradient(135deg,var(--green),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tino-iot-banner-sub{font-size:0.6rem;color:var(--text-secondary);font-weight:600;letter-spacing:0.3px}.tino-iot-banner-dot{width:6px;height:6px;background:var(--green);border-radius:50%;-webkit-animation:dotBlink 1.5s ease-in-out infinite;animation:dotBlink 1.5s ease-in-out infinite;box-shadow:0 0 8px var(--green);flex-shrink:0}@-webkit-keyframes bannerSlideIn{from{opacity:0;-webkit-transform:translateX(-30px);transform:translateX(-30px)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes bannerSlideIn{from{opacity:0;-webkit-transform:translateX(-30px);transform:translateX(-30px)}to{opacity:1;-webkit-transform:translateX(0);transform:translateX(0)}}@-webkit-keyframes iotPulse{0%,100%{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.15);transform:scale(1.15)}}@keyframes iotPulse{0%,100%{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.15);transform:scale(1.15)}}@-webkit-keyframes dotBlink{0%,100%{opacity:1}50%{opacity:0.3}}@keyframes dotBlink{0%,100%{opacity:1}50%{opacity:0.3}}@media (max-width:600px){.tino-iot-banner{top:10px;top:calc(10px + var(--safe-top));left:10px;left:calc(10px + var(--safe-left));padding:6px 12px 6px 8px;gap:8px;border-radius:12px}.tino-iot-banner-icon{font-size:1.2rem}.tino-iot-banner-title{font-size:0.7rem}.tino-iot-banner-sub{font-size:0.55rem}}.share-fab{position:fixed;bottom:24px;bottom:calc(24px + var(--safe-bottom));right:24px;right:calc(24px + var(--safe-right));z-index:9998}.share-fab-btn{width:56px;height:56px;border-radius:50%;border:1.5px solid rgba(0,245,255,0.3);background:linear-gradient(135deg,rgba(18,18,26,0.95),rgba(26,26,37,0.95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--cyan);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,0.4),0 0 15px rgba(0,245,255,0.1);-webkit-transition:transform 0.3s ease,opacity 0.3s ease;transition:transform 0.3s ease,opacity 0.3s ease;will-change:transform,opacity}.share-fab-btn:hover{opacity:1.1;-webkit-transform:scale(1.08);transform:scale(1.08)}.share-fab-btn svg{width:24px;height:24px;fill:var(--cyan)}.share-fab-menu{position:absolute;bottom:66px;right:0;background:linear-gradient(135deg,rgba(18,18,26,0.98),rgba(26,26,37,0.98));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1.5px solid rgba(0,245,255,0.2);border-radius:16px;padding:10px;min-width:200px;box-shadow:0 8px 32px rgba(0,0,0,0.5),0 0 20px rgba(0,245,255,0.08);opacity:0;visibility:hidden;-webkit-transform:translateY(10px) scale(0.95);transform:translateY(10px) scale(0.95);-webkit-transition:opacity 0.25s ease,visibility 0.25s ease,-webkit-transform 0.25s ease;transition:opacity 0.25s ease,visibility 0.25s ease,transform 0.25s ease;will-change:opacity,transform}.share-fab-menu.open{opacity:1;visibility:visible;-webkit-transform:translateY(0) scale(1);transform:translateY(0) scale(1)}.share-fab-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;border-radius:10px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:0.9rem;font-weight:500;cursor:pointer;-webkit-transition:transform 0.2s ease,opacity 0.2s ease;transition:transform 0.2s ease,opacity 0.2s ease;text-align:left;will-change:transform,opacity;position:relative;overflow:hidden}.share-fab-menu-item::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,245,255,0.08);opacity:0;-webkit-transition:opacity 0.2s ease;transition:opacity 0.2s ease;z-index:-1}.share-fab-menu-item:hover::before{opacity:1}.share-fab-menu-item:hover{-webkit-transform:translateX(4px);transform:translateX(4px)}.share-fab-menu-item svg{width:20px;height:20px;flex-shrink:0}.share-fab-menu-item .sfm-icon{font-size:1.2rem;width:20px;text-align:center;flex-shrink:0}@media (max-width:600px){.share-fab{bottom:16px;bottom:calc(16px + var(--safe-bottom));right:16px;right:calc(16px + var(--safe-right))}.share-fab-btn{width:50px;height:50px;font-size:1.2rem}.share-fab-btn svg{width:22px;height:22px}.share-fab-menu{bottom:60px;min-width:180px}}.skip-link{position:absolute;top:-40px;left:0;background:var(--cyan);color:var(--bg);padding:8px 16px;z-index:100;font-weight:700;text-decoration:none;border-radius:0 0 8px 0}.skip-link:focus{top:0}.share-btn{text-decoration:none;padding:12px 20px;border-radius:8px;font-weight:600;transition:all 0.3s ease;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.share-btn.primary{background:linear-gradient(135deg,var(--accent-orange),var(--accent-yellow));color:var(--bg-dark)}.share-btn.primary:hover{opacity:0.9;transform:translateY(-2px);box-shadow:0 8px 16px rgba(0,245,255,0.2)}.share-btn.secondary{background:none;border:2px solid;color:var(--accent-magenta)}.share-btn.secondary{border-color:var(--accent-magenta)}.share-btn.quiz{background:linear-gradient(135deg,var(--accent-orange),var(--accent-yellow));color:var(--bg-dark)}.share-btn.sondages{background:linear-gradient(135deg,#aa00ff,var(--accent-cyan))}.share-btn.debat{background:linear-gradient(135deg,#00ff88,#ff4444);color:white}.share-btn.messagerie{border-color:var(--accent-magenta);color:var(--accent-magenta)}.share-btn.forum{border-color:var(--accent-cyan);color:var(--accent-cyan)}.share-btn.creations{background:linear-gradient(135deg,var(--accent-magenta),var(--accent-cyan))}.share-btn.premium{background:linear-gradient(135deg,#ffd700,#ff9500);color:#0a0a0f}.share-btn.boutique{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-magenta))}.share-btn.veille{background:linear-gradient(135deg,#00f5ff,#aa00ff)}.share-buttons{display:flex;flex-wrap:wrap;gap:12px}.share-buttons.margin-top{margin-top:15px}.share-buttons.margin-top-lg{margin-top:20px}.d-none{display:none!important}.d-flex{display:flex}.flex-col{flex-direction:column}.align-center{align-items:center}.gap-1{gap:8px}.gap-2{gap:12px}.gap-3{gap:16px}.mt-1{margin-top:10px}.mt-2{margin-top:15px}.mt-3{margin-top:20px}.text-small{font-size:0.85rem}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.link-cyan{color:var(--cyan);text-decoration:none}.link-cyan:hover{text-decoration:underline}.modal-fullscreen{max-width:100%!important;width:100%!important;max-height:100vh!important;height:100vh!important;background:#0a0a0f!important;border-radius:0!important;border:none!important}.modal-header-gradient{background:linear-gradient(135deg,rgba(255,68,68,0.2),rgba(255,149,0,0.2));padding:12px 20px;flex-shrink:0}.modal-body-full{padding:0;max-height:none;overflow:hidden;flex:1;display:flex;flex-direction:column}.position-relative{position:relative}.vc-join-screen{padding:40px 20px;text-align:center;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.vc-icon{font-size:4rem;margin-bottom:20px}.vc-title{font-family:'Syne',sans-serif;font-size:1.3rem;margin-bottom:10px}.vc-desc{color:rgba(255,255,255,0.6);margin-bottom:20px}.vc-btn{padding:15px 35px;border:none;border-radius:15px;font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;cursor:pointer;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-magenta));color:white}.vc-grid{display:none;padding:10px;background:#000;flex:1;align-content:center}.vc-controls{display:none;padding:15px;background:rgba(0,0,0,0.8);justify-content:center;gap:12px;align-items:center;flex-shrink:0}.vc-count{font-size:0.8rem;color:rgba(255,255,255,0.6)}.vc-header-flex{display:flex;align-items:center;gap:10px}.invites-btn{background:rgba(255,255,255,0.1)}.empty-invitation{color:var(--text-secondary);text-align:center;padding:20px}.btn-danger-red{background:var(--red);color:white}.text-orange{color:var(--orange)}.text-green{color:var(--green)}.text-cyan{color:var(--cyan)}.text-success{color:var(--green)}.text-warning{color:var(--orange)}.text-info{color:var(--cyan)}.text-danger{color:var(--red)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.global-user-badge{position:fixed;top:74px;top:calc(74px + var(--safe-top));right:16px;right:calc(16px + var(--safe-right));z-index:9998;display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:linear-gradient(135deg,rgba(18,18,26,0.95),rgba(26,26,37,0.95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1.5px solid rgba(255,0,170,0.3);border-radius:30px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:0.8rem;font-weight:600;text-decoration:none;-webkit-transition:transform 0.3s ease,border-color 0.3s ease,box-shadow 0.3s ease;transition:transform 0.3s ease,border-color 0.3s ease,box-shadow 0.3s ease;box-shadow:0 4px 16px rgba(0,0,0,0.4),0 0 12px rgba(255,0,170,0.08);white-space:nowrap;-webkit-animation:bannerSlideIn 0.5s ease-out;animation:bannerSlideIn 0.5s ease-out}.global-user-badge:hover{-webkit-transform:translateY(-2px);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.5),0 0 16px rgba(255,0,170,0.2)}.global-user-badge.connected{border-color:rgba(0,245,255,0.35);box-shadow:0 4px 16px rgba(0,0,0,0.4),0 0 12px rgba(0,245,255,0.1)}.global-user-badge.connected:hover{box-shadow:0 6px 20px rgba(0,0,0,0.5),0 0 18px rgba(0,245,255,0.2)}.gub-icon{font-size:1rem;line-height:1}.gub-text{color:var(--text)}.gub-avatar{width:22px;height:22px;background:var(--accent-orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.7rem;color:var(--bg-dark);flex-shrink:0}@media (max-width:600px){.global-user-badge{top:64px;top:calc(64px + var(--safe-top));right:10px;right:calc(10px + var(--safe-right));padding:6px 12px;font-size:0.75rem}.gub-avatar{width:20px;height:20px;font-size:0.65rem}}