.global-alert{position:fixed;top:70px;left:50%;transform:translate(-50%) translateY(-100px);z-index:9999;display:flex;align-items:center;gap:10px;padding:14px 24px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;border:2px solid transparent;font-size:15px;font-weight:600;cursor:pointer;opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}.global-alert--visible{transform:translate(-50%) translateY(0);opacity:1}.global-alert--success{border-color:#22c55e;color:#166534}.global-alert--success .global-alert__icon{background:#22c55e;color:#fff}.global-alert--error{border-color:#ef4444;color:#991b1b}.global-alert--error .global-alert__icon{background:#ef4444;color:#fff}.global-alert__icon{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:700}.global-alert__message{max-width:400px}.global-alert:hover{box-shadow:0 12px 40px #0003}html,body,#root{height:100%;margin:0}body{background:#fdfcf9}a{color:inherit}.app-shell{display:flex;flex-direction:column;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.topbar{height:60px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;justify-content:space-between;position:sticky;top:0;z-index:100}.brand{font-weight:900;font-size:20px;color:var(--brand);letter-spacing:-.5px}.topbar nav{display:flex;gap:20px;font-size:14px;font-weight:600;color:#4b5563}.topbar nav a{text-decoration:none;transition:color .2s}.topbar nav a:hover{color:#111827}main{flex:1;display:flex;flex-direction:column;padding:20px;min-height:0;overflow:auto}main.no-padding{padding:0}@media(max-width:1024px)and (orientation:landscape){.app-shell--game .topbar{display:none}.app-shell--game main.no-padding{overflow:hidden}}:root{--font-family: "Pretendard Variable", "Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", "Segoe UI", sans-serif;--brand: #925528;--brand-dark: #442914;--surface: #ffffff;--surface-muted: #f4f6fb;--line: #e3e7f3;--text-primary: #22160c;--text-secondary: #5d3d1c;--alert-error: #fee4e2;--alert-success: #e5f6ed;--alert-info: #e7edff}*{box-sizing:border-box}html,body{height:100%;margin:0;font-family:var(--font-family);color:var(--text-primary);background:radial-gradient(circle at top,#eff3ff,#f5f7fc 45%,#fafbff)}.auth-shell{height:100%;min-height:0;display:flex;align-items:center;justify-content:center;padding:32px;overflow:auto}.auth-card{width:100%;max-width:960px;background:var(--surface);border:1px solid var(--line);border-radius:28px;box-shadow:0 25px 60px #0f172a14;overflow:hidden}.auth-card--split{display:grid;grid-template-columns:minmax(260px,1.1fr) minmax(320px,380px)}.auth-illustration{position:relative;padding:0;background:linear-gradient(135deg,#d7e6ff,#eff2ff);border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center;min-height:360px;aspect-ratio:1 / 1;overflow:hidden}.auth-illustration:before{content:"";position:absolute;inset:16px;border-radius:28px;border:1px dashed rgba(92,55,28,.3);pointer-events:none}.auth-illustration__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.auth-panel{padding:48px 40px 38px;display:flex;flex-direction:column;gap:20px}.auth-header h1{margin:0;font-size:28px;font-weight:800}.auth-header p{margin:8px 0 0;color:var(--text-secondary);line-height:1.5}.form{display:flex;flex-direction:column;gap:14px}.input{height:46px;padding:0 14px;border-radius:14px;border:1px solid var(--line);font-size:15px;background:var(--surface-muted);transition:border .2s,box-shadow .2s,background .2s}.input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px #5c371c26}.btn{height:48px;border-radius:14px;border:none;font-size:16px;font-weight:700;cursor:pointer;transition:transform .1s,box-shadow .2s,background .2s}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 12px 24px #5c371c40}.btn-primary:hover{background:var(--brand-dark)}.btn-primary:active{transform:translateY(1px)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--line)}.btn-outline:hover{border-color:var(--brand);color:var(--brand)}.actions{display:flex;gap:12px;margin-top:4px}.actions .btn{flex:1}.alert{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:14px;font-size:14px;border:1px solid transparent}.alert-icon{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700}.alert-error{background:var(--alert-error);border-color:#f2b4af}.alert-error .alert-icon{background:#f87171;color:#fff}.alert-success{background:var(--alert-success);border-color:#9fddb7}.alert-success .alert-icon{background:#22c55e;color:#fff}.alert-info{background:var(--alert-info);border-color:#9eb4ff}.alert-info .alert-icon{background:var(--brand);color:#fff}.link{font-size:14px;text-align:center;color:var(--text-secondary);margin-top:16px}.link a{color:var(--brand);text-decoration:none;font-weight:600}.link a:hover{text-decoration:underline}.auth-card--stack{max-width:480px;padding:48px 40px;display:flex;flex-direction:column}@media(max-width:900px){.auth-card--split{grid-template-columns:1fr}.auth-illustration{border-right:none;border-bottom:1px solid var(--line);aspect-ratio:auto;min-height:240px}}@media(max-width:520px){.auth-shell{padding:16px}.auth-panel{padding:32px 20px 28px}.auth-card--stack{padding:32px 20px 36px}.actions{flex-direction:column}}.auth-footer{margin-top:auto;display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:5px;flex-wrap:nowrap}.auth-footer__credit{font-size:12px;color:var(--text-secondary);opacity:.85;white-space:nowrap}.btn-small{height:28px;padding:0 10px;font-size:11px;border-radius:8px;box-shadow:inherit}.auth-footer__burger{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;opacity:.85}.auth-footer__burger:hover{opacity:1}@supports (background: color-mix(in srgb,#000 50%,#fff)){.auth-footer__burger.btn-primary{background:color-mix(in srgb,var(--brand) 72%,#fff)}.auth-footer__burger.btn-primary:hover{background:color-mix(in srgb,var(--brand-dark) 72%,#fff)}}:root{--bg: #fffcf7;--panel: #ffffff;--border: #e5e7eb;--muted: #6b7280;--brand: #925528;--shadow: 0 12px 28px rgba(0, 0, 0, .06);--radius-lg: 16px;--radius-md: 10px;--gap: 16px;--board-w: 770px;--page-max: 1200px}.game-layout{display:flex;flex-direction:column;height:100%;min-height:0;background:linear-gradient(180deg,var(--bg) 0%,#eef3ff 100%);color:#372d1f}.game-header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 4px 12px #0000000a;display:flex;align-items:center;padding:10px 14px;max-width:var(--page-max);margin:0 auto;width:100%;gap:12px}.game-header .left{display:flex;align-items:center;gap:10px;flex:0 0 auto;min-width:0}.game-header .center{margin-left:auto;display:flex;align-items:center;gap:10px;white-space:nowrap;font-weight:700;font-size:18px}.game-header .right-wrap{display:flex;align-items:center;gap:12px;white-space:nowrap}.account-dropdown{position:relative}.account-btn{height:32px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#514237;font-weight:600;cursor:pointer}.account-btn:hover{background:#f8fafc}.account-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:150px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 12px 28px #00000014;display:none;flex-direction:column;overflow:hidden;z-index:20}.account-dropdown:hover .account-menu,.account-dropdown:focus-within .account-menu{display:flex}.account-menu a{display:block;padding:10px 12px;color:#372d1f;text-decoration:none;font-size:14px}.account-menu a:hover{background:#f8fafc}.clock{min-width:88px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums;color:#111827}.game-main{flex:1 1 auto;min-height:0;max-width:var(--page-max);margin:0 auto;width:100%;display:flex;gap:var(--gap);padding:10px;overflow:hidden}.game-main>.left{flex:1;min-width:0;display:flex;justify-content:center}.board-stack{width:100%;max-width:var(--board-w)}.game-main>.right{width:400px;display:flex;flex-wrap:wrap;align-content:flex-start;gap:10px}.side-panels{display:flex;gap:10px;width:100%}canvas.game-canvas{width:100%;max-width:var(--board-w);aspect-ratio:770 / 600;height:auto;display:block;border:1px solid #d1d5db;background:#fff;border-radius:var(--radius-lg);touch-action:none;box-shadow:var(--shadow);cursor:crosshair}.tools{display:flex;align-items:center;gap:10px;margin-top:10px;padding:8px 10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 6px 16px #0000000a}.tools input[type=color]{width:38px;height:32px;padding:0;border:none;background:transparent}.tools input[type=range]{width:200px;max-width:100%;flex:1 1 200px}.tools button{height:32px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.tools button:hover{background:#f8fafc}.tools button.active{border-color:#5b7cff;box-shadow:0 0 0 2px #ffb25b26}.panel{border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px;min-height:0;background:var(--panel);box-shadow:var(--shadow);display:flex;flex-direction:column;box-sizing:border-box}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;position:sticky;top:0;background:#fff;z-index:1}.panel h3{margin:2px 0 6px;font-size:16px}.panel select{height:30px;padding:0 8px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:13px}.chat-panel{width:400px;height:477.5px}.users-panel{width:164px;height:175px}.ranking-panel{width:224px;height:175px}.chatlog{flex:1 1 auto;overflow:auto;height:auto;background:#fafafa;border:1px solid #eee;border-radius:var(--radius-md);padding:8px;margin-bottom:8px}.chatlog .sys{color:var(--muted);font-style:italic}.chatbox{display:flex;gap:8px}.chatbox input{flex:1;height:40px;padding:0 12px;border:1px solid #d1d5db;border-radius:var(--radius-md);font:inherit;outline:none}.chatbox input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #5b7cff26}.chatbox button{height:40px;padding:0 14px;border:none;border-radius:var(--radius-md);background:var(--brand);color:#fff;font-weight:700;cursor:pointer}.chatbox button:hover{filter:brightness(.97)}.users{list-style:none;margin:0;flex:1 1 auto;overflow:auto;padding:0 8px 8px}.ranking{flex:1 1 auto;overflow:auto;margin:0;padding:0 8px 8px;list-style:decimal;list-style-position:inside}.muted{color:var(--muted)}@media(max-width:1024px)and (orientation:portrait){.game-main{flex-direction:column;overflow:auto}.game-main>.right{width:100%;height:auto}.chat-panel,.users-panel,.ranking-panel{width:100%;height:auto;min-height:200px}}@media(max-width:768px)and (orientation:portrait){.game-header .left,.game-header .round-msg{display:none}.game-header .center{margin-left:0;justify-content:center;font-size:16px;white-space:normal;text-align:center}}@media(max-width:1024px)and (orientation:landscape){.game-header{display:none}.game-layout{height:100dvh}.game-main{flex-direction:row;max-width:none;padding:6px;overflow:hidden;height:100%}.game-main>.right{width:min(360px,42vw);height:100%;min-height:0;display:flex;flex-direction:column;flex-wrap:nowrap;overflow:hidden}.game-main>.left{height:100%;min-height:0}.board-stack{height:100%;min-height:0;display:flex;flex-direction:column;gap:6px}canvas.game-canvas{width:auto;height:auto;max-width:100%;max-height:calc(100% - 56px);aspect-ratio:770 / 600;margin:0 auto}.tools{margin-top:0;padding:6px 8px;gap:8px;flex:0 0 auto}.chat-panel{width:100%;height:auto;flex:1 1 auto;min-height:0}.side-panels{flex:0 0 auto;height:clamp(120px,32dvh,180px);min-height:0}.users-panel,.ranking-panel{width:auto;height:100%;flex:1 1 0;min-width:0}}
