:root{--bg: #f5f0e8;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-card-h: #fbf9f5;--border: rgba(30,45,74,.14);--border-dim: rgba(30,45,74,.1);--text: #1a1a1a;--text-muted: #6b6b6b;--text-dim: rgba(26,26,26,.55);--primary: #1a3a2a;--primary-2: #1e2d4a;--accent: #c8860a;--accent-dim: rgba(200,134,10,.14);--accent-glow: rgba(200,134,10,.22);--success: #1f6f4a;--success-dim: rgba(31,111,74,.1);--error: #b23a3a;--error-dim: rgba(178,58,58,.1);--shadow: 0 10px 24px rgba(30,45,74,.1);--shadow-sm: 0 6px 14px rgba(30,45,74,.08);--locked: #ede6dd;--radius: 10px;--font: "Noto Serif SC", serif;--mono: "JetBrains Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.75;min-height:100vh}.toast-stack{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;width:min(460px,calc(100vw - 36px));z-index:9999;pointer-events:none}.toast{pointer-events:auto;background:#ffffffeb;border:1px solid rgba(30,45,74,.18);box-shadow:var(--shadow);border-radius:16px;padding:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-title{font-size:14px;font-weight:800;color:var(--primary-2);line-height:1.35}.toast-body{margin-top:6px;font-size:13px;color:#1a1a1ab8;font-family:var(--mono);word-break:break-word}.toast.success{border-color:#1f6f4a4d}.toast.success .toast-title{color:var(--success)}.toast.error{border-color:#b23a3a4d}.toast.error .toast-title{color:var(--error)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffffa6;color:var(--primary-2);font-family:var(--font);font-size:14px;cursor:pointer;transition:all .15s}.btn:hover{border-color:#1e2d4a47;background:var(--bg-surface);box-shadow:var(--shadow-sm)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#1a1a1a;font-weight:600}.btn-primary:hover{background:#d69415;border-color:#d69415;color:#1a1a1a}.btn-ghost{border:none;background:none}input[type=text],input[type=password]{width:100%;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:15px;outline:none;transition:border-color .15s}input:focus{border-color:#c8860a8c;box-shadow:0 0 0 4px #c8860a24}input::placeholder{color:var(--text-muted)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,rgba(200,134,10,.18),transparent),var(--bg)}.login-card{width:360px;padding:48px 40px 40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.login-title{font-size:28px;font-weight:700;color:var(--primary);letter-spacing:.05em;margin-bottom:4px}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:36px}.field{margin-bottom:20px}.field label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:8px}.error-msg{font-size:13px;color:var(--error);margin-bottom:16px}.login-card .btn-primary{width:100%;justify-content:center;margin-top:8px}.nickname-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,rgba(200,134,10,.18),transparent),var(--bg)}.nickname-card{width:360px;padding:40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;text-align:center;box-shadow:var(--shadow)}.nickname-card h2{font-size:20px;color:var(--primary);margin-bottom:8px}.nickname-card p{font-size:13px;color:var(--text-muted);margin-bottom:28px}.nickname-card .btn-primary{width:100%;justify-content:center;margin-top:12px}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:56px;background:#f5f0e8db;border-bottom:1px solid var(--border);box-shadow:0 8px 18px #1e2d4a14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-header-title{font-size:16px;font-weight:700;color:var(--primary-2);letter-spacing:.08em}.app-header-right{display:flex;align-items:center;gap:16px}.nickname-badge{font-size:13px;color:var(--text-muted)}.nickname-badge span{color:var(--text)}.nickname-edit{margin-left:10px;padding:4px 10px;border-radius:999px;border:1px solid rgba(30,45,74,.14);background:#ffffff8c;color:var(--primary-2)}.nickname-edit:hover{background:var(--bg-surface)}.gameboard{padding:32px 28px 64px;max-width:1100px;margin:0 auto}.gameboard-columns{display:grid;gap:28px;align-items:start}.gameboard-columns.one-col{grid-template-columns:1fr}.gameboard-columns.two-col{grid-template-columns:1fr 1fr}@media (max-width: 980px){.gameboard-columns.two-col{grid-template-columns:1fr}}.area-section{margin-bottom:56px}.gameboard-columns .area-section{margin-bottom:0}.area-header{display:flex;align-items:baseline;gap:16px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-dim)}.area-name{font-size:20px;font-weight:500;color:var(--text)}.area-progress{font-size:13px;color:var(--text-muted);font-family:var(--mono)}.area-locked-badge{font-size:12px;color:var(--text-dim);border:1px solid var(--border-dim);padding:2px 10px;border-radius:20px}.puzzle-list{display:flex;flex-direction:column;gap:6px}.puzzle-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--bg-surface);box-shadow:0 1px #1e2d4a08;cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s,background .12s}.puzzle-row:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#1e2d4a38}.puzzle-row.active{border-color:#c8860a59}.puzzle-row.locked{background:#1e2d4a0a;border-color:#1e2d4a1a;cursor:default;opacity:.8}.puzzle-row.locked:hover{transform:none;box-shadow:none;border-color:#1e2d4a1a}.puzzle-row.solved{background:#1f6f4a0f}.puzzle-row.solved .puzzle-row-title{color:#1a1a1a9e}.puzzle-row.solved .puzzle-row-answer{color:#1a1a1a8c}.puzzle-row.solved .puzzle-row-status{color:#1f6f4abf}.puzzle-row.solved{border-color:#1f6f4a2e}.puzzle-row.solved:hover{border-color:#1f6f4a47}.puzzle-row-status{min-width:18px;text-align:right}.puzzle-row-answer{background:#1e2d4a0a;border:1px solid rgba(30,45,74,.1);padding:2px 8px;border-radius:999px}.puzzle-row-passbtn{border:1px solid rgba(200,134,10,.35);background:#c8860a1a;color:var(--primary-2);padding:4px 10px;border-radius:999px;cursor:pointer;font-size:12px;font-family:var(--font);flex-shrink:0}.puzzle-row-passbtn:hover{background:#c8860a29;border-color:#c8860a8c}.puzzle-row-index{font-family:var(--mono);font-size:12px;color:#1e2d4ab3;width:46px;flex-shrink:0}.puzzle-row-title{flex:1;font-size:14px;color:var(--text);line-height:1.35}.puzzle-row-status{font-family:var(--mono);font-size:12px;color:#1e2d4ab8;flex-shrink:0}.puzzle-row-answer{font-family:var(--mono);font-size:12px;color:#1e2d4ac7;flex-shrink:0;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-meta-badge{display:inline-block;font-size:11px;color:var(--accent);background:var(--accent-dim);padding:1px 8px;border-radius:10px;margin-top:6px}.puzzle-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.puzzle-topbar{display:flex;align-items:center;gap:16px;padding:0 20px;height:52px;background:#f5f0e8b3;border-bottom:1px solid var(--border);box-shadow:0 6px 16px #1e2d4a0f;flex-shrink:0}.puzzle-topbar-title{font-size:16px;font-weight:500;flex:1}.solved-badge{font-size:12px;color:var(--success);background:var(--success-dim);padding:3px 10px;border-radius:20px;font-family:var(--mono)}.puzzle-layout{display:flex;flex:1;overflow:hidden}.puzzle-iframe-area{flex:1;position:relative;background:transparent;padding:16px 18px 18px;overflow:hidden}.puzzle-left-scroll{height:100%;overflow:auto;padding-right:6px}.puzzle-title{font-size:26px;line-height:1.25;font-weight:800;color:var(--primary-2);letter-spacing:.02em;margin:6px 4px 14px}.iframe-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;color:var(--text-muted);font-size:14px;background:transparent}.iframe-fallback a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-dim);padding-bottom:2px}.puzzle-sidebar{width:380px;flex-shrink:0;display:flex;flex-direction:column;background:#ffffffbf;border-left:1px solid var(--border);overflow:hidden}.sidebar-content{flex:1;overflow-y:auto;padding:16px}.sidebar-section{padding:10px 2px}.sidebar-section-title{font-size:12px;letter-spacing:.08em;color:#1e2d4ab8;font-weight:800;text-transform:uppercase;margin-bottom:10px}.sidebar-divider{height:1px;background:#1e2d4a1f;margin:14px 0}.submit-form{margin-bottom:24px}.submit-form label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:8px}.submit-row{display:flex;gap:8px;margin-top:8px}.submit-row input{flex:1}.submit-row .btn-primary{padding:10px 16px;white-space:nowrap}.submit-result{font-size:13px;padding:10px 14px;border-radius:var(--radius);margin-top:10px;font-family:var(--mono)}.submit-result.correct{background:var(--success-dim);color:var(--success)}.submit-result.wrong{background:var(--error-dim);color:var(--error)}.submissions-list{margin-top:8px}.submissions-list h4{font-size:12px;color:var(--text-muted);margin-bottom:10px;letter-spacing:.06em}.sub-item{display:flex;align-items:baseline;gap:8px;padding:7px 0;border-bottom:1px solid var(--border-dim);font-size:13px}.sub-item:last-child{border-bottom:none}.sub-answer{font-family:var(--mono);color:var(--text);flex:1;word-break:break-all}.sub-answer.correct-ans{color:var(--success)}.sub-by{color:var(--text-muted);font-size:12px;flex-shrink:0}.sub-time{color:var(--text-dim);font-size:11px;flex-shrink:0;font-family:var(--mono)}.sub-icon{font-size:12px;flex-shrink:0}.hint-item{margin-bottom:12px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-dim)}.hint-header{display:flex;padding:10px 14px;background:var(--bg-card);font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none}.hint-header:hover{background:var(--bg-card-h)}.hint-header-main{width:100%;display:flex;flex-direction:column;gap:6px}.hint-header-row{width:100%;display:flex;align-items:baseline;justify-content:space-between;gap:10px}.hint-label{color:var(--text);font-weight:700}.hint-readers{font-size:11px;color:var(--text-dim);font-family:var(--mono);flex-shrink:0}.hint-meta{font-size:12px;color:var(--text-muted)}.hint-body{padding:12px 14px;font-size:14px;color:var(--text);background:var(--bg-surface);line-height:1.8;white-space:pre-wrap}.hint-locked{display:flex;padding:12px 14px;border:1px solid var(--border-dim);border-radius:var(--radius);margin-bottom:12px;background:#ffffff8c}.hint-locked-label{font-size:13px;color:var(--text);font-weight:700}.hint-countdown{font-size:12px;color:var(--text-dim);font-family:var(--mono)}.no-hints{font-size:13px;color:var(--text-muted);text-align:center;padding:32px 0}.puzzle-content{padding:26px 28px;max-width:980px;margin:0 auto 18px;background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;color:var(--text);font-size:15px;line-height:1.85;font-family:"Noto Serif SC",serif}:where(.puzzle-content) :where(p,ul,ol,blockquote,pre,table,details){margin:10px 0}:where(.puzzle-content) :where(h1,h2,h3){margin:18px 0 10px;line-height:1.35}:where(.puzzle-content) :where(h1){font-size:22px}:where(.puzzle-content) :where(h2){font-size:18px}:where(.puzzle-content) :where(h3){font-size:16px}:where(.puzzle-content) :where(a){color:var(--primary-2);text-decoration:underline;text-underline-offset:2px}:where(.puzzle-content) :where(a:hover){color:var(--accent)}:where(.puzzle-content) :where(img){max-width:100%;height:auto;display:block;margin:12px 0}:where(.puzzle-content) :where(ul,ol){padding-left:1.4em}:where(.puzzle-content) :where(li){margin:4px 0}:where(.puzzle-content) :where(table){border-collapse:collapse;width:100%;margin:12px 0;font-size:14px}:where(.puzzle-content) :where(td,th){border:1px solid rgba(30,45,74,.14);padding:6px 10px;vertical-align:top}:where(.puzzle-content) :where(th){background:#0000000a;font-weight:600}:where(.puzzle-content) :where(hr){border:none;border-top:1px solid #e7e7e7;margin:16px 0}:where(.puzzle-content) :where(blockquote){border-left:3px solid rgba(0,0,0,.18);padding:8px 12px;background:#00000008;color:#000000c7}:where(.puzzle-content) :where(code){font-family:var(--mono);font-size:13px;background:#0000000a;padding:1px 6px;border-radius:6px}:where(.puzzle-content) :where(pre){background:#0000000a;border:1px solid rgba(0,0,0,.1);padding:12px 14px;border-radius:10px;overflow:auto;max-width:100%}:where(.puzzle-content) :where(pre code){background:transparent;padding:0;border-radius:0;white-space:pre}:where(.puzzle-content) :where(.well){padding:12px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#00000008}:where(.puzzle-content) :where(details){border:1px solid rgba(0,0,0,.1);border-radius:10px;padding:10px 12px;background:#00000005}:where(.puzzle-content) :where(summary){cursor:pointer;font-weight:600;-webkit-user-select:none;user-select:none;color:#000000bf}:where(.puzzle-content) :where(details[open] summary){margin-bottom:10px}:where(.puzzle-content) :where(center){text-align:center}:where(.puzzle-content) :where(video){max-width:100%;height:auto;display:block;margin:12px 0}
