:root{font-family:Noto Sans KR,Apple SD Gothic Neo,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh}.page{--bg: #ffffff;--text: #111827;--line: #e5e7eb;--sidebar-shadow: rgba(17, 24, 39, .15);--board: #f3f4f6;--board-line: #d1d5db;--button-bg: #ffffff;--button-line: #d1d5db;min-height:100vh;position:relative;overflow:hidden;background:var(--bg);color:var(--text)}.page.dark{--bg: #0b1220;--text: #f3f4f6;--line: #2b3548;--sidebar-shadow: rgba(0, 0, 0, .35);--board: #1a2438;--board-line: #3b4a68;--button-bg: #111827;--button-line: #374151}.menu-button{position:absolute;top:16px;left:16px;width:44px;height:44px;border:1px solid transparent;border-radius:10px;background:transparent;display:inline-flex;flex-direction:column;justify-content:center;gap:5px;padding:10px;cursor:pointer;transition:transform .2s ease;z-index:20}.menu-button.open{transform:rotate(90deg)}.menu-button span{display:block;width:100%;height:2px;background:var(--text);border-radius:999px}.menu-button:focus-visible{outline:2px solid var(--text);outline-offset:2px}.account-menu-wrap{position:fixed;top:16px;right:16px;z-index:35}.account-button{width:48px;height:48px;border:1px solid var(--button-line);border-radius:999px;background:var(--button-bg);color:var(--text);display:grid;place-items:center;cursor:pointer}.account-icon{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;overflow:visible}.account-dropdown{position:absolute;top:52px;right:0;width:150px;border:1px solid var(--line);border-radius:10px;background:var(--button-bg);box-shadow:0 12px 24px var(--sidebar-shadow);overflow:hidden}.account-dropdown-item{width:100%;border:none;border-bottom:1px solid var(--line);background:transparent;color:var(--text);padding:12px 14px;text-align:left;font-size:12px;cursor:pointer}.account-dropdown-item:last-child{border-bottom:none}.account-button:focus-visible,.account-dropdown-item:focus-visible{outline:2px solid var(--text);outline-offset:-2px}.sidebar{position:fixed;top:0;left:0;width:min(280px,78vw);height:100vh;background:var(--bg);border-right:1px solid var(--line);box-shadow:12px 0 24px var(--sidebar-shadow);transform:translate(-100%);transition:transform .2s ease;z-index:15;display:flex;flex-direction:column}.sidebar.open{transform:translate(0)}.sidebar-header-spacer{height:72px;border-bottom:1px solid var(--line);flex:0 0 auto}.sidebar-home-fixed{position:sticky;top:0;z-index:2;background:var(--bg);border-bottom:1px solid var(--line)}.sidebar-menu-list{flex:1 1 auto;overflow-y:auto}.menu-item{width:100%;border:none;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:transparent;color:var(--text);display:flex;align-items:center;justify-content:center;text-align:center;padding:15px 20px;font-size:15px;cursor:pointer}.menu-item+.menu-item{border-top:none}.menu-item.active{font-weight:700}.game-menu-toggle{position:relative;justify-content:center}.accordion-mark{position:absolute;right:24px;width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .16s ease}.accordion-mark.open{transform:rotate(225deg)}.submenu-list{border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--button-bg) 70%,var(--bg))}.submenu-item{width:100%;border:none;border-top:1px solid var(--line);background:transparent;color:var(--text);display:flex;align-items:center;justify-content:center;padding:12px 20px 12px 34px;font-size:13px;cursor:pointer}.rainbow-menu-label{display:inline-flex;align-items:center;gap:0}.rainbow-char{display:inline-block;animation:rainbow-char-shift 2s linear infinite}@keyframes rainbow-char-shift{0%{color:#ef4444}20%{color:#eab308}40%{color:#22c55e}60%{color:#3b82f6}80%{color:#8b5cf6}to{color:#ef4444}}.submenu-item.active{font-weight:700}.content{min-height:100vh;padding:80px 20px;display:flex;justify-content:center;align-items:flex-start}.content.chat-layout{padding:72px 0 0}.gomoku-view{width:min(100%,720px)}.chat-lobby-view{width:min(100%,720px);border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--button-bg);display:grid;gap:12px}.chat-shell{width:100%}.chat-header{display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:10px}.chat-header h2{font-size:16px;letter-spacing:.02em}.chat-header p{font-size:12px;color:color-mix(in srgb,var(--text) 66%,transparent)}.chat-connection{display:inline-flex;align-items:center;gap:6px}.chat-connection .dot{width:8px;height:8px;border-radius:999px;background:#9ca3af}.chat-connection.open .dot{background:#16a34a}.chat-connection.connecting .dot{background:#ca8a04}.chat-connection.error .dot,.chat-connection.closed .dot{background:#dc2626}.chat-meta-row{display:grid;grid-template-columns:150px 1fr auto;gap:8px;align-items:center}.chat-nickname{border:1px solid var(--button-line);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 10px;font:inherit}.chat-endpoint{border:1px dashed var(--line);border-radius:8px;padding:8px 10px;font-size:11px;color:color-mix(in srgb,var(--text) 66%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-messages{overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:6px 2px 4px}.chat-empty{font-size:13px;color:color-mix(in srgb,var(--text) 65%,transparent)}.room-list-block .chat-empty{text-align:center}.chat-lobby-actions{display:flex;justify-content:flex-start}.room-list-block{border:1px solid var(--line);border-radius:10px;padding:10px;display:grid;gap:8px}.room-list-block h3{font-size:14px}.room-list{list-style:none;display:grid;gap:8px}.room-list.room-list-column{align-content:start;overflow-y:auto}.room-list li{list-style:none}.room-list-empty{border:1px dashed var(--line);border-radius:10px;padding:12px 10px}.room-item-button{width:100%;border:1px solid var(--line);border-radius:10px;background:var(--button-bg);color:var(--text);padding:10px 12px;text-align:left;display:grid;gap:4px;cursor:pointer}.room-item-button span{font-size:12px;color:color-mix(in srgb,var(--text) 70%,transparent)}.chat-room-panel{border:1px solid var(--line);border-radius:12px;padding:12px;min-height:0;display:grid;grid-template-rows:auto 1fr auto;gap:8px}.chat-room-single{min-height:calc(100vh - 92px);width:min(100%,980px);margin:0 auto;display:grid;grid-template-rows:auto 1fr auto;gap:10px}.chat-room-single .chat-room-top{border-bottom:1px solid var(--line);padding-bottom:8px}.chat-message-area{display:none}.chat-room-single.has-messages .chat-message-area{display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0;padding:6px 2px 4px}.chat-composer-wrap{align-self:center;width:min(100%,780px);justify-self:center;transition:all .2s ease}.chat-room-single.has-messages .chat-composer-wrap{align-self:end}.chat-room-single .chat-input-row{border-top:none;padding-top:0}.chat-input-row.composer-bar{border:1px solid var(--line);background:color-mix(in srgb,var(--bg) 93%,#f3f4f6);border-radius:999px;min-height:64px;padding:8px 10px;display:flex!important;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:8px}.chat-input.composer-input{flex:1;min-width:0;width:100%;border:none;background:transparent;min-height:42px;max-height:120px;resize:none;padding:10px 4px;line-height:1.4}.composer-input:focus-visible{outline:none}.composer-icon{border:none;background:transparent;color:color-mix(in srgb,var(--text) 70%,transparent);width:34px;height:34px;border-radius:999px;display:grid;place-items:center;font-size:22px;cursor:pointer;flex:0 0 auto}.composer-plus{font-size:36px;line-height:1}.composer-mic{font-size:11px;text-transform:uppercase;letter-spacing:.4px}.composer-send{border:none;width:46px;height:46px;border-radius:999px;background:#0b0b0b;color:#fff;display:grid;place-items:center;cursor:pointer;font-size:11px;letter-spacing:1px}.composer-actions{display:flex;align-items:center;gap:4px;flex:0 0 auto;margin-left:auto}.chat-room-title{font-size:14px;font-weight:700}.chat-room-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.chat-room-nickname{margin-top:8px;display:flex;gap:8px;align-items:center}.chat-room-nickname .modal-input{width:160px}.chat-warning{border:1px solid #f59e0b;background:color-mix(in srgb,#f59e0b 16%,var(--button-bg));color:var(--text);border-radius:8px;padding:8px 10px;font-size:12px}.chat-message{max-width:100%;align-self:flex-start;background:transparent;border:none;border-radius:0;padding:0;display:grid;gap:4px}.chat-message.mine{align-self:flex-end;max-width:78%;background:color-mix(in srgb,var(--button-bg) 90%,var(--line));border:1px solid var(--line);border-radius:14px 14px 4px;padding:9px 10px 7px}.chat-message p{font-size:14px;line-height:1.4;white-space:pre-wrap;word-break:break-word}.chat-message strong{font-size:12px;letter-spacing:.01em}.chat-message time{font-size:11px;color:color-mix(in srgb,var(--text) 62%,transparent);justify-self:end}.chat-input-row{border-top:1px solid var(--line);padding-top:10px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}.chat-input{border:1px solid var(--button-line);background:var(--bg);color:var(--text);border-radius:10px;padding:10px 12px;min-height:42px;max-height:130px;resize:vertical;font:inherit}.chat-input:focus-visible{outline:2px solid var(--text);outline-offset:1px}.chat-send{border:1px solid var(--button-line);background:var(--button-bg);color:var(--text);border-radius:10px;padding:10px 14px;height:42px;cursor:pointer}.chat-send:disabled{opacity:.45;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;padding:16px;z-index:40}.modal-card{width:min(100%,420px);border-radius:12px;border:1px solid var(--line);background:var(--bg);color:var(--text);padding:16px;display:grid;gap:10px}.modal-card h3{font-size:18px}.modal-card p{font-size:13px}.modal-input{min-height:42px;max-height:42px;resize:none}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.created-room-box{border:1px dashed var(--line);border-radius:10px;padding:10px}.created-room-box p{margin-top:4px;font-size:13px}.gomoku-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.status{font-size:14px;letter-spacing:.04em}.text-button{border:1px solid var(--button-line);background:var(--button-bg);color:var(--text);border-radius:8px;padding:8px 12px;font-size:12px;cursor:pointer}.board-frame{width:min(92vw,660px);padding:10px;border:4px solid var(--board-line);background:var(--board);position:relative;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.board-frame.turn-black{border-color:#111827;box-shadow:inset 0 0 0 10px #111827,0 0 8px #11182724,0 0 18px #1118272e}.board-frame.turn-white{border-color:#cbd5e1;box-shadow:inset 0 0 0 10px #fff,0 0 8px #ffffff4d,0 0 20px #ffffff61}.page.dark .board-frame.turn-black{border-color:#34d399;box-shadow:inset 0 0 0 10px #34d399,0 0 10px #34d39952,0 0 22px #34d3996b}.page.dark .board-frame.turn-white{border-color:#cbd5e1;box-shadow:inset 0 0 0 10px #f8fafc,0 0 8px #f8fafc2e,0 0 22px #f8fafc3d}.board-frame.winner{border-color:transparent;box-shadow:inset 0 0 0 10px #ef4444,0 0 10px #ef444447,0 0 24px #ef444459;animation:board-rainbow-frame 1.8s linear infinite}@keyframes board-rainbow-frame{0%{border-color:#ef4444;box-shadow:inset 0 0 0 10px #ef4444,0 0 10px #ef444447,0 0 24px #ef444459}20%{border-color:#f59e0b;box-shadow:inset 0 0 0 10px #f59e0b,0 0 10px #f59e0b47,0 0 24px #f59e0b59}40%{border-color:#22c55e;box-shadow:inset 0 0 0 10px #22c55e,0 0 10px #22c55e47,0 0 24px #22c55e59}60%{border-color:#3b82f6;box-shadow:inset 0 0 0 10px #3b82f6,0 0 10px #3b82f647,0 0 24px #3b82f659}80%{border-color:#a855f7;box-shadow:inset 0 0 0 10px #a855f7,0 0 10px #a855f747,0 0 24px #a855f759}to{border-color:#ef4444;box-shadow:inset 0 0 0 10px #ef4444,0 0 10px #ef444447,0 0 24px #ef444459}}.board{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--board);border:1px solid var(--board-line);overflow:hidden}.grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.grid-lines line{stroke:var(--board-line);stroke-width:.25}.point{position:absolute;width:28px;height:28px;border:none;background:transparent;cursor:pointer;transform:translate(-50%,-50%)}.point:before{content:"";position:absolute;top:7px;right:7px;bottom:7px;left:7px;border-radius:50%;background:transparent;transition:background .12s ease}.point:hover:before{background:#6b728029}.stone{position:absolute;width:18px;height:18px;border-radius:999px;top:50%;left:50%;transform:translate(-50%,-50%)}.stone.black{background:#111827}.stone.white{background:#fff;border:1px solid #9ca3af}.page.dark .stone.black{background:#22c55e;box-shadow:0 0 8px #22c55ebf,0 0 18px #22c55e8c,0 0 30px #22c55e59}.page.dark .stone.white{box-shadow:0 0 8px #ffffffc7,0 0 16px #ffffff8f,0 0 26px #ffffff57}.home-icon{width:18px;height:18px;fill:currentColor}.theme-toggle{position:fixed;right:18px;bottom:18px;border:1px solid var(--button-line);background:var(--button-bg);color:var(--text);border-radius:999px;padding:10px 14px;font-size:12px;letter-spacing:.04em;cursor:pointer;z-index:30}@media (max-width: 640px){.content,.content.chat-layout{padding-top:72px}.chat-room-single{min-height:calc(100vh - 88px)}.chat-message{max-width:88%}.chat-meta-row{grid-template-columns:1fr}.chat-room-top,.chat-room-nickname{flex-direction:column;align-items:flex-start}.chat-room-nickname .modal-input{width:100%}}.auth-shell{width:min(100%,900px);display:grid;gap:14px}.home-empty{width:100%;min-height:120px}.auth-card{border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--button-bg);display:grid;gap:10px}.auth-card h2{font-size:17px}.auth-logged-in{width:min(100%,420px)}.auth-tip{font-size:12px;color:color-mix(in srgb,var(--text) 70%,transparent)}.form-stack{display:grid;gap:8px}.auth-actions{display:flex;gap:8px;align-items:center}.auth-actions-col{flex-direction:column;align-items:stretch}.password-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.board-shell{width:min(100%,900px);display:grid;gap:12px}.suika-shell{width:min(100%,420px);display:grid;gap:10px}.suika-meta{display:flex;align-items:center;justify-content:space-between}.suika-field{position:relative;width:min(100%,360px);height:560px;border:1px solid var(--line);border-radius:14px;touch-action:manipulation;background:color-mix(in srgb,var(--bg) 84%,#f8fafc);overflow:hidden;cursor:crosshair}.suika-top-line{position:absolute;left:0;right:0;top:32px;border-top:2px dashed color-mix(in srgb,var(--text) 25%,transparent)}.suika-preview{position:absolute;border-radius:999px;opacity:.45}.suika-ball{position:absolute;border-radius:999px;box-shadow:inset -8px -8px 12px #0000001f}.page.dark .suika-ball{box-shadow:inset -8px -8px 12px #00000038,0 0 9px color-mix(in srgb,var(--ball-glow, #ffffff) 54%,#ffffff 22%),0 0 18px color-mix(in srgb,var(--ball-glow, #ffffff) 40%,transparent),0 0 30px color-mix(in srgb,var(--ball-glow, #ffffff) 26%,transparent);filter:saturate(1.12) brightness(1.03);animation:suika-glitter 1.9s ease-in-out infinite alternate}@keyframes suika-glitter{0%{transform:translateZ(0) scale(1);opacity:.94}to{transform:translateZ(0) scale(1.015);opacity:.98}}.suika-field.over{outline:2px solid #dc2626}.suika-over{position:absolute;top:8px;left:50%;transform:translate(-50%);border-radius:999px;border:1px solid #dc2626;background:#fee2e2;color:#991b1b;padding:4px 10px;font-size:12px;font-weight:700}.tama-shell{width:min(100%,420px);display:grid;gap:12px}.tama-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.tama-top h2{font-size:20px}.tama-top p{margin-top:2px;font-size:12px;color:color-mix(in srgb,var(--text) 65%,transparent)}.tama-stage{border:1px solid var(--line);background:color-mix(in srgb,var(--bg) 88%,#f8fafc);min-height:300px;display:grid;place-items:center;align-content:center;gap:14px}.tama-stage.good{background:color-mix(in srgb,var(--bg) 82%,#dcfce7)}.tama-stage.bad{background:color-mix(in srgb,var(--bg) 82%,#fee2e2)}.tama-stage.sleep{background:color-mix(in srgb,var(--bg) 82%,#dbeafe)}.tama-pet{width:132px;height:132px;object-fit:contain;image-rendering:pixelated}.tama-status{font-size:13px;font-weight:700;letter-spacing:.08em}.tama-stats{border:1px solid var(--line);background:var(--button-bg);padding:12px;display:grid;gap:10px}.tama-stats label{display:grid;grid-template-columns:78px 1fr 36px;gap:8px;align-items:center;font-size:12px}.tama-stats meter{width:100%;height:14px}.tama-stats span{text-align:right;font-variant-numeric:tabular-nums}.tama-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.tama-actions .chat-send{padding:8px 6px}.board-form{border:1px solid var(--line);border-radius:12px;background:var(--button-bg);padding:14px;display:grid;gap:10px}.board-form h2{font-size:18px}.board-list{display:grid;gap:10px}.board-item{border:1px solid var(--line);border-radius:12px;background:var(--button-bg);padding:12px;display:grid;gap:8px}.board-item-head{display:flex;justify-content:space-between;gap:8px;align-items:center}.board-item-head span{font-size:12px;color:color-mix(in srgb,var(--text) 65%,transparent)}.board-item p{white-space:pre-wrap;word-break:break-word;font-size:14px}.board-item-foot{display:flex;justify-content:space-between;align-items:center;gap:8px}.board-item-foot time{font-size:12px;color:color-mix(in srgb,var(--text) 62%,transparent)}.poem-shell,.poem-detail{border:1px solid var(--line);border-radius:12px;background:var(--button-bg);padding:16px;display:grid;gap:12px}.poem-shell-head,.poem-detail-actions{display:flex;justify-content:space-between;align-items:center;gap:10px}.poem-shell-actions{display:flex;align-items:center;gap:8px}.poem-add-button{width:34px;height:34px;border:1px solid var(--line);background:var(--bg);font-size:22px;line-height:1}.poem-composer{width:100%;min-width:0;border-top:1px solid var(--line);padding-top:14px;display:grid;gap:10px}.poem-composer-standalone{border-top:none;padding-top:0}.poem-composer-title,.poem-detail-title{width:100%;min-width:0;text-align:center;font-size:24px;font-weight:700}.poem-detail-title{margin:0}.poem-composer-author,.poem-detail-author{justify-self:end;font-size:13px;color:color-mix(in srgb,var(--text) 68%,transparent)}.poem-composer-content{width:100%;min-width:0;min-height:260px;resize:vertical;white-space:pre-wrap}.poem-composer-actions{display:flex;justify-content:flex-end;gap:8px}.poem-list{display:grid;gap:10px}.poem-list-item{width:100%;border:1px solid var(--line);border-radius:12px;background:var(--button-bg);padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left}.poem-list-item strong{font-size:15px}.poem-list-item time{font-size:12px;color:color-mix(in srgb,var(--text) 62%,transparent);flex-shrink:0}.poem-detail-content{margin:0;white-space:pre-wrap;word-break:break-word;font-family:inherit;font-size:15px;line-height:1.7}.admin-panel{border:1px solid var(--line);border-radius:12px;background:var(--button-bg);padding:14px;display:grid;gap:10px}.admin-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.admin-panel h3{font-size:16px}.admin-user-list{list-style:none;display:grid;gap:8px}.admin-user-list li{border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;justify-content:space-between;align-items:center;gap:10px}.admin-user-list li>div{display:grid;gap:4px}.admin-user-list span{font-size:12px;color:color-mix(in srgb,var(--text) 65%,transparent)}.admin-user-actions{display:flex;gap:8px}@media (max-width: 640px){.admin-panel-head,.admin-user-list li{flex-direction:column;align-items:flex-start}.admin-user-actions{width:100%;flex-wrap:wrap}.poem-shell-head,.poem-detail-actions,.poem-list-item{flex-direction:column;align-items:flex-start}.poem-shell-actions,.poem-composer-actions{width:100%;justify-content:space-between}.poem-shell{padding:14px}.poem-composer{padding-top:12px}.poem-composer-title,.poem-detail-title{font-size:20px}.password-row{grid-template-columns:1fr}}
