.auth-wrap{display:flex;justify-content:center;align-items:flex-start;padding:48px 16px}.auth-card{width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px;background:var(--card, #fffaf2);border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:28px 26px;box-shadow:0 12px 40px #78461e1f}.auth-brand{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--accent, #c2603f)}.auth-card h1{margin:0;font-size:1.4rem}.auth-card label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:#5a4636}.auth-card input{padding:10px 12px;border:1px solid rgba(0,0,0,.15);border-radius:10px;font-size:1rem;background:#fff}.auth-card input:focus{outline:2px solid var(--accent, #c2603f);border-color:transparent}.auth-submit{margin-top:4px}.auth-error{background:#fdecec;color:#a02020;padding:9px 12px;border-radius:10px;font-size:.88rem}.auth-notice{background:#eaf7ec;color:#1f6b30;padding:9px 12px;border-radius:10px;font-size:.88rem}.auth-links{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.auth-links .link{background:none;border:none;color:var(--accent, #c2603f);cursor:pointer;font-size:.85rem;padding:0;text-decoration:underline}:root{--bg: #f6f0e7;--panel: #fdfbf6;--panel-2: #f1e9da;--border: #e6d8c2;--text: #362e24;--muted: #8a7a64;--accent: #c0563a;--accent-dark: #a8482e;--clay: #c0563a;--sage: #8fae6f;--forest: #5f7d45;--sand: #e1b272;--dark-btn: #36281f;--good: #6f9e4a;--warn: #c9952f;--destructive: #c0392b;--serif: "DM Serif Display", Georgia, "Times New Roman", serif;color-scheme:light}*{box-sizing:border-box}body{margin:0;font-family:Fira Sans,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}h1,h2,h3,h4{font-family:var(--serif)}.app{display:grid;grid-template-columns:1fr 320px;grid-template-rows:auto 1fr auto auto;grid-template-areas:"header header" "board sidebar" "hand sidebar" "actionbar sidebar";height:100vh;gap:12px;padding:12px}.header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--panel);border:1px solid var(--border);border-radius:12px}.header h1{font-size:18px;margin:0;letter-spacing:.5px}.header .phase{color:var(--muted);font-size:13px}.board-wrap{position:relative;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 45%,#cfe9f2,#9ccbe0 55%,#5f9fbd);border:2px solid rgba(192,86,58,.3);border-radius:16px;overflow:hidden}.board-wrap>svg{width:100%;height:100%;max-height:78vh}.sidebar{grid-area:sidebar;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px}.card h2{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 0 8px}.player-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px}.player-row.active{background:var(--panel-2);outline:1px solid var(--accent)}.swatch{width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.3)}.player-row .name{flex:1;font-weight:600;font-size:14px}.player-row .pts{font-variant-numeric:tabular-nums;color:var(--muted);font-size:13px}.badge{font-size:11px;padding:1px 6px;border-radius:999px;background:var(--panel-2);color:var(--warn);border:1px solid var(--border)}.hand{display:flex;flex-wrap:wrap;gap:6px}.bank-card{min-height:200px;display:flex;flex-direction:column}.bank-grid{flex:1;display:flex;flex-wrap:nowrap;gap:5px;align-content:center;align-items:center;justify-content:center;padding:4px}.bank-pile{position:relative;flex:0 0 auto}.bank-pile img{width:40px;height:56px;object-fit:cover;border-radius:6px;border:2px solid #fdfbf6;box-shadow:1px 2px 5px #00000038;display:block}.bank-pile .card-count{min-width:17px;height:17px;font-size:11px;top:-7px;right:-7px}.res-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;font-size:13px;font-variant-numeric:tabular-nums}.actionbar{grid-area:actionbar;display:flex;flex-direction:column;gap:8px;padding:8px 12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;min-height:92px;justify-content:center}.action-status{font-size:13px;color:var(--muted);min-height:18px}.action-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.primary.pulse{animation:pulseBtn 1s ease-in-out infinite}@keyframes pulseBtn{0%,to{box-shadow:0 0 #4da3ff99;transform:scale(1)}50%{box-shadow:0 0 0 6px #4da3ff00;transform:scale(1.05)}}.trade-popup{position:absolute;top:12px;right:12px;width:256px;background:var(--panel);color:var(--text);border:2px solid var(--accent);border-radius:14px;padding:13px 15px;box-shadow:0 14px 34px -10px #50281473;z-index:20}.trade-popup .muted-note{color:var(--muted)}.trade-popup h3{margin:0 0 4px;font-size:15px}.trade-popup .trade-summary{margin:0 0 8px;font-size:14px}.trade-timer{height:5px;background:var(--panel-2);border-radius:3px;overflow:hidden;margin-bottom:10px}.trade-timer-bar{display:block;height:100%;background:var(--accent);transform-origin:left;animation:tradeShrink 20s linear forwards}@keyframes tradeShrink{0%{width:100%}to{width:0%}}.modal-actions.wrap{flex-wrap:wrap}.card-stack{position:relative;display:inline-flex}.play-card.back{position:absolute;top:0}.play-card.front{position:relative}.card-count{position:absolute;bottom:-3px;right:-4px;min-width:16px;height:16px;padding:0 3px;border-radius:8px;background:#0c1118;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.3)}.dev-divider{display:inline-flex;gap:14px;margin-left:10px;padding-left:12px;border-left:1px solid var(--border)}button{font:inherit;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer;transition:background .12s,border-color .12s}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);color:#07121f;font-weight:700;border-color:transparent}button.active{outline:2px solid var(--accent)}select,input[type=text],input:not([type]){font:inherit;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 8px}.build-btn{display:inline-flex;flex-direction:column;align-items:center;gap:1px;line-height:1.15;padding:5px 12px}.build-btn small{font-size:11px;color:var(--muted);letter-spacing:1px}.build-btn small.short{color:#ff8a8a}.trade-bank{display:inline-flex;align-items:center;gap:4px}.dice-faces{display:inline-flex;align-items:center;gap:6px;margin-left:auto}.dice-faces.rolling svg{animation:diceShake .12s linear infinite}@keyframes diceShake{0%{transform:rotate(-9deg)}50%{transform:rotate(9deg)}to{transform:rotate(-9deg)}}.dice-sum{font-size:18px;font-variant-numeric:tabular-nums}.piece-enter{animation:piecePop .22s ease-out;transform-origin:center;transform-box:fill-box}@keyframes piecePop{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}.spot-arrow{transform-box:fill-box;transform-origin:center;animation:spotBob 1s ease-in-out infinite}.spot-ring{transform-box:fill-box;transform-origin:center;animation:spotPulse 1.4s ease-out infinite}@keyframes spotBob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes spotPulse{0%{transform:scale(.7);opacity:.85}70%{transform:scale(1.45);opacity:0}to{opacity:0}}.spot-pulse{animation:spotBlink 1.1s ease-in-out infinite}@keyframes spotBlink{0%,to{opacity:.35}50%{opacity:1}}.robber-ring{animation:robberPulse 1.1s ease-in-out infinite}@keyframes robberPulse{0%,to{opacity:.45;stroke-width:3}50%{opacity:1;stroke-width:5}}.toasts{position:fixed;top:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:60;pointer-events:none}.toast{padding:8px 16px;border-radius:999px;font-size:14px;background:var(--panel-2);border:1px solid var(--border);box-shadow:0 6px 22px #00000073;animation:toastIn .2s ease-out}.toast.good{border-color:var(--good)}.toast.warn{border-color:var(--warn)}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.help-list{margin:4px 0 12px;padding-left:18px;font-size:13px}.help-list li{margin:2px 0}.modal h4{margin:12px 0 6px}.lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.lobby-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;width:min(460px,94vw);box-shadow:0 20px 60px #00000073}.lobby-card h1{margin:0 0 4px}.lobby-sub{color:var(--muted);margin:0 0 22px;font-size:14px}.lobby-field{margin-bottom:18px}.lobby-field>label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}.seg{display:inline-flex;gap:6px}.seg button{min-width:46px}.seg button.active{background:var(--accent);color:#07121f;font-weight:700;border-color:transparent}.seg.small button{min-width:34px;padding:5px 7px}.lobby-player{flex-wrap:wrap}.lobby-players{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}.lobby-player{display:flex;align-items:center;gap:10px}.lobby-player input{flex:1}.swatch.lg{width:22px;height:22px;border-radius:6px}.color-pick{display:inline-flex;gap:5px}.color-dot{width:24px;height:24px;border-radius:50%;padding:0;border:2px solid transparent}.color-dot.active{border-color:var(--text)}.seed-row{display:flex;gap:8px}.seed-row input{flex:1}.primary.big{width:100%;padding:12px;font-size:15px;margin-top:4px}.lobby{display:block;min-height:100vh;padding:28px 20px;background:radial-gradient(ellipse at 50% 0%,#2a86c4,#1a64a0 55%,#134f86);color:#eef6fc;overflow-y:auto}.lobby-shell{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start}.lobby-players,.lobby-main{background:#ffffff14;border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:18px}.lobby-players h2,.lobby-main h1{margin:0 0 12px;text-align:center}.lobby-main h1{font-size:26px}.lobby-main .lobby-sub{text-align:center;color:#cfe6f7;margin:0 0 18px;font-size:14px}.lobby-section{margin-bottom:18px}.lobby-section h3{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:#bfe0f5;margin:0 0 10px;text-align:center}.lobby .seg{display:inline-flex;gap:6px}.lobby .seg.full{display:flex;width:100%;margin-bottom:12px}.lobby .seg.full button{flex:1}.lobby .seg button,.lobby input,.lobby .color-dot{background:#ffffff1f;border:1px solid rgba(255,255,255,.22);color:#eef6fc}.lobby .seg button.active{background:#ffce47;color:#0c3253;font-weight:700;border-color:transparent}.lobby .seg.tiny button{padding:4px 8px;font-size:12px}.seat{background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-left:4px solid #fff;border-radius:10px;padding:10px;margin-bottom:10px}.seat-top{display:flex;gap:8px;align-items:center}.seat-top input{flex:1;padding:7px 9px;border-radius:8px}.seat-bottom{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:8px}.tile-row{display:flex;gap:12px}.tile{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 8px;background:#ffffff14;border:2px solid rgba(255,255,255,.16);border-radius:12px;color:#eef6fc;cursor:pointer}.tile.active{border-color:#ffce47;background:#ffce4729}.tile-icon{font-size:24px}.tile-label{font-weight:600;font-size:13px}.tile-hint{font-size:11px;color:#bfe0f5}.slider-row{margin-bottom:14px}.slider-row label{display:block;font-size:13px;margin-bottom:6px;color:#dceefb}.slider-row label b{color:#ffce47}.lobby input[type=range]{width:100%;accent-color:#ffce47;padding:0}.lobby .seed-row{display:flex;gap:8px}.lobby .seed-row input{flex:1;padding:7px 9px;border-radius:8px}.lobby-start{width:100%;padding:13px;font-size:16px;font-weight:800;background:#36b34a;color:#fff;border:none;border-radius:10px;cursor:pointer;margin-top:4px}.lobby-start:hover{background:#2fa040}@media (max-width: 720px){.lobby-shell{grid-template-columns:1fr}}.hand-bar{grid-area:hand;display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:8px 12px;min-height:64px}.hand-bar-name{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);white-space:nowrap}.hand-cards{display:flex;align-items:center;flex-wrap:wrap;gap:12px 16px;padding:2px 0;flex:1}.card-stack.clickable{cursor:pointer}.card-stack.playable .play-card.front{outline:2px solid #ffce47;outline-offset:1px}.card-stack.clickable:hover{transform:translateY(-4px);transition:transform .1s}.card-group{display:flex}.play-card{width:34px;height:48px;border-radius:6px;border:1px solid rgba(0,0,0,.45);box-shadow:0 2px 5px #0006,inset 0 1px #ffffff40;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:transform .1s}.card-group .play-card+.play-card{margin-left:-16px}.card-group:hover .play-card{margin-left:1px}.play-card.dev{background:#2f3a4d;color:#dbe6f2}.dev-group{margin-left:6px;padding-left:10px;border-left:1px solid var(--border)}.play-card-icon{font-size:18px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}.player-card{border:1px solid var(--border);border-left:4px solid var(--pc, var(--border));border-radius:10px;padding:9px 10px;margin-bottom:8px;background:var(--panel-2)}.player-card.active{outline:2px solid var(--pc, var(--accent));box-shadow:0 0 12px -2px var(--pc, transparent)}.player-card-top{display:flex;align-items:center;gap:8px}.player-card-top .pc-color{width:16px;height:16px;border-radius:5px;border:1px solid rgba(255,255,255,.35)}.player-card-top .name{flex:1;font-weight:700;font-size:15px}.vp-badge{display:inline-flex;align-items:baseline;gap:2px;font-size:18px;font-weight:800;color:var(--warn);font-variant-numeric:tabular-nums}.vp-badge i{font-size:13px;font-style:normal}.player-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}.player-stats .stat{display:flex;flex-direction:column;align-items:center;gap:1px;padding:5px 0;background:var(--panel);border:1px solid var(--border);border-radius:7px}.player-stats .stat b{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums}.player-stats .stat i{font-size:13px;font-style:normal;opacity:.85}.player-stats .stat.on{border-color:var(--good);background:#4caf7629}.player-stats .stat.on b{color:var(--good)}.modal.confirm{min-width:280px;text-align:center}.modal.confirm .modal-actions{justify-content:center}.hint{color:var(--muted);font-size:13px;flex:1;min-width:160px}.dice{display:inline-flex;gap:6px;font-size:20px}.log{font-size:12px;color:var(--muted);min-height:0;overflow-y:auto;display:flex;flex-direction:column-reverse;gap:3px}.error{color:#ff8a8a;font-size:13px}.muted-note{color:var(--muted);font-size:13px;margin:0}.dev-cards{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.dev-cards button{width:100%;text-align:left}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04080ea8;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;min-width:320px;max-width:92vw;box-shadow:0 20px 60px #00000080}.modal.wide{min-width:520px}.modal h3{margin:0 0 14px;font-size:16px}.modal h4{margin:0 0 8px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.modal-actions{display:flex;gap:8px;margin-top:16px}button.link{background:none;border:none;color:var(--muted);padding:8px 0 0;text-decoration:underline}.trade-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.trade-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:3px 0;font-size:14px}.stepper{display:inline-flex;align-items:center;gap:8px}.stepper button{width:28px;padding:4px 0;text-align:center;font-weight:700}.stepper b{min-width:18px;text-align:center;font-variant-numeric:tabular-nums}.trade-recipients{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:16px}.chk{display:inline-flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.trade-summary{font-size:15px;margin:0 0 14px}.trade-responders{display:flex;flex-direction:column;gap:8px}.site{min-height:100vh;background:radial-gradient(ellipse at 72% -12%,#f8e0cb,var(--bg) 46%)}.site-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fdfbf6db;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--serif);font-size:22px;color:var(--text);background:none;border:none;cursor:pointer}.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center}.site-nav{display:flex;gap:4px}.site-nav button{background:none;border:none;color:var(--muted);font-size:15px;padding:6px 12px;cursor:pointer}.site-nav button.on{color:var(--text);font-weight:600}.site-actions{display:flex;gap:10px;align-items:center}.site-actions .ghost{background:none;border:none;color:var(--muted)}.cta{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-weight:600;font-size:15px;cursor:pointer}.cta:hover{background:var(--accent-dark)}.cta.big{padding:14px 24px;font-size:16px}.cta.sm{padding:6px 16px;font-size:13px}.ghost{background:#fff;color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 18px;font-weight:600;font-size:15px;cursor:pointer}.ghost.big{padding:14px 24px;font-size:16px}.dark{background:var(--dark-btn);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-weight:600;cursor:pointer}.landing{max-width:1120px;margin:0 auto;padding:0 24px}.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:64px 0}.badge-pill{display:inline-block;font-size:12px;letter-spacing:.5px;color:var(--accent);background:#fff;border:1px solid var(--border);border-radius:999px;padding:6px 14px}.hero h1{font-size:56px;line-height:1.04;margin:18px 0 14px;letter-spacing:-1px}.accent-text{color:var(--accent)}.hero p{color:var(--muted);font-size:17px;max-width:470px;line-height:1.55}.hero-buttons{display:flex;gap:12px;margin:26px 0 22px}.hero-stats{display:flex;gap:22px;color:var(--muted);font-size:13px;flex-wrap:wrap}.hero-art{background:linear-gradient(160deg,#f6ddc8,#eef1e6);border:1px solid var(--border);border-radius:26px;padding:44px;box-shadow:0 36px 70px -28px #965a3266}.resource-strip{display:flex;align-items:center;justify-content:space-between;padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:14px}.strip-title{font-family:var(--serif);font-style:italic;font-size:19px}.pills{display:flex;gap:10px;flex-wrap:wrap}.pill{color:#fff;padding:6px 16px;border-radius:999px;font-size:13px;font-weight:600}.features{padding:64px 0 30px}.features h2{font-size:40px;margin:0 0 6px;letter-spacing:-.5px}.features-sub{color:var(--muted);margin:0 0 30px}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.feature-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:22px;box-shadow:0 14px 34px -22px #78503280}.feature-icon{display:inline-flex;width:42px;height:42px;background:#fbe6d8;color:var(--accent);border-radius:11px;align-items:center;justify-content:center;font-size:18px}.feature-card h3{margin:16px 0 6px;font-size:19px}.feature-card p{color:var(--muted);font-size:14px;margin:0;line-height:1.5}.site-footer{max-width:1120px;margin:0 auto;display:flex;justify-content:space-between;padding:26px 24px 44px;color:var(--muted);font-size:13px}.foot-links a{margin-left:16px;cursor:pointer}.page{max-width:1000px;margin:0 auto;padding:40px 24px 90px}.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px}.eyebrow{font-size:12px;letter-spacing:1px;color:var(--muted)}.page-head h1{font-size:42px;margin:4px 0 0;letter-spacing:-.5px}.quick-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}.quick-card{background:linear-gradient(150deg,#f7e3d2,#f3ece0);border:1px solid var(--border);border-radius:16px;padding:20px}.quick-card.green{background:linear-gradient(150deg,#e7eed9,#f1ece0)}.quick-icon{display:inline-flex;width:38px;height:38px;background:#fff9;border-radius:10px;align-items:center;justify-content:center;font-size:18px}.quick-card h3{margin:12px 0 4px;font-size:20px}.quick-card p{color:var(--muted);font-size:13px;min-height:34px;margin:0 0 12px}.room-toolbar{display:flex;gap:10px;margin-bottom:14px}.room-toolbar input{flex:1;padding:11px 14px;border:1px solid var(--border);border-radius:10px;background:#fff}.room-table{background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden}.room-row{display:grid;grid-template-columns:2fr 1.5fr 1fr 1.1fr .7fr .8fr;align-items:center;padding:12px 18px;border-top:1px solid var(--border)}.room-row.head{color:var(--muted);font-size:12px;letter-spacing:.5px;border-top:none}.room-name{display:flex;flex-direction:column}.room-name small{color:var(--muted)}.mode{padding:3px 11px;border-radius:999px;font-size:12px;font-weight:600}.mode.casual{background:#e7efd9;color:#5a7a36}.mode.ranked{background:#f7ddd2;color:var(--accent)}.mode.speed{background:#f3e7c8;color:#9a7a1f}.seats{display:flex;align-items:center;gap:3px}.seats i{width:7px;height:7px;border-radius:50%;background:var(--border)}.seats i.on{background:var(--accent)}.ping{color:var(--muted)}.site .card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px}.profile-head{display:flex;align-items:center;gap:16px;margin-bottom:18px}.avatar{width:64px;height:64px;border-radius:14px;background:linear-gradient(150deg,#e08a5e,#c0563a);color:#fff;font-family:var(--serif);font-size:28px;display:flex;align-items:center;justify-content:center}.profile-id{flex:1}.profile-id h1{margin:2px 0;font-size:30px}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-box{display:flex;flex-direction:column;gap:3px}.stat-value{font-family:var(--serif);font-size:30px}.profile-cols{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.match-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--border)}.match-row:nth-child(2){border-top:none}.dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.dot.win{background:var(--good)}.dot.loss{background:var(--accent)}.match-info{flex:1;font-size:14px}.match-info small{display:block;color:var(--muted)}.match-delta{text-align:right}.match-delta .up{color:var(--good);font-weight:700}.match-delta .down{color:var(--accent);font-weight:700}.match-delta small{display:block;color:var(--muted)}.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.ach{display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 6px;background:#fff;border:1px solid var(--border);border-radius:12px;font-size:12px}.ach-medal{font-size:22px}.ach.off{opacity:.4;filter:grayscale(1)}.lobby-back{background:none;border:none;color:#fffc;cursor:pointer;font-size:13px;margin-bottom:8px}@media (max-width: 820px){.hero,.feature-grid,.quick-cards,.stat-row,.profile-cols{grid-template-columns:1fr}}.game{height:100vh;display:flex;flex-direction:column}.game-header{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border);background:#fdfbf6e6}.game-header .brand{font-size:20px}.turn-chip{font-size:13px;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:4px 12px}.game-header-actions{display:flex;gap:8px;align-items:center}.hbtn{background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:8px 12px;cursor:pointer;color:var(--text);font-size:14px}.hbtn:hover:not(:disabled){border-color:var(--accent)}.hbtn:disabled{opacity:.45;cursor:not-allowed}.hbtn.primary-soft{background:linear-gradient(180deg,var(--accent),var(--accent-dark));color:#fff;border-color:transparent;font-weight:600}.game-body{flex:1;min-height:0;display:grid;grid-template-columns:268px 1fr 308px;gap:12px;padding:12px}.nobres,.pergaminho>.card,.center-top,.center-hand{background:var(--panel);border:1px solid var(--border);border-radius:16px}.nobres{padding:14px;overflow-y:auto;border:2px solid rgba(192,86,58,.35)}.nobres-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.nobres-head h2{margin:0;font-size:20px}.match-timer{font-size:12px;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:3px 10px}.noble{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:11px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2);margin-bottom:8px}.noble.active{border-color:var(--accent);background:linear-gradient(90deg,rgba(192,86,58,.12),transparent);box-shadow:0 0 0 1px #c0563a40}.noble-left{display:flex;flex-direction:column;align-items:center;gap:4px}.noble-crest{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-size:18px;box-shadow:inset 0 0 0 1px #0000001f}.noble-pts{text-align:center;line-height:1}.noble-pts b{display:block;font-family:var(--serif);font-size:24px;color:var(--accent)}.noble-pts span{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.noble-main{min-width:0}.noble-name{display:flex;align-items:center;gap:6px;font-size:14px}.noble-nick{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.you-tag{background:var(--text);color:var(--bg);font-size:9px;text-transform:uppercase;border-radius:4px;padding:1px 5px}.bot-tag{background:var(--panel);border:1px solid var(--border);color:var(--muted);font-size:9px;text-transform:uppercase;border-radius:4px;padding:1px 5px}.noble-stats{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.nstat{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--muted);background:var(--panel);border-radius:6px;padding:2px 6px}.nstat.hl{background:#c0563a26;color:var(--accent);font-weight:600}.noble-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.title-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:#fff;background:linear-gradient(90deg,var(--accent),var(--accent-dark));border-radius:6px;padding:2px 7px}.title-cards{margin-top:14px;display:flex;flex-direction:column;gap:8px}.title-card{display:flex;gap:8px;padding:10px;border-radius:12px;border:1px dashed var(--border);background:#e1b2721f;font-size:12px}.title-card.earned{border:1px solid var(--accent);background:linear-gradient(90deg,rgba(192,86,58,.14),transparent)}.tc-icon{font-size:16px}.tc-head{display:flex;justify-content:space-between;align-items:center}.tc-pv{background:var(--accent);color:#fff;font-size:9px;font-weight:700;border-radius:4px;padding:1px 5px}.tc-owner{color:var(--muted);margin-top:2px}.tc-hint{color:var(--muted);font-style:italic;font-size:10px;margin-top:2px;opacity:.85}.center{display:flex;flex-direction:column;gap:12px;min-height:0}.center-top{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border:2px solid rgba(192,86,58,.3)}.eyebrow-turn{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin:0}.center-top h2{margin:2px 0 0;font-size:24px}.roll-btn{background:linear-gradient(180deg,var(--accent),var(--accent-dark));color:#fff;border:none;border-radius:10px;padding:11px 20px;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 4px 12px -4px #c0563a99}.roll-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.roll-btn.pulse{animation:pulseBtn 1s ease-in-out infinite}.board-wrap .dice-faces{position:absolute;bottom:12px;right:14px;margin:0;background:#ffffffb3;border-radius:12px;padding:6px 10px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 4px 12px -4px #0000004d}.roll-on-board{position:absolute;right:14px;bottom:60px;z-index:5}.turn-timer{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:16px;font-variant-numeric:tabular-nums;color:var(--accent);background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:8px 14px}.turn-timer.danger{color:#fff;background:var(--accent);border-color:transparent;animation:pulseBtn 1s ease-in-out infinite}.center-hand{padding:12px 16px}.hand-error{min-height:20px;font-size:13px;line-height:20px;color:var(--destructive);margin-bottom:4px}.hand-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.hand-count{margin:2px 0 0;font-family:var(--serif);font-size:18px}.over-limit{margin-left:8px;font-family:Fira Sans,sans-serif;font-size:11px;color:var(--destructive);background:#c0392b1a;border:1px solid rgba(192,57,43,.25);border-radius:6px;padding:2px 7px}.hand-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.hand-cards{display:flex;align-items:flex-end;flex-wrap:wrap;gap:10px;padding:2px;min-height:100px}.hand-divider{width:1px;height:64px;background:var(--border);margin:0 6px}.card-pile{position:relative;background:none;border:none;padding:0;cursor:default}.card-pile:disabled{opacity:1;cursor:default}.card-pile.clickable{cursor:pointer}.card-pile-inner{position:relative;display:inline-block;height:74px}.play-img{position:absolute;top:0;width:52px;height:74px;object-fit:cover;border-radius:7px;border:2px solid #fdfbf6;box-shadow:2px 3px 7px #00000040}.card-pile.clickable:hover{transform:translateY(-6px);transition:transform .12s}.card-pile.playable .play-img{outline:2px solid var(--accent)}.card-count{position:absolute;top:-8px;right:-8px;min-width:20px;height:20px;padding:0 4px;border-radius:10px;background:var(--dark-btn);color:#fff;font-family:var(--serif);font-size:12px;display:flex;align-items:center;justify-content:center;border:2px solid var(--panel)}.pergaminho{display:flex;flex-direction:column;gap:12px;min-height:0}.pergaminho .scroll-card{flex:1;display:flex;flex-direction:column;min-height:80px;border:2px solid rgba(192,86,58,.3)}.pergaminho .scroll-card .log{flex:1}.chat-card{display:flex;flex-direction:column;height:188px;flex:0 0 auto}.chat-head{display:flex;align-items:center;gap:7px;font-size:15px;margin:0 0 8px}.chat-log{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column-reverse;gap:3px;font-size:13px}.chat-row{display:flex;gap:6px;margin-top:8px}.chat-row input{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:9px;background:var(--bg);font-size:13px}.chat-row button{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:0 14px;cursor:pointer}.game svg,.site svg{flex:0 0 auto}.hbtn,.roll-btn,.cta,.ghost,.dark,.chat-row button{display:inline-flex;align-items:center;gap:6px}.hbtn.icon-only{padding:8px}.nobres-head h2,.pergaminho h2,.card h2{display:flex;align-items:center;gap:7px}.turn-chip,.match-timer{display:inline-flex;align-items:center;gap:5px}.ic-primary{color:var(--accent)}.tc-icon{display:inline-flex;margin-top:1px}.tc-pv{display:inline-flex;align-items:center;gap:2px}.site-nav button,.brand{display:inline-flex;align-items:center;gap:8px}.card-pile-inner{height:92px}.play-img{width:64px;height:92px}.hand-divider{height:80px}.hero-stats span,.badge-pill,.foot-brand,.stat-eyebrow,.room-name b{display:inline-flex;align-items:center;gap:6px}.feature-icon svg,.quick-icon svg{display:block}.room-online{color:var(--good)}.search-box{flex:1;display:inline-flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--muted)}.search-box input{flex:1;border:none;background:none;padding:11px 0;outline:none}.ach svg{margin-bottom:2px}.log-line,.log-chat{padding:1px 0}.log-line b{font-weight:700}.log-sep{height:1px;background:var(--border);margin:7px 0}.log-chat{color:var(--text)}.have{color:var(--muted)}.setup-page{max-width:1020px}.back-link{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;margin-bottom:8px;display:inline-flex;align-items:center;gap:6px}.setup-grid{display:grid;grid-template-columns:330px 1fr;gap:18px;align-items:start}.su-h{font-size:20px;margin:0 0 12px;text-transform:none;letter-spacing:0;color:var(--text)}.su-sub{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 0 10px}.su-settings .su-sub+h3,.su-settings h3.su-sub~h3.su-sub{margin-top:18px}.su-settings .su-slider+.su-sub,.su-settings .su-tiles+.su-sub{margin-top:18px}.su-seg{display:inline-flex;gap:6px}.su-seg.full{display:flex;width:100%;margin-bottom:12px}.su-seg.full button{flex:1}.su-seg button{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px}.su-seg button.on{background:var(--accent);color:#fff;border-color:transparent;font-weight:600}.su-seg.sm button{padding:6px 9px}.su-seg.xs button{padding:4px 10px;font-size:12px}.su-players-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.su-count{color:var(--muted);font-weight:600}.su-note{color:var(--muted);font-size:13px;margin:4px 0 14px}.su-maps{display:flex;gap:8px;margin:12px 0 4px}.su-map{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:9px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);color:var(--text);text-align:left;cursor:pointer}.su-map b{font-size:13px}.su-map small{color:var(--muted);font-size:10.5px;line-height:1.2}.su-map.on{border-color:var(--accent);background:var(--panel);box-shadow:inset 0 0 0 1px var(--accent)}.su-map:disabled{opacity:.4;cursor:not-allowed}.su-seat{display:flex;align-items:center;gap:10px;background:var(--panel-2);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:10px;padding:9px 11px;margin-bottom:9px}.su-seat.open{justify-content:space-between;border:1px dashed var(--border);background:transparent}.su-crest{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:inset 0 0 0 1px #00000026}.su-name{flex:1;min-width:0;padding:7px 9px;border:1px solid var(--border);border-radius:8px;background:var(--panel);font:inherit;color:var(--text)}.su-name.bot-name{display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;font-weight:600;padding-left:0}.su-tag{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);white-space:nowrap}.su-open-label{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px}.su-open-label em{font-style:normal;opacity:.7;font-size:12px}.su-addbot{display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 11px;cursor:pointer}.su-addbot:hover{border-color:var(--accent);color:var(--accent)}.su-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:inline-flex;flex-shrink:0}.su-remove:hover{color:var(--accent);background:var(--panel)}.su-start:disabled{opacity:.55;cursor:not-allowed}.su-seat.bot{flex-direction:column;align-items:stretch;gap:8px}.su-seat-row{display:flex;align-items:center;gap:10px}.su-seat-diff{display:flex;gap:6px}.su-seat-diff button{flex:1}.su-tiles{display:flex;gap:12px;margin-bottom:4px}.su-tile{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:var(--panel-2);border:2px solid var(--border);border-radius:12px;color:var(--text);cursor:pointer}.su-tile.active{border-color:var(--accent);background:#c0563a1a}.su-tile:disabled{opacity:.45;cursor:not-allowed}.su-tile-icon{color:var(--accent);display:inline-flex}.su-tile-label{font-weight:600;font-size:14px}.su-tile-hint{font-size:11px;color:var(--muted)}.su-pace{margin-bottom:14px}.su-pace label{display:block;font-size:13px;margin-bottom:6px;color:var(--muted)}.su-pace .su-seg{width:100%}.su-pace .su-seg button{flex:1}.su-slider{margin-bottom:14px}.su-slider label{display:block;font-size:13px;margin-bottom:6px}.su-slider label b{color:var(--accent)}.su-slider input[type=range]{width:100%;accent-color:var(--accent);padding:0}.su-seed{display:flex;gap:8px}.su-seed input{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.su-start{width:100%;margin-top:10px;justify-content:center}@media (max-width: 760px){.setup-grid{grid-template-columns:1fr}}.fly-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:200;overflow:hidden}.fly-el{position:absolute;top:0;left:0;will-change:transform,opacity}.fly-card{border-radius:5px;border:2px solid #fdfbf6;object-fit:cover;box-shadow:2px 4px 9px #00000059}.fly-robber{border-radius:50% 50% 45% 45%;background:#2b2b2b;box-shadow:0 0 0 2px #111,0 4px 8px #00000073}
