:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}body{background:#020617;display:flex;justify-content:center;align-items:center}.app{width:100%;max-width:480px;height:100dvh;box-sizing:border-box;padding:.9rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;background:#020617;color:#e5e7eb;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}h1,h2,h3{margin:0;padding:0;line-height:1.1}h1{font-size:1.6rem;margin-bottom:.75rem}h2{font-size:1.1rem}h3{font-size:1rem}button{border:none;padding:.55rem 1rem;border-radius:999px;font-size:1rem;cursor:pointer}button:hover{filter:brightness(1.08)}button:disabled{opacity:.6;cursor:not-allowed}.menu{width:100%;max-width:360px;display:flex;flex-direction:column;gap:.75rem}.menu-btn{width:100%;background:#334155;color:#e5e7eb}.menu-btn.primary{background:#22c55e;color:#022c22}.screen{width:100%;height:100%;display:flex;flex-direction:column;gap:.75rem}.topbar{width:100%;display:grid;grid-template-columns:88px 1fr 88px;align-items:center;gap:.5rem}.topbar button{background:#334155;color:#e5e7eb;padding:.45rem .75rem;font-size:.9rem}.topbar h2{text-align:center}.muted{opacity:.8;font-size:.85rem}.error{color:#fca5a5;font-size:.9rem;text-align:center}.card,.list-card{width:100%;background:#0f172a;border-radius:.75rem;padding:.75rem;box-sizing:border-box;box-shadow:0 10px 25px #0006}.list-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.list{list-style:none;padding:0;margin:0;max-height:48dvh;overflow:auto}.list-item{display:flex;justify-content:space-between;gap:.75rem;padding:.35rem 0;border-bottom:1px solid rgba(148,163,184,.15)}.name{font-weight:600}.users-form{width:100%;display:flex;gap:.5rem}.users-form input{flex:1;background:#0a1124;border:1px solid #334155;border-radius:10px;padding:.45rem .6rem;color:#e5e7eb;min-width:0}.users-form button{background:#22c55e;color:#022c22}.scores{width:100%;display:flex;justify-content:space-evenly;gap:.75rem}.team{flex:1;max-width:200px;background:#0f172a;border-radius:.75rem;padding:.75rem;box-sizing:border-box;text-align:center;box-shadow:0 10px 25px #0006}.players{display:flex;flex-direction:column;gap:.35rem;margin:.5rem 0 .6rem;font-size:.85rem}.players label{display:flex;justify-content:center;align-items:center;gap:.35rem}.players select{background:#0a1124;border:1px solid #334155;border-radius:10px;padding:.2rem .35rem;color:#e5e7eb;width:110px;font-size:.85rem;text-align:center}.numeric-score{margin-top:.25rem;font-size:.8rem;opacity:.85}.controls{display:flex;justify-content:center;gap:.5rem;margin-top:.6rem}.controls button:first-child{background:#4b5563;color:#fff}.controls button:last-child{background:#22c55e;color:#022c22}.reset{background:#ef4444;color:#fff}.truco-score{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin:.2rem 0 .35rem}.truco-box{position:relative;width:42px;height:42px;border-radius:6px;background:#0f172ab3}.truco-divider{width:70%;height:3px;background:#94a3b8e6;margin:.25rem 0}.stick{position:absolute;background:#e5e7eb}.stick.vertical.left{width:2px;left:9px;top:5px;bottom:5px}.stick.vertical.right{width:2px;right:9px;top:5px;bottom:5px}.stick.horizontal.top{height:2px;top:7px;left:7px;right:7px}.stick.horizontal.bottom{height:2px;bottom:7px;left:7px;right:7px}.stick.diagonal{height:2px;left:5px;right:5px;top:50%;transform:rotate(45deg);transform-origin:center}@media(max-width:360px){.app{padding:.75rem}.team{max-width:180px;padding:.65rem}.players select{width:95px;font-size:.8rem}.truco-box{width:38px;height:38px}}.table-card{width:100%;background:#0f172a;border-radius:.75rem;padding:.5rem;box-sizing:border-box;box-shadow:0 10px 25px #0006;overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:.9rem}.users-table thead{background:#94a3b814}.users-table th,.users-table td{padding:.4rem .35rem;text-align:center}.users-table th{font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.users-table td.username{text-align:left;font-weight:600}.users-table tbody tr:not(:last-child){border-bottom:1px solid rgba(148,163,184,.15)}.users-table .empty{text-align:center;padding:.75rem 0;opacity:.8}@media(max-width:360px){.users-table{font-size:.8rem}.users-table th{font-size:.7rem}}
