@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.container{width:100%}.block{display:block}.contents{display:contents}.flex{display:flex}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.h-\[100dvh\]{height:100dvh}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-\[480px\]{max-width:480px}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.bg-\[\#f3f4f6\]{background-color:#f3f4f6}.bg-\[url\(\'\/diagonal-lines\.svg\'\)\]{background-image:url(/diagonal-lines.svg)}.bg-repeat{background-repeat:repeat}.uppercase{text-transform:uppercase}.opacity-40{opacity:.4}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#0f172a;background-color:#f8faf9;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}html,body,#root{height:100%;overflow:hidden}body{background-color:#f8faf9;margin:0}button,a,[role=button]{-webkit-tap-highlight-color:transparent}.map-screen{box-sizing:border-box;background:#f8fafc;justify-content:stretch;align-items:stretch;height:100dvh;min-height:100dvh;padding:0;display:flex;overflow:hidden}@supports (height:100dvh){html,body,#root{height:100dvh}.map-screen{height:100dvh;min-height:100dvh}}.map-frame{-webkit-overflow-scrolling:touch;width:100%;height:100%;max-height:none;box-shadow:none;background:#f8fafc;border-radius:0;position:relative;overflow-y:auto}@media(max-width:500px)and (max-height:950px){.map-screen{justify-content:center;align-items:center;padding:24px 16px}.map-frame{border-radius:36px;width:390px;height:100%;max-height:100%;box-shadow:0 20px 60px #0f172a14}}.map-road{width:auto;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.map-header{z-index:10;position:absolute;top:32px;left:24px}.map-label{letter-spacing:.35em;text-transform:uppercase;color:#94a3b8;font-size:12px;font-weight:600}.map-title{color:#0f172a;margin:4px 0 0;font-size:30px;font-weight:600}.map-start{z-index:20;flex-direction:column;align-items:center;gap:12px;display:flex;position:absolute;top:300px;left:88px}.map-start-pill{color:#2b8cee;background:#fff;border:1px solid #dbeafe;border-radius:999px;padding:4px 20px;font-size:14px;font-weight:600;box-shadow:0 10px 20px #0f172a1f}.map-start-button{cursor:pointer;background:#2b8cee;border:10px solid #dbeafe;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;display:flex;box-shadow:0 14px 28px #0f172a29}.map-nav{z-index:20;width:350px;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.map-nav-inner{background:#fff;border:1px solid #e2e8f0;border-radius:36px;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;box-shadow:0 18px 40px #0f172a1f}.map-nav-item{background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:0;display:flex}.map-nav-item img{width:28px;height:28px}.map-nav-label{color:#64748b;font-size:14px;font-weight:500}.map-nav-label.active{color:#2b8cee}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.map-screen{height:100dvh;min-height:100dvh;display:flex;justify-content:stretch;align-items:stretch;padding:0;border-radius:36px;box-sizing:border-box;background:#f8fafc;top:0;position:relative}@media(max-width:500px)and (max-height:950px){.map-screen{justify-content:center;align-items:center;padding:16px;top:-2%}}.floating-wrong-button{position:fixed;top:20px;left:20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#ff4757,#ff3838);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #ff475766;transition:all .3s ease;z-index:1000}@media(min-width:1024px){.floating-wrong-button,.floating-fb-button{display:none}}.floating-wrong-button:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 12px 30px #ff475799}.floating-wrong-button:active{transform:scale(.95)}.floating-wrong-button .wrong-icon{font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.floating-wrong-button .wrong-badge{position:absolute;top:-5px;right:-5px;background:#fff;color:#ff4757;font-size:14px;font-weight:700;padding:4px 8px;border-radius:12px;min-width:24px;text-align:center;box-shadow:0 2px 8px #0003;line-height:1}.floating-fb-button{position:fixed;top:90px;left:20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#1877f2,#0c63d4);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #1877f266;transition:all .3s ease;z-index:1000;text-decoration:none;padding:10px}.floating-fb-button:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 12px 30px #1877f299}.floating-fb-button:active{transform:scale(.95)}.floating-fb-button img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.map-frame{position:relative;width:100%;height:100%;max-width:none;max-height:none;aspect-ratio:auto;border-radius:0;overflow:hidden;background:#f8fafc;box-shadow:none}.map-total-tickets{position:absolute;top:20px;left:50%;transform:translate(-50%);font-size:14px;color:#666;opacity:.7;z-index:10;pointer-events:none;font-weight:500}.map-scroll{position:relative;height:100%;overflow-y:auto;scroll-snap-type:y mandatory;display:flex;top:0;flex-direction:column;scrollbar-width:none}@media(max-width:500px)and (max-height:950px){.map-frame{width:min(100vw,390px);height:auto;aspect-ratio:390 / 844;max-height:100vh;border-radius:36px;box-shadow:0 20px 60px #0f172a1f}.map-scroll{top:-5%}}.map-scroll::-webkit-scrollbar{width:0;height:0}.map-page{position:relative;flex:0 0 100%;height:100%;scroll-snap-align:start}.map-road{position:absolute;left:50%;transform:rotate(190deg);top:0;height:100%;width:auto;transform:translate(-50%)}.map-car{position:absolute;width:clamp(50px,calc(var(--road-width, 255px) * .22 * var(--car-scale, 1)),160px);height:auto;transform:translate(-50%,-50%) rotate(var(--rotation));transform-origin:center;z-index:0;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25));pointer-events:none;will-change:transform}.level-button{position:absolute;top:var(--btn-top);left:var(--btn-left);transform:translate(-50%,-50%);transform-origin:center;pointer-events:auto;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}.level-button *{cursor:pointer}.level-button .container{gap:12px}.level-number{font-size:15px;font-weight:600;color:#1f2937;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.level-number{display:block;max-width:150px;white-space:normal;word-break:normal;overflow-wrap:break-word;word-spacing:2px;line-height:1.2;text-align:center}.level-button--completed{transform:translate(-50%,-50%) scale(.85)}.level-button--active{transform:translate(-50%,-50%) scale(.56)}.level-button--locked{transform:translate(-50%,-50%) scale(.78)}.level-button--locked .level-number{color:#9ca3af}.level-button--quiz .pill-btn{background:#fbbf24;color:#7c2d12;box-shadow:0 8px 18px #fbbf2473}.level-button--quiz .play-btn{background:#f59e0b;box-shadow:0 10px 20px #f59e0b73}.level-button--quiz .play-btn svg path{fill:#fff7ed}.level-button--quiz .level-number{color:#92400e}.map-frame .bottom-nav{position:absolute;bottom:26px;left:50%;transform:translate(-50%);width:min(86%,350px);max-width:350px;padding:16px 0;border-radius:34px;z-index:30}.map-frame .nav-item{font-size:11px;gap:4px;cursor:pointer}.map-frame .nav-item *{cursor:pointer}@media(max-width:420px)and (max-height:950px){.map-frame{border-radius:28px}}.bottom-nav{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:500px;display:flex;justify-content:space-around;align-items:center;padding:14px 0;background:#fff;border-radius:30px;box-shadow:0 6px 20px #0000001a;border:.7px solid #E2E8F0;z-index:100}@media(min-width:1024px){.bottom-nav{display:none}}.nav-item{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;color:#7a7a7a;cursor:pointer!important;font-weight:semibold;text-decoration:none}.nav-item *{cursor:pointer!important}.nav-fb-icon{width:22px;height:22px;-o-object-fit:contain;object-fit:contain}.nav-emoji{font-size:18px;line-height:1;display:block}.nav-item .icon{width:20px;height:20px;display:block;background-color:currentColor;mask-repeat:no-repeat;mask-position:center;mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain}.icon--home{mask-image:url(/assets/nav_home_icon.svg);-webkit-mask-image:url(/assets/nav_home_icon.svg)}.icon--education{mask-image:url(/assets/nav_education_icon.svg);-webkit-mask-image:url(/assets/nav_education_icon.svg)}.icon--duel{mask-image:url("data:image/svg+xml;utf8,<svg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'><path%20d='M2%2021l6-6'/><path%20d='M4%2015l5%205'/><path%20d='M14%203l7%207'/><path%20d='M10%207l7%207'/><path%20d='M3%203l6%206'/><path%20d='M21%2021l-6-6'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'><path%20d='M2%2021l6-6'/><path%20d='M4%2015l5%205'/><path%20d='M14%203l7%207'/><path%20d='M10%207l7%207'/><path%20d='M3%203l6%206'/><path%20d='M21%2021l-6-6'/></svg>")}.icon--exam{mask-image:url(/assets/nav_exam_icon.svg);-webkit-mask-image:url(/assets/nav_exam_icon.svg)}.icon--profile{mask-image:url(/assets/nav_profile_icon.svg);-webkit-mask-image:url(/assets/nav_profile_icon.svg)}.nav-item.active{color:#2f80ed}.nav-item.active img{filter:brightness(0) saturate(100%) invert(47%) sepia(88%) saturate(1353%) hue-rotate(195deg) brightness(95%) contrast(91%)}.desktop-nav-left{position:fixed;left:0;top:0;height:100vh;width:100px;background:#fff;border-right:1px solid #E2E8F0;box-shadow:2px 0 10px #0000000d;z-index:999;display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:16px;overflow:visible}.desktop-logo{width:62px;height:62px;margin-bottom:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease}.desktop-logo:hover{transform:scale(1.05)}.desktop-logo img{width:100px;height:100px;-o-object-fit:contain;object-fit:contain;border-radius:50%}.desktop-nav-item{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:12px;color:#7a7a7a;cursor:pointer;text-decoration:none;padding:10px 12px;border-radius:12px;transition:all .2s;width:76px}.desktop-nav-item:hover{background:#f8f9fa}.desktop-nav-item.active{color:#2f80ed;background:#e3f2fd}.desktop-nav-item .icon{width:22px;height:22px;display:block;background-color:currentColor;mask-repeat:no-repeat;mask-position:center;mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain}.desktop-nav-item img{width:22px;height:22px}.desktop-nav-item.active img{filter:brightness(0) saturate(100%) invert(47%) sepia(88%) saturate(1353%) hue-rotate(195deg) brightness(95%) contrast(91%)}.desktop-nav-spacer{flex:1}.desktop-nav-bottom{width:100%;margin-top:auto;padding:12px 0 10px;border-top:1px solid #E2E8F0;display:flex;flex-direction:column;align-items:center;gap:12px;position:relative}.desktop-fb-callout{position:absolute;left:calc(100% + 14px);bottom:18px;width:350px;min-height:78px;padding:12px 16px;border-radius:16px;border:1px solid #dbeafe;background:linear-gradient(180deg,#f8fbff,#eef5ff);display:flex;align-items:center;gap:12px;text-decoration:none;box-shadow:0 10px 26px #2563eb1f;transition:transform .2s ease,box-shadow .2s ease}.desktop-fb-callout:hover{transform:translateY(-1px);box-shadow:0 14px 28px #2563eb2e}.desktop-fb-callout-logo-wrap{width:56px;height:56px;border-radius:999px;background:#fff;border:1px solid #bfdbfe;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.desktop-fb-callout-logo{width:46px;height:46px;-o-object-fit:contain;object-fit:contain}.desktop-fb-callout-text{margin:0;color:#1d4ed8;font-size:12px;font-weight:700;line-height:1.35}.desktop-action-item{border:0;background:transparent}.desktop-action-item--hidden{visibility:hidden;pointer-events:none}.action-icon-wrapper{position:relative;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;transition:all .3s ease}.action-icon-wrapper.fb-icon{border:solid 1px #1877f2;padding:6px}.desktop-nav-item:hover .action-icon-wrapper{transform:scale(1.1);box-shadow:0 6px 20px #00000040}.action-icon-wrapper .wrong-icon{font-size:22px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.action-icon-wrapper .wrong-badge{position:absolute;top:-5px;right:-5px;background:#fff;color:#ff4757;font-size:12px;font-weight:700;padding:3px 6px;border-radius:10px;min-width:20px;text-align:center;box-shadow:0 2px 8px #0003;line-height:1}.action-icon-wrapper img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.container{display:flex;flex-direction:column;gap:24px;align-items:center}.pill-btn{padding:10px 28px;border-radius:999px;border:2px solid #cfe3f7;background:#fff;color:#1e88e5;font-size:18px;font-weight:500;cursor:pointer!important}.pill-btn *{cursor:pointer!important}.play-btn{width:140px;height:140px;border-radius:50%;border:none;background:#2f8cf0;position:relative;cursor:pointer!important}.play-btn *{cursor:pointer!important}.play-icon{position:absolute;top:50%;left:50%;transform:translate(-40%,-50%);width:0;height:0;border-top:22px solid transparent;border-bottom:22px solid transparent;border-left:36px solid #fff}.badge{position:relative;width:80px;height:80px;border-radius:50%;background:#6ad400;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 12px #0003}.check{color:#fff;font-size:36px;font-weight:700}.star{position:absolute;color:#ffd400;font-size:24px}.star-1{top:-18px;right:16px}.star-2{bottom:-12px;right:6px}.star-3{bottom:8px;left:-9px}.lock-circle{width:96px;height:96px;background:#9aa7b8;border-radius:50%;display:flex;align-items:center;justify-content:center}.lock{position:relative;width:32px;height:40px}.lock-shackle{position:absolute;top:0;left:50%;width:20px;height:16px;border:4px solid white;border-bottom:none;border-radius:12px 12px 0 0;transform:translate(-50%)}.lock-body{position:absolute;bottom:0;width:32px;height:24px;background:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center}.lock-dot{width:6px;height:6px;background:#9aa7b8;border-radius:50%}.overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center}.card{position:relative;width:80%;max-width:360px;height:80%;max-height:80vh;background:#fff;border-radius:28px;padding:20px;text-align:center;overflow:auto}.close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:#eef2f6;font-size:20px;cursor:pointer}.image{height:35%;border-radius:20px;background:url(./intersection.png) center / cover no-repeat;margin-bottom:20px;width:100%}.title{font-size:22px;margin:8px 0}.description{font-size:14px;color:#6b7280;margin-bottom:16px}.badge2{display:inline-block;background:#fff3d6;color:#f59e0b;padding:6px 4px;border-radius:999px;font-size:14px;margin-bottom:20px}.badge2--tickets{margin-top:-8px;margin-bottom:20px}.primary{width:100%;height:56px;border-radius:18px;border:none;background:#3b82f6;color:#fff;font-size:18px;font-weight:600;cursor:pointer}.lessons-page{max-width:420px;margin:0 auto;padding:32px 20px}.lessons-title{font-size:34px;margin:0;color:#1f2937}.lessons-subtitle{color:#9ca3af;margin:8px 0 24px}.lessons-search{display:flex;align-items:center;background:#f9fafb;border-radius:16px;padding:14px 16px;margin-bottom:28px;border:1px solid #e5e7eb}.lessons-search input{border:none;outline:none;background:transparent;margin-left:10px;font-size:16px;width:100%}.lessons-search-icon{font-size:18px;opacity:.5}.lessons-card{display:flex;gap:16px;background:#fff;border-radius:24px;padding:18px;margin-bottom:18px;box-shadow:0 12px 24px #0000000f;cursor:pointer}.lessons-icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600}.lessons-icon.blue{background:#3b82f6;color:#fff}.lessons-icon.yellow{background:#fef3c7;color:#d97706}.lessons-icon.green{background:#dcfce7;color:#16a34a}.lessons-content{flex:1}.lessons-content.row{display:flex;justify-content:space-between;align-items:center}.lessons-card-title{font-size:18px;font-weight:600;color:#1f2937}.lessons-card-desc{font-size:14px;color:#6b7280;margin-top:4px}.lessons-badge{display:inline-block;margin-top:10px;padding:6px 12px;font-size:13px;background:#eff6ff;color:#2563eb;border-radius:999px}.lessons-counter{font-size:14px;color:#9ca3af}.regulator-icon{width:100%;height:100%;display:block}.duel-page{max-width:100%;margin:0 auto;padding:24px 16px 120px;height:100vh;overflow-y:auto;overflow-x:hidden}.duel-title{text-align:center;font-size:26px;margin:0}.duel-subtitle{text-align:center;color:#8b94a3;margin:8px 0 24px}.duel-card{background:#fff;border-radius:28px;padding:24px;width:100%;display:flex;align-items:center;justify-content:space-between;box-shadow:0 20px 40px #00000014}.duel-player{display:flex;flex-direction:column;align-items:center;gap:8px}.duel-avatar{width:96px;height:96px;border-radius:50%;border:3px solid #3b82f6;display:flex;align-items:center;justify-content:center;background:#eff6ff}.duel-avatar--dashed{border:3px dashed #cbd5e1;background:#f8fafc;color:#cbd5e1;font-size:32px}.duel-icon{width:32px;height:4px;background:#3b82f6;border-radius:2px;position:relative}.duel-icon:before{content:"";position:absolute;width:4px;height:24px;background:#3b82f6;left:14px;top:-10px;border-radius:2px}.duel-vs{background:#fde047;color:#92400e;font-weight:700;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}.duel-muted{color:#9ca3af}.duel-name{font-size:13px;color:#64748b;font-weight:500}.duel-section-title{font-size:18px;font-weight:600;margin:32px 0 16px;color:#1e293b}.duel-chips{display:flex;gap:12px}.duel-chip{flex:1;text-align:center;padding:12px 24px;border-radius:14px;border:2px solid #e5e7eb;background:#fff;font-size:18px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s}.duel-chip:hover{border-color:#d1d5db}.duel-chip--active{background:#3b82f6;color:#fff;border-color:#3b82f6}.duel-input{width:100%;padding:16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;text-align:center;text-transform:uppercase;letter-spacing:4px;margin-bottom:16px;font-weight:600;color:#1e293b}.duel-input:focus{outline:none;border-color:#3b82f6;background:#eff6ff}.duel-input::-moz-placeholder{color:#cbd5e1;letter-spacing:normal}.duel-input::placeholder{color:#cbd5e1;letter-spacing:normal}.duel-button{width:100%;padding:16px;border:none;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.duel-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.duel-button:active{transform:translateY(0)}.duel-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.duel-error{color:#ef4444;background:#fee2e2;padding:12px;border-radius:8px;font-size:14px;text-align:center;margin-top:16px}.duel-invite{background:#eff6ff;border-radius:20px;padding:20px;margin:32px 0}.duel-invite h3{margin:0 0 6px;color:#1d4ed8}.duel-invite p{margin:0 0 16px;color:#60a5fa}.duel-link-box{background:#fff;border-radius:14px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;color:#2563eb;font-weight:500}.duel-link-btn{border:none;background:#e0edff;border-radius:10px;padding:6px 10px;cursor:pointer}.duel-cta{width:100%;background:#1f2937;color:#fff;border:none;border-radius:28px;padding:18px;margin-top:16px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s}.duel-cta:hover{background:#374151;transform:translateY(-2px)}.duel-success{background:#d1fae5;border-radius:16px;padding:20px;margin-top:16px}.duel-success-title{font-size:18px;font-weight:600;color:#065f46;margin-bottom:12px}.duel-code{font-size:32px;font-weight:700;color:#047857;text-align:center;letter-spacing:8px;margin:16px 0}.duel-link{background:#fff;padding:12px;border-radius:8px;font-size:12px;color:#047857;word-break:break-all;margin-top:12px}.duel-waiting{text-align:center;color:#6b7280;font-size:14px;margin-top:12px}.privacy-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px}.privacy-modal{background:#fff;border-radius:20px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.privacy-header{padding:25px 30px;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.privacy-header h2{margin:0;font-size:24px;color:#111827;font-weight:700}.privacy-close{width:40px;height:40px;border-radius:50%;border:none;background:#f3f4f6;font-size:30px;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.privacy-close:hover{background:#e5e7eb;transform:scale(1.05)}.privacy-content{flex:1;overflow-y:auto;padding:30px;line-height:1.8;color:#374151}.privacy-content section{margin-bottom:30px}.privacy-content section:last-child{margin-bottom:0}.privacy-content h3{font-size:18px;font-weight:700;color:#111827;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #3B82F6}.privacy-content p{margin-bottom:12px;font-size:14px}.privacy-content strong{color:#1f2937;font-weight:600}@media(max-width:768px){.privacy-modal{max-height:95vh;border-radius:15px}.privacy-header{padding:20px}.privacy-header h2{font-size:20px}.privacy-content{padding:20px}.privacy-content h3{font-size:16px}.privacy-content p{font-size:13px}}.login-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .2s ease-out}.login-modal{background:#fff;border-radius:1.5rem;padding:2rem;width:100%;top:-5%;max-width:420px;max-height:calc(100dvh - 2rem);overflow-y:auto;box-shadow:0 20px 60px #0006;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-modal__close{position:absolute;top:1rem;right:1rem;background:#f5f5f5;border:none;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:#666;transition:all .2s}.login-modal__close:hover{background:#e0e0e0;color:#333}.login-modal__header{margin-bottom:2rem;text-align:center}.login-modal__logo{width:180px;height:auto;margin:0 auto;display:block}.login-modal__title{font-size:1.75rem;font-weight:700;color:#333;margin-bottom:.5rem}.login-modal__subtitle{font-size:.9rem;color:#666;line-height:1.4}.login-modal--register{padding:1.5rem}.login-modal--register .login-modal__header{margin-bottom:.6rem}.login-modal--register .login-modal__logo{width:auto;height:28px;max-width:100%;-o-object-fit:contain;object-fit:contain;margin-bottom:.2rem}.login-modal--login .login-modal__logo{width:auto;height:28px;max-width:100%;-o-object-fit:contain;object-fit:contain}.login-modal--register .login-modal__title{font-size:1.4rem;margin-bottom:0}.login-modal--register .login-modal__form{gap:.85rem}.login-modal--register .login-modal__field{gap:.35rem}.login-modal--register .login-modal__field input{padding:.7rem}.login-modal--register .phone-prefix{padding:.7rem .45rem .7rem .7rem}.login-modal--register .login-modal__submit{padding:.85rem}.login-modal--register .login-modal__privacy{margin:10px 0 4px}.login-modal--register .privacy-checkbox{font-size:13px;line-height:1.35}.login-modal--register .privacy-checkbox input[type=checkbox]{width:16px;height:16px}.login-modal--register .login-modal__toggle{margin-top:1rem;padding-top:1rem}.login-modal__form{display:flex;flex-direction:column;gap:1.25rem}.login-modal__field{display:flex;flex-direction:column;gap:.5rem}.login-modal__field label{font-weight:600;color:#555;font-size:.9rem}.login-modal__field input{padding:.875rem;border:2px solid #e0e0e0;border-radius:.75rem;font-size:1rem;transition:all .3s;background:#fafafa}.login-modal__field input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.login-modal__field input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.phone-input-wrapper{display:flex;align-items:center;border:2px solid #e0e0e0;border-radius:.75rem;background:#fafafa;transition:all .3s;overflow:hidden}.phone-input-wrapper:focus-within{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.phone-prefix{display:flex;align-items:center;gap:.5rem;padding:.875rem .5rem .875rem .875rem;background:#f0f0f0;border-right:2px solid #e0e0e0;white-space:nowrap}.flag-emoji{font-size:1.25rem;line-height:1}.country-code{font-weight:600;color:#333;font-size:1rem}.phone-input-wrapper input{flex:1;border:none!important;padding-left:.75rem!important;background:transparent!important;box-shadow:none!important}.phone-input-wrapper input:focus{border:none!important;box-shadow:none!important}.login-modal__error{background:#fee;color:#c33;padding:.875rem;border-radius:.75rem;font-size:.9rem;text-align:center;border:1px solid #fcc}.login-modal__submit{padding:1rem;background:#1f2937;color:#fff;border:none;border-radius:.75rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.login-modal__submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-modal__submit:active:not(:disabled){transform:translateY(0)}.login-modal__submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-modal__toggle{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0;text-align:center;color:#666;font-size:.95rem}.login-modal__toggle button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;font-size:.95rem;padding:0;transition:color .2s}.login-modal__toggle button:hover:not(:disabled){color:#764ba2}.login-modal__toggle button:disabled{opacity:.5;cursor:not-allowed}.login-modal__privacy{margin:20px 0 10px}.privacy-checkbox{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;color:#4b5563;line-height:1.5}.privacy-checkbox input[type=checkbox]{margin-top:3px;width:18px;height:18px;cursor:pointer;flex-shrink:0}.privacy-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.privacy-link{color:#3b82f6;text-decoration:underline;cursor:pointer;font-weight:600;transition:color .2s}.privacy-link:hover{color:#2563eb}@media(max-width:480px){.login-modal{padding:1.5rem;border-radius:1rem;max-height:calc(100dvh - 1rem)}.login-modal__title{font-size:1.5rem}.login-modal__subtitle{font-size:.85rem}.login-modal--register{padding:1rem}.login-modal--register .login-modal__logo,.login-modal--login .login-modal__logo{height:24px}.login-modal--register .login-modal__title{font-size:1.3rem}}.toast-message{position:fixed;top:12px;left:50%;transform:translate(-50%,-20px);background:#111827eb;color:#fff;padding:10px 16px;border-radius:999px;font-size:14px;font-weight:600;z-index:3000;opacity:0;pointer-events:none;transition:transform .3s ease,opacity .3s ease;box-shadow:0 10px 20px #00000040}.toast-message--visible{opacity:1;transform:translate(-50%)}.duel-game{max-width:390px;margin:0 auto;padding:20px 16px 40px;height:100vh;overflow-y:auto;overflow-x:hidden;position:relative}.duel-game__top{display:flex;justify-content:space-between;align-items:flex-end}.duel-game__player-side{width:120px}.duel-game__player-side--right{text-align:right}.duel-game__name{display:block;font-weight:600;color:#1f2937}.duel-game__name--muted{color:#9ca3af}.duel-game__badge{display:inline-block;margin:6px 0;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:600}.duel-game__badge--red{background:#fee2e2;color:#ef4444}.duel-game__bar{height:10px;border-radius:999px;background:#e5e7eb}.duel-game__bar--blue{width:80%;background:#3b82f6}.duel-game__bar--gray{width:65%;background:#9ca3af}.duel-game__center{display:flex;flex-direction:column;align-items:center;gap:6px}.duel-game__timer{background:#f3f4f6;padding:10px 22px;border-radius:999px;font-weight:700;font-size:22px}.duel-game__vs{font-size:13px;font-weight:700;color:#9ca3af}.duel-game__divider{height:1px;background:#e5e7eb;margin:24px 0}.duel-game__question-box{background:#e0f2fe;border-radius:28px;height:200px;display:flex;align-items:center;justify-content:center;color:#3b82f6;font-weight:600;margin-bottom:24px}.duel-game__question{font-size:22px;margin-bottom:20px;color:#1f2937}.duel-game__answers{display:flex;flex-direction:column;gap:16px}.duel-game__answer{position:relative;padding:18px 20px;border-radius:18px;border:2px solid #e5e7eb;background:#fff;font-size:17px;text-align:left;color:#374151;cursor:pointer}.duel-game__answer--active{border-color:#10b981;background:#ecfdf5;color:#047857;font-weight:600}.duel-game__check{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#10b981;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px}.duel-game__progress{margin-top:40px;text-align:center;color:#9ca3af;font-size:15px}.duel-game__finish{margin-top:32px;width:100%;background:#ef4444;color:#fff;border:none;border-radius:20px;padding:16px;font-size:17px;font-weight:600;cursor:pointer;transition:all .2s}.duel-game__finish:hover{background:#dc2626}.duel-game__finish:active{transform:scale(.98)}.duel-game-screen{max-width:100%;margin:0 auto;padding:20px 16px 40px;height:100vh;overflow-y:auto;overflow-x:hidden;background:#fff}.duel-scoreboard{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.duel-scoreboard__player{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.duel-scoreboard__player--right{align-items:center}.duel-scoreboard__avatar{width:60px;height:60px;border-radius:50%;border:3px solid #3b82f6;display:flex;align-items:center;justify-content:center;background:#eff6ff;flex-shrink:0}.duel-scoreboard__avatar--blue{border-color:#3b82f6;background:#eff6ff}.duel-scoreboard__avatar--gray{border:3px dashed #d1d5db;background:#f5f5f5;color:#c0c4cc;font-size:24px;font-weight:600}.duel-scoreboard__avatar-icon{width:20px;height:3px;background:#3b82f6;border-radius:2px;position:relative}.duel-scoreboard__avatar-icon:before{content:"";position:absolute;width:3px;height:18px;background:#3b82f6;left:8px;top:-7px;border-radius:2px}.duel-scoreboard__name{font-size:14px;font-weight:600;color:#1f2937;white-space:nowrap}.duel-scoreboard__name--muted{color:#9ca3af}.duel-scoreboard__badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}.duel-scoreboard__badge--red{background:#fee2e2;color:#ef4444}.duel-scoreboard__progress{width:100%;height:8px;border-radius:999px;background:#e5e7eb;overflow:hidden}.duel-scoreboard__progress-bar{height:100%;border-radius:999px;transition:width .3s ease}.duel-scoreboard__progress-bar--blue{background:#3b82f6}.duel-scoreboard__progress-bar--gray{background:#9ca3af}.duel-scoreboard__center{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.duel-scoreboard__timer{background:#f3f4f6;padding:8px 16px;border-radius:999px;font-weight:700;font-size:18px;color:#1f2937}.duel-scoreboard__vs{font-size:11px;font-weight:700;color:#9ca3af}.duel-divider{height:1px;background:#e5e7eb;margin:20px 0}.duel-question-card{margin-top:20px}.duel-question-card__image{background:#e0f2fe;border-radius:20px;overflow:hidden;margin-bottom:20px;min-height:200px;display:flex;align-items:center;justify-content:center}.duel-question-card__image img{width:100%;height:auto;-o-object-fit:cover;object-fit:cover}.duel-question-card__question{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 20px;line-height:1.4}.duel-question-card__answers{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.duel-question-card__answer{position:relative;padding:16px 18px;border-radius:16px;border:2px solid #e5e7eb;background:#fff;font-size:16px;text-align:left;color:#374151;cursor:pointer;transition:all .2s}.duel-question-card__answer:hover:not(:disabled){border-color:#d1d5db;background:#f9fafb}.duel-question-card__answer:disabled{cursor:not-allowed}.duel-question-card__answer--selected{border-color:#3b82f6;background:#eff6ff}.duel-question-card__answer--correct{border-color:#10b981;background:#ecfdf5;color:#047857;font-weight:600}.duel-question-card__answer--wrong{border-color:#ef4444;background:#fef2f2;color:#dc2626;font-weight:600}.duel-question-card__check{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:#10b981;color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}.duel-question-card__cross{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:#ef4444;color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}.duel-question-card__progress{text-align:center;color:#9ca3af;font-size:14px;font-weight:500}.duel-game-screen__quit{margin-top:32px;width:100%;background:#ef4444;color:#fff;border:none;border-radius:20px;padding:16px;font-size:17px;font-weight:600;cursor:pointer;transition:all .2s}.duel-game-screen__quit:hover{background:#dc2626}.duel-game-screen__quit:active{transform:scale(.98)}.confirm-dialog__overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:3000;padding:16px}.confirm-dialog__card{width:100%;max-width:360px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 20px 40px #0f172a33;animation:confirm-pop .2s ease-out}.confirm-dialog__title{margin:0 0 8px;font-size:18px;font-weight:700;color:#0f172a}.confirm-dialog__description{margin:0 0 16px;color:#64748b;font-size:14px}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:8px}.confirm-dialog__btn{border:none;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer;background:#2563eb;color:#fff}.confirm-dialog__btn--ghost{background:#f1f5f9;color:#0f172a}@keyframes confirm-pop{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.duel-result{max-width:390px;margin:0 auto;padding:40px 16px;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff}.duel-result__header{text-align:center;margin-bottom:40px}.duel-result__trophy{font-size:80px;margin-bottom:16px;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.duel-result__title{font-size:32px;font-weight:700;margin:0 0 8px;color:#1f2937}.duel-result__title--win{color:#10b981}.duel-result__title--lose{color:#ef4444}.duel-result__subtitle{font-size:16px;color:#6b7280;margin:0}.duel-result__stats{width:100%;display:flex;align-items:center;gap:16px;margin-bottom:40px}.duel-result__stat-card{flex:1;background:#fff;border-radius:20px;padding:20px;box-shadow:0 10px 30px #0000001a}.duel-result__stat-header{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:16px}.duel-result__stat-avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.duel-result__stat-avatar--blue{border:3px solid #3b82f6;background:#eff6ff}.duel-result__stat-avatar--gray{border:3px dashed #d1d5db;background:#f5f5f5;color:#c0c4cc;font-size:24px;font-weight:600}.duel-result__stat-icon{width:20px;height:3px;background:#3b82f6;border-radius:2px;position:relative}.duel-result__stat-icon:before{content:"";position:absolute;width:3px;height:18px;background:#3b82f6;left:8px;top:-7px;border-radius:2px}.duel-result__stat-name{font-size:14px;font-weight:600;color:#1f2937}.duel-result__stat-name--muted{color:#9ca3af}.duel-result__stat-rows{display:flex;flex-direction:column;gap:12px}.duel-result__stat-row{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#f9fafb;border-radius:12px}.duel-result__stat-label{font-size:13px;color:#6b7280;font-weight:500}.duel-result__stat-value{font-size:18px;font-weight:700}.duel-result__stat-value--red{color:#ef4444}.duel-result__stat-value--blue{color:#3b82f6}.duel-result__stat-value--gray{color:#6b7280}.duel-result__vs{font-size:18px;font-weight:700;color:#9ca3af;flex-shrink:0}.duel-result__actions{width:100%;display:flex;flex-direction:column;gap:12px}.duel-result__button{width:100%;padding:16px;border-radius:20px;font-size:17px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.duel-result__button--primary{background:#3b82f6;color:#fff}.duel-result__button--primary:hover{background:#2563eb}.duel-result__button--secondary{background:#f3f4f6;color:#1f2937}.duel-result__button--secondary:hover{background:#e5e7eb}.duel-result__button:active{transform:scale(.98)}.duel-join-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.duel-join-card{background:#fff;border-radius:2rem;padding:3rem 2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}.duel-join-card h2{font-size:1.75rem;font-weight:700;color:#333;margin:1rem 0}.duel-join-card p{color:#666;font-size:1rem;margin:.5rem 0}.duel-code{font-size:2rem;font-weight:700;color:#667eea;margin:1.5rem 0;letter-spacing:.2em;font-family:monospace}.spinner{width:60px;height:60px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.waiting-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.error-icon{font-size:4rem;margin-bottom:1rem}.error-message{color:#c33;font-weight:500;margin:1rem 0}.btn-primary{margin-top:2rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.duel-join-message{background:#fff;border-radius:2rem;padding:2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;margin-top:2rem}.duel-join-message h2{font-size:1.75rem;color:#333;margin-bottom:1rem}.duel-join-message p{color:#666;margin-bottom:.5rem}@media(max-width:480px){.duel-join-card{padding:2rem 1.5rem}.duel-code{font-size:1.5rem}}.waiting-room{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f3f4f6;padding:1rem}.waiting-room__toast{position:fixed;top:12px;left:50%;transform:translate(-50%,-20px);background:#111827eb;color:#fff;padding:10px 16px;border-radius:999px;font-size:14px;font-weight:600;z-index:2000;opacity:0;pointer-events:none;transition:transform .3s ease,opacity .3s ease;box-shadow:0 10px 20px #00000040}.waiting-room__toast--visible{opacity:1;transform:translate(-50%)}.waiting-room__card{background:#fff;border-radius:2rem;padding:3rem 2rem;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}.waiting-room__spinner{width:80px;height:80px;border:6px solid #f3f3f3;border-top:6px solid #3B82F6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.waiting-room__success{font-size:5rem;margin-bottom:1rem;animation:bounceIn .6s ease-out}.waiting-room__title{font-size:1.75rem;font-weight:700;color:#333;margin-bottom:.5rem}.waiting-room__subtitle{color:#666;font-size:1rem;margin-bottom:2rem}.waiting-room__starting{color:#3b82f6;font-size:1.1rem;font-weight:600;margin-top:1rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.waiting-room__code-box{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem 0}.waiting-room__code{font-size:3rem;font-weight:700;color:#3b82f6;letter-spacing:.3em;font-family:monospace}.waiting-room__copy-btn{background:#f0f0f0;border:none;width:3rem;height:3rem;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.waiting-room__copy-btn:hover{background:#e0e0e0;transform:scale(1.1)}.waiting-room__link-box{display:flex;gap:.5rem;margin:1.5rem 0;padding:.75rem;background:#f8f8f8;border-radius:1rem}.waiting-room__link-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:.85rem;background:#fff;color:#666;font-family:monospace}.waiting-room__link-input:focus{outline:none;border-color:#3b82f6}.waiting-room__share-btn{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:transform .2s;white-space:nowrap}.waiting-room__share-btn:hover{transform:translateY(-2px)}.waiting-room__error{background:#fee;color:#c33;padding:.75rem;border-radius:.5rem;margin:1rem 0;font-size:.9rem}.waiting-room__cancel{margin-top:2rem;padding:.75rem 2rem;background:#f0f0f0;color:#666;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.waiting-room__cancel:hover{background:#e0e0e0}@media(max-width:480px){.waiting-room__card{padding:2rem 1.5rem}.waiting-room__code{font-size:2rem}.waiting-room__link-box{flex-direction:column}.waiting-room__share-btn{width:100%}}.duel-finishing{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.duel-finishing__card{background:#fff;border-radius:2rem;padding:3rem 2rem;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}.duel-finishing__spinner{width:80px;height:80px;border:6px solid #f3f3f3;border-top:6px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.duel-finishing__success{font-size:5rem;margin-bottom:1rem;animation:bounceIn .6s ease-out}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.duel-finishing__title{font-size:1.75rem;font-weight:700;color:#333;margin-bottom:.5rem}.duel-finishing__subtitle{color:#666;font-size:1rem;margin-bottom:2rem}.duel-finishing__stats{display:flex;gap:1.5rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}.duel-finishing__stat{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:#f8f8f8;border-radius:1rem;min-width:120px}.duel-finishing__stat-label{font-size:.85rem;color:#999;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.duel-finishing__stat-value{font-size:1.5rem;font-weight:700;color:#667eea}@media(max-width:480px){.duel-finishing__card{padding:2rem 1.5rem}.duel-finishing__stats{gap:1rem}.duel-finishing__stat{min-width:100px;padding:.75rem 1rem}.duel-finishing__stat-value{font-size:1.25rem}}.failed-exam{min-height:100vh;padding:40px 20px;display:flex;flex-direction:column;align-items:center}.failed-exam__title{margin:0;color:#f04444;font-size:28px;font-weight:700}.failed-exam__subtitle{margin-top:8px;color:#6b7280;font-size:16px}.failed-exam__traffic{margin:40px 0;width:70px;padding:14px 0;background:#1f2937;border-radius:18px;display:flex;flex-direction:column;align-items:center;gap:10px}.failed-exam__light{width:26px;height:26px;background:#374151;border-radius:50%}.failed-exam__light.red{background:#ff5a5a;box-shadow:0 0 12px #ff5a5acc}.failed-exam__progress-card{width:100%;max-width:320px;padding:24px;border:2px solid #ffd1d1;border-radius:20px;text-align:center}.failed-exam__circle{width:110px;height:110px;margin:0 auto;border-radius:50%;border:10px solid #ffd1d1;border-top-color:#f04444;border-right-color:#f04444;border-bottom-color:#f04444;display:flex;align-items:center;justify-content:center}.failed-exam__circle span{font-size:26px;font-weight:700;color:#111827}.failed-exam__remaining{margin-top:12px;color:#f04444;font-size:16px}.failed-exam__actions{margin-top:auto;width:100%;max-width:340px;display:flex;flex-direction:column;gap:12px}.failed-exam__cta{width:100%;padding:18px;border:none;border-radius:999px;background:#1f2937;color:#fff;font-size:18px;font-weight:600;cursor:pointer}.failed-exam__cta--secondary{background:#fff;color:#111827;border:1px solid #e5e7eb}.success-exam{max-width:420px;margin:0 auto;padding:48px 20px 32px;text-align:center;position:relative}.success-exam__title{font-size:36px;color:#059669;margin:0}.success-exam__subtitle{color:#6b7280;margin:10px 0 36px;font-size:18px}.success-exam__confetti{position:absolute;width:12px;height:12px}.success-exam__confetti.c1{background:#f59e0b;border-radius:50%;top:40px;left:60px}.success-exam__confetti.c2{background:#ec4899;transform:rotate(20deg);top:60px;left:90px}.success-exam__confetti.c3{background:#3b82f6;border-radius:50%;top:80px;right:80px}.success-exam__confetti.c4{background:#22c55e;transform:rotate(15deg);top:60px;right:50px}.success-exam__trophy{margin:40px auto 36px}.success-exam__cup{width:180px;height:120px;background:linear-gradient(#ffd54f,#fbbf24);border-radius:0 0 90px 90px;margin:0 auto;position:relative}.success-exam__cup:before,.success-exam__cup:after{content:"";position:absolute;width:36px;height:48px;border:8px solid #f59e0b;border-radius:50%;top:30px}.success-exam__cup:before{left:-30px}.success-exam__cup:after{right:-30px}.success-exam__star{color:#fff;font-size:36px;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.success-exam__stem{width:36px;height:46px;background:#d97706;margin:0 auto}.success-exam__base{width:90px;height:16px;background:#b45309;border-radius:999px;margin:6px auto 0}.success-exam__score-card{border:1px solid #e5e7eb;border-radius:28px;padding:28px 0 22px;margin-bottom:40px}.success-exam__ring{width:120px;height:120px;border-radius:50%;margin:0 auto;background:conic-gradient(#10b981 0deg 300deg,#d1fae5 300deg 360deg);display:flex;align-items:center;justify-content:center}.success-exam__ring span{width:86px;height:86px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#1f2937}.success-exam__score-text{margin-top:16px;color:#6b7280;font-size:16px}.success-exam__cta{width:100%;padding:22px;border-radius:999px;border:none;background:#1f2937;color:#fff;font-size:20px;font-weight:600}.exam-page{max-width:100%;margin:0 auto;padding:32px 20px 140px;overflow-y:auto;max-height:100%}.exam-title{font-size:34px;margin:0;color:#1f2937;text-align:center}.exam-subtitle{color:#9ca3af;margin:8px 0 28px;text-align:center}.exam-card{border:1px solid #e5e7eb;border-radius:28px;padding:22px;margin-bottom:22px}.exam-card-title{font-size:18px;font-weight:600;color:#374151;margin-bottom:16px}.exam-card-header{display:flex;justify-content:space-between;align-items:center}.exam-pill-row{display:flex;gap:12px;margin-bottom:20px}.exam-pill{flex:1;text-align:center;padding:14px 0;border-radius:16px;background:#f3f4f6;color:#6b7280;font-size:18px;font-weight:600;border:none;cursor:pointer}.exam-pill.active{background:#fff;border:3px solid #3b82f6;color:#3b82f6}.exam-slider{display:none}.exam-badge{background:#dcfce7;color:#16a34a;padding:8px 14px;border-radius:999px;font-weight:600;font-size:14px}.exam-levels{display:flex;gap:14px;flex-wrap:nowrap;margin:16px 0 20px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}.exam-levels::-webkit-scrollbar{height:0}.exam-level{width:54px;height:54px;border-radius:50%;border:3px solid #d1d5db;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;color:#9ca3af;background:#fff;cursor:pointer;flex:0 0 auto;aspect-ratio:1 / 1}.exam-level.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.exam-info{display:flex;gap:12px;background:#eff6ff;padding:16px;border-radius:18px;color:#2563eb;font-size:15px}.exam-check{font-size:22px}.exam-start{width:100%;padding:22px;border-radius:999px;border:none;background:#1f2937;color:#fff;font-size:20px;font-weight:600;margin-top:28px;cursor:pointer}.exam-start:disabled{opacity:.6;cursor:not-allowed}.exam-level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:12px;margin-bottom:20px}.exam-level-item{aspect-ratio:1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;cursor:pointer;border:3px solid #d1d5db;background:#fff;color:#9ca3af;transition:all .2s}.exam-level-item:hover{border-color:#a8b4c1}.exam-level-item.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.sheet-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#fff;width:100%;max-width:400px;height:50vh;border-top-left-radius:32px;border-top-right-radius:32px;display:flex;flex-direction:column;padding:12px 24px 30px;box-sizing:border-box;position:relative;overflow:hidden}.drag-handle{width:40px;height:5px;background-color:#e5e7eb;border-radius:10px;align-self:center;margin-bottom:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header h2{margin:0;font-size:22px;color:#111827;font-weight:700}.close-btn{background:#f3f4f6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}.header-actions{display:flex;align-items:center;gap:8px}.debug-btn{width:36px;height:36px;border-radius:50%;border:none;background:#f3f4f6;cursor:pointer;font-size:18px}.chat-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:6px;margin-bottom:12px;flex:1;min-height:0}.chat-empty,.chat-typing{color:#6b7280;font-size:14px}.chat-bubble{padding:12px 14px;border-radius:18px;font-size:15px;line-height:1.4;max-width:85%;word-break:break-word}.chat-bubble--ai{align-self:flex-start;background:#f3f4f6;color:#374151;border-bottom-left-radius:6px}.chat-bubble--user{align-self:flex-end;background:#3b82f6;color:#fff;border-bottom-right-radius:6px}.suggestions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.chip{background:#fff;border:1px solid #e5e7eb;border-radius:50px;padding:10px 16px;font-size:14px;color:#4b5563;cursor:pointer;display:flex;align-items:center;gap:6px}.footer{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:12px;background:#fff;position:sticky;bottom:0}.input-field{flex:1;padding:16px 20px;border-radius:50px;border:1px solid #d1d5db;outline:none;font-size:16px;box-shadow:0 4px 6px -1px #0000001a}.send-btn{background:#fff;border:1px solid #d1d5db;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a;flex-shrink:0}.debug-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:60}.debug-modal{width:min(520px,92vw);max-height:70vh;background:#fff;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px}.debug-header{display:flex;align-items:center;justify-content:space-between}.debug-header h3{margin:0;font-size:16px;color:#111827}.debug-actions{display:flex;gap:8px;align-items:center}.debug-copy,.debug-close{border:none;border-radius:999px;padding:6px 12px;background:#f3f4f6;cursor:pointer;font-size:12px}.debug-body{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:12px;font-size:13px;color:#374151;white-space:pre-wrap;overflow:auto;flex:1}*{box-sizing:border-box;font-family:system-ui,sans-serif}.page{max-width:420px;margin:0 auto;padding:16px 16px 96px;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.top{display:flex;align-items:center;justify-content:space-between}.icon-page{width:36px;height:36px;border-radius:50%;border:1px solid #d1d5db;background:#fff;display:flex;justify-content:center;align-items:center;cursor:pointer}.progress-text{font-weight:600}.progress-stats{display:flex;justify-content:center;gap:12px;margin-top:8px}.stat{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}.stat--correct{background:#ecfdf5;color:#047857}.stat--wrong{background:#fef2f2;color:#b91c1c}.stat-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:12px;background:#ffffffb3}.progress{height:8px;background:#e5e7eb;border-radius:999px;margin:16px 0}.progress-fill{width:33%;height:100%;background:#10b981;border-radius:999px}.image-question{height:auto;border-radius:20px;background:url(./intersection.png) center / cover no-repeat;margin-bottom:20px;width:100%}.question{font-size:16px;margin-bottom:20px;font-weight:semi-bold}.answers{display:flex;flex-direction:column;gap:14px}.answer{position:relative;padding:16px;border-radius:18px;border:2px solid #e5e7eb;background:#fff;font-size:16px;text-align:left;cursor:pointer}.answer.correct{border-color:#10b981;background:#ecfdf5;color:#065f46}.answer.wrong{border-color:#ef4444;background:#fef2f2;color:#991b1b}.check{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#10b981;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;line-height:1}.cross{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#ef4444;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;line-height:1}.ai{margin:20px 0;display:flex;align-items:center;gap:10px;color:#10b981;font-size:14px}.bars{display:flex;gap:4px}.bars span{width:4px;height:14px;background:#10b981;border-radius:2px;animation:ai-bars 1s ease-in-out infinite}.bars span:nth-child(2){animation-delay:.15s}.bars span:nth-child(3){animation-delay:.3s}.bars span:nth-child(4){animation-delay:.45s}@keyframes ai-bars{0%,to{transform:scaleY(.6);opacity:.6}50%{transform:scaleY(1.4);opacity:1}}.ai--muted .bars span{animation:none}.ai-error{margin-top:8px;color:#b91c1c;font-size:13px}.bottom{display:flex;align-items:center;gap:12px;position:fixed;bottom:16px;left:50%;transform:translate(-50%);width:min(420px,100% - 32px);padding:12px 0;z-index:2}.primary{flex:1;height:52px;border-radius:999px;border:none;background:#1f2937;color:#fff;font-size:16px;cursor:pointer}.primary:disabled{opacity:.6;cursor:not-allowed}.round{width:52px;height:52px;border-radius:50%;border:none;background:#1f2937;color:#fff;font-size:18px;cursor:pointer}.round:disabled{opacity:.6;cursor:not-allowed}.round--active{background:#ef4444}.sheet-overlay{position:fixed;inset:0;background:#00000059;display:flex;justify-content:center;align-items:flex-end;z-index:3}.sheet-wrapper{width:min(400px,100%)}.progress-resume-overlay{position:fixed;inset:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:20px;z-index:9999}.progress-resume-card{background:#fff;border-radius:20px;padding:24px;width:100%;max-width:360px;box-shadow:0 20px 50px #0f172a40;text-align:center}.progress-resume-title{margin:0 0 6px;font-size:22px;color:#0f172a}.progress-resume-subtitle{margin:0 0 12px;font-size:14px;color:#64748b}.progress-resume-text{margin:0 0 18px;font-size:14px;color:#475569;line-height:1.5}.progress-resume-actions{display:flex;gap:10px}.progress-resume-btn{flex:1;border:none;border-radius:12px;padding:12px 10px;font-size:14px;font-weight:600;cursor:pointer}.progress-resume-btn--secondary{background:#e2e8f0;color:#475569}.progress-resume-btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.wrong-answers-page{min-height:100vh;background:#f8fafc;padding-bottom:80px;max-width:100%;margin:0 auto;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.wrong-answers-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff;border-bottom:1px solid #e2e8f0;color:#111827}.wrong-answers-header h1{font-size:24px;font-weight:700;margin:0}.back-button{width:40px;height:40px;border-radius:50%;background:#f1f5f9;border:1px solid #e2e8f0;color:#111827;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.back-button:hover{background:#e2e8f0;transform:scale(1.05)}.loading{text-align:center;padding:40px;color:#475569;font-size:18px}.statistics-card{display:flex;gap:15px;padding:20px;margin:0 20px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a}.stat-item{flex:1;display:flex;align-items:center;gap:10px}.stat-icon{font-size:32px}.stat-value{font-size:24px;font-weight:700;color:#333}.stat-label{font-size:12px;color:#666}.filter-tabs{display:flex;gap:10px;padding:0 20px 20px;overflow-x:auto}.filter-tab{padding:10px 15px;border-radius:20px;border:none;background:#e2e8f0;color:#475569;font-size:14px;cursor:pointer;white-space:nowrap;transition:all .3s}.filter-tab.active{background:#1f2937;color:#fff;font-weight:700}.filter-tab:hover{background:#cbd5f5}.clear-button{margin:0 20px 20px;padding:12px 20px;border-radius:10px;border:none;background:#ef4444;color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s}.clear-button:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 15px #ff475766}.empty-state{text-align:center;padding:60px 20px;color:#475569}.empty-icon{font-size:80px;display:block;margin-bottom:20px}.empty-state h2{font-size:24px;margin-bottom:10px}.empty-state p{font-size:16px;opacity:1}.wrong-answers-list{padding:0 20px;display:flex;flex-direction:column;gap:15px}.wrong-answer-card{background:#fff;border-radius:15px;padding:15px;box-shadow:0 4px 15px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.source-badge{padding:6px 12px;border-radius:20px;background:#f0f0f0;font-size:12px;font-weight:700;color:#333}.ticket-id{font-size:12px;color:#999}.question-image{width:100%;margin-bottom:15px;border-radius:10px;overflow:hidden}.question-image img{width:100%;height:auto;display:block;-o-object-fit:cover;object-fit:cover}.question-text{font-size:16px;font-weight:700;color:#333;margin-bottom:15px;line-height:1.5}.answers-section{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.answer-option{padding:12px 15px;border-radius:10px;background:#f8f9fa;border:2px solid transparent;font-size:14px;position:relative;transition:all .3s}.answer-option.correct{background:#d4edda;border-color:#28a745;color:#155724;font-weight:700}.answer-option.wrong{background:#f8d7da;border-color:#dc3545;color:#721c24;font-weight:700}.answer-option .check,.answer-option .cross{position:absolute;right:15px;top:50%;transform:translateY(-50%);font-size:18px}.answer-option .check{color:#28a745}.answer-option .cross{color:#dc3545}.card-footer{padding-top:10px;border-top:1px solid #eee;text-align:right}.date{font-size:12px;color:#999}.tutorial-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tutorial-modal{background:#fff;border-radius:20px;padding:28px 24px;max-width:380px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease;position:relative}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.tutorial-progress{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.tutorial-progress-dot{width:8px;height:8px;border-radius:50%;background:#e2e8f0;transition:all .3s ease}.tutorial-progress-dot.active{width:24px;border-radius:4px;background:linear-gradient(135deg,#3b82f6,#2563eb)}.tutorial-progress-dot.completed{background:#3b82f6}.tutorial-content{text-align:center;margin-bottom:20px}.tutorial-title{font-size:22px;font-weight:700;color:#1e293b;margin:0 0 12px}.tutorial-description{font-size:15px;line-height:1.6;color:#64748b;margin:0}.tutorial-actions{display:flex;gap:10px;justify-content:center;align-items:center;margin-bottom:16px}.tutorial-btn{padding:12px 20px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.tutorial-btn--next{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d;min-width:120px}.tutorial-btn--next:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.tutorial-btn--back{background:#f1f5f9;color:#64748b;min-width:80px}.tutorial-btn--back:hover{background:#e2e8f0}.tutorial-btn--skip{background:transparent;color:#94a3b8;padding:12px 16px;font-size:13px}.tutorial-btn--skip:hover{color:#64748b;text-decoration:underline}.tutorial-counter{text-align:center;font-size:13px;color:#94a3b8;font-weight:500}@media(max-width:480px){.tutorial-modal{max-width:90%;padding:24px 20px}.tutorial-title{font-size:20px}.tutorial-description{font-size:14px}.tutorial-btn{padding:10px 16px;font-size:14px}.tutorial-btn--next{min-width:100px}}@media(prefers-reduced-motion:reduce){.tutorial-overlay,.tutorial-modal{animation:none}.tutorial-btn{transition:none}}.admin-dashboard-page{padding:24px;background:#f8fafc;min-height:100dvh;overflow-y:auto}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-title{margin:0;font-size:28px;color:#0f172a}.admin-header-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-refresh-btn{border:none;background:#2563eb;color:#fff;padding:8px 14px;border-radius:8px;font-weight:600;cursor:pointer}.admin-refresh-btn:hover{background:#1d4ed8}.admin-updated-at{margin-top:8px;color:#64748b;font-size:13px}.admin-period-label{margin-top:4px;color:#475569;font-size:13px}.admin-section{margin-top:22px}.admin-section h2{margin:0 0 10px;font-size:18px;color:#1e293b}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.admin-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;box-shadow:0 8px 25px #0f172a0f}.admin-stat-label{margin:0 0 6px;color:#64748b;font-size:12px}.admin-stat-value{margin:0;color:#0f172a;font-size:24px;font-weight:700}.admin-error-text{color:#b91c1c;font-weight:600}.admin-status-text{color:#334155;font-weight:600}.admin-select,.admin-input{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;background:#fff;color:#0f172a;font-size:13px}.admin-chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}.admin-chart-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:14px 14px 6px;box-shadow:0 8px 25px #0f172a0f}.admin-chart-card h3{margin:0 0 10px;color:#1e293b;font-size:16px}.admin-users-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.admin-users-filters .admin-input{min-width:260px}.admin-table-wrapper{overflow:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.admin-table{width:100%;border-collapse:collapse;min-width:880px}.admin-table th,.admin-table td{border-bottom:1px solid #f1f5f9;padding:10px;text-align:left;font-size:13px;color:#1e293b}.admin-table th{background:#f8fafc;color:#334155;font-weight:700}.admin-pagination{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.admin-login-page{min-height:100dvh;display:grid;place-items:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:24px}.admin-login-card{width:min(420px,100%);background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 20px 45px #0f172a1f;padding:24px}.admin-login-card h1{margin:0;color:#0f172a;font-size:24px}.admin-login-card p{margin:8px 0 18px;color:#475569;font-size:14px}.admin-login-form{display:grid;gap:12px}.admin-login-form label{font-size:13px;font-weight:600;color:#334155}.admin-login-form input{border:1px solid #cbd5e1;border-radius:10px;padding:10px 12px;outline:none;font-size:14px}.admin-login-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.admin-login-btn{margin-top:8px;border:none;border-radius:10px;padding:10px 14px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.admin-login-btn:hover{background:#1d4ed8}.admin-login-btn:disabled{opacity:.75;cursor:not-allowed}.admin-login-btn--secondary{background:#e2e8f0;color:#0f172a}.admin-login-btn--secondary:hover{background:#cbd5e1}.admin-login-error{margin:2px 0;color:#b91c1c;font-size:13px;font-weight:600}.admin-login-actions{display:grid;gap:10px;margin-top:12px}
