:root{--bg: #fdf6f0;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-card-h: #fff6fa;--border: rgba(26,26,26,.1);--border-dim: rgba(26,26,26,.08);--text: #1a1a1a;--text-muted: rgba(26,26,26,.62);--text-dim: rgba(26,26,26,.45);--primary: #1a1a1a;--accent: #ff85a1;--accent-dim: #ffe0ea;--accent-glow: rgba(255,133,161,.3);--success: #4caf82;--success-dim: #e8f7f0;--error: #e05252;--error-dim: #fdeaea;--gray: #f0ebe6;--shadow: 0 2px 12px rgba(0,0,0,.06);--shadow-sm: 0 2px 10px rgba(0,0,0,.05);--locked: rgba(26,26,26,.04);--radius: 12px;--font: "Noto Sans SC", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);background-image:radial-gradient(circle at 14px 14px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 6px 22px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 22px 22px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 14px 26px,rgba(26,26,26,.04) 0 3px,transparent 4px),radial-gradient(circle at 80px 70px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 72px 78px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 88px 78px,rgba(26,26,26,.04) 0 2px,transparent 3px),radial-gradient(circle at 80px 82px,rgba(26,26,26,.04) 0 3px,transparent 4px);background-size:140px 120px;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(26,26,26,.14);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(--text);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:#4caf8259}.toast.success .toast-title{color:var(--success)}.toast.error{border-color:#e0525259}.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:#ffffffdb;color:var(--text);font-family:var(--font);font-size:14px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.btn:hover{border-color:#1a1a1a29;background:var(--bg-surface);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#1a1a1a;font-weight:700}.btn-primary:hover{background:#ff6f93;border-color:#ff6f93;color:#1a1a1a;transform:scale(1.03)}.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:var(--accent);box-shadow:0 0 0 4px var(--accent-dim)}input::placeholder{color:var(--text-muted)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(#fdf6f0b8,#fdf6f0b8),url(/bg.png) center/cover no-repeat,radial-gradient(ellipse 60% 50% at 50% -10%,rgba(255,133,161,.18),transparent),var(--bg)}.login-card{width:360px;padding:48px 40px 40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.login-title{font-size:28px;font-weight:800;color:var(--text);letter-spacing:.05em;margin-bottom:4px;white-space:nowrap}.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}.field select{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,box-shadow .15s}.field select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-dim)}.error-msg{font-size:13px;color:var(--error);margin-bottom:16px}.login-card .btn-primary{width:100%;justify-content:center;margin-top:8px}.login-footnote{margin-top:16px;font-size:12px;color:var(--text-dim);text-align:center}.nickname-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,rgba(255,133,161,.22),transparent),var(--bg)}.nickname-card{width:360px;padding:40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;text-align:center;box-shadow:var(--shadow)}.nickname-card h2{font-size:20px;color:var(--text);margin-bottom:8px;font-weight:800}.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:#ffffffd1;border-bottom:1px solid var(--border);box-shadow:0 6px 18px #0000000f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cockpit-bar{gap:16px}.cockpit-left{font-weight:800;letter-spacing:.02em;white-space:nowrap}.cockpit-center{display:flex;align-items:center;gap:10px;padding:0;border-radius:0;background:transparent;border:none;box-shadow:none;white-space:nowrap}.cockpit-hunt{font-weight:800}.cockpit-sep{color:var(--text-dim)}.cockpit-solved{font-family:var(--mono);color:#1a1a1ab3}.cockpit-status{font-weight:800}.cockpit-status.ongoing{color:var(--error)}.cockpit-status.done{color:var(--success)}.cockpit-right{position:relative;display:flex;align-items:center}.user-menu{position:relative}.user-menu-trigger{border:1px solid rgba(26,26,26,.12);background:#ffffffdb;box-shadow:var(--shadow-sm);border-radius:999px;padding:8px 12px;font-family:var(--font);font-weight:800;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.user-menu-trigger:hover{transform:translateY(-1px);border-color:#1a1a1a2e}.user-menu-caret{color:var(--text-dim);font-weight:900;margin-left:2px}.user-menu-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:140px;background:#ffffffeb;border:1px solid rgba(26,26,26,.12);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000}.user-menu-item{width:100%;text-align:left;border:none;background:transparent;padding:10px 12px;cursor:pointer;font-family:var(--font);font-size:14px;color:var(--text);transition:background .15s}.user-menu-item:hover{background:#ff85a11f}.user-menu-item.danger:hover{background:var(--error-dim);color:var(--error)}.app-header-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:.08em;white-space:nowrap}.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-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;align-items:stretch}.area-header-collapsible,.chapter-header{-webkit-user-select:none;user-select:none;cursor:pointer}.area-collapse-caret{margin-left:6px;color:#1a1a1aad;font-family:var(--mono);font-weight:900;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;border-radius:999px;border:1px solid rgba(26,26,26,.12);background:#1a1a1a08}.chapter-header{font-size:13px;color:var(--text-muted);margin-bottom:12px;display:flex;gap:12px;align-items:baseline;justify-content:space-between}.chapter-title{display:flex;align-items:baseline;gap:6px}.chapter-progress{font-family:var(--mono);color:#1a1a1a73}.puzzle-card{position:relative;border-radius:14px;padding:14px 14px 12px;background:#ffffffdb;border:1px solid var(--border);box-shadow:0 1px #1e2d4a08;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;display:flex;flex-direction:column;gap:8px}.puzzle-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#1a1a1a2e}.puzzle-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.puzzle-card-top-right{display:flex;align-items:center;gap:8px}.puzzle-card-index{font-family:var(--mono);font-size:12px;color:#1e2d4ab3}.puzzle-card-title{font-weight:800;color:#1a1a1aeb;line-height:1.28;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.puzzle-card-badge{font-size:12px;font-weight:800;border-radius:999px;padding:2px 8px;border:1px solid rgba(26,26,26,.1);background:#1a1a1a08;color:#1a1a1abd;white-space:nowrap}.puzzle-card-badge.badge-open{border-color:#ff85a152;background:#ff85a11a;color:#1a1a1acc}.puzzle-card-badge.badge-solved{width:22px;height:22px;display:flex;align-items:center;justify-content:center;padding:0;border-color:#78a56261;background:#78a5622e;color:#78a562;font-family:var(--mono);font-weight:900}.puzzle-card-badge.badge-locked{border-color:#1a1a1a1f;background:#1a1a1a08;color:#1a1a1a8c}.puzzle-card-meta{display:flex;flex-wrap:wrap;gap:6px}.puzzle-card-stat{font-size:12px;padding:2px 6px;border-radius:999px;background:transparent;border:0;color:#1a1a1a9e;display:flex;align-items:center;gap:6px}.puzzle-card-stat-icon{font-size:12px;opacity:.55}.puzzle-card-answer{margin-top:2px;font-family:var(--mono);font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;border:1px solid rgba(120,165,98,.4);background:#e2f2d8fa;color:#426e3aeb;width:fit-content;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.puzzle-card.solved{background:#ecf6e7b8;border-color:#78a5622e}.puzzle-card.solved .puzzle-card-title{color:#1a1a1ab3;font-weight:750}.puzzle-card.solved:hover{transform:translateY(-1px);border-color:#78a56242}.puzzle-card.open{border-color:#ff85a13d}.puzzle-card.open:hover{border-color:#1a1a1a38}.puzzle-card.open:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:999px;background:var(--accent)}.puzzle-card.locked{background:#1a1a1a08;border-color:#1a1a1a14;opacity:.82;cursor:default}.puzzle-card.locked:hover{transform:none;box-shadow:0 1px #1e2d4a08;border-color:#1a1a1a14}.puzzle-card-passbtn{margin-top:6px;align-self:flex-start;border:1px solid rgba(255,133,161,.4);background:#ff85a124;color:var(--text);padding:4px 10px;border-radius:999px;cursor:pointer;font-size:12px;font-family:var(--font)}.puzzle-card-passbtn:hover{background:#ff85a133;border-color:#ff85a199}.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-row{display:flex;align-items:center;gap:10px;margin:0 2px 10px}.puzzle-back{padding:6px 12px;border-radius:999px;background:var(--accent);border-color:var(--accent);color:#1a1a1a;font-weight:800}.puzzle-back:hover{background:#ff6f93;border-color:#ff6f93;transform:translateY(-1px)}.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:transparent;border-left:none;overflow:hidden}.sidebar-content{flex:1;overflow-y:auto;padding:16px}.sidecard{background:#ffffffeb;border:1px solid rgba(26,26,26,.12);box-shadow:var(--shadow);border-radius:16px;padding:12px;margin-bottom:14px}.sidecard:last-child{margin-bottom:0}.sidecard-title{font-size:13px;font-weight:900;color:var(--text);margin:2px 2px 10px;letter-spacing:.02em}.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:0;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:var(--font);overflow:hidden}.puzzle-content-head{padding:18px 20px 0}.puzzle-content-body{padding:0 20px 20px}:where(.puzzle-content-body) :where(p,ul,ol,blockquote,pre,table,details){margin:10px 0}:where(.puzzle-content-body) :where(h1,h2,h3){margin:18px 0 10px;line-height:1.35}:where(.puzzle-content-body) :where(h1){font-size:22px}:where(.puzzle-content-body) :where(h2){font-size:18px}:where(.puzzle-content-body) :where(h3){font-size:16px}:where(.puzzle-content-body) :where(a){color:var(--primary-2);text-decoration:underline;text-underline-offset:2px}:where(.puzzle-content-body) :where(a:hover){color:var(--accent)}:where(.puzzle-content-body) :where(img){max-width:100%;height:auto;display:block;margin:12px 0}:where(.puzzle-content-body) :where(ul,ol){padding-left:1.4em}:where(.puzzle-content-body) :where(li){margin:4px 0}:where(.puzzle-content-body) :where(table){border-collapse:collapse;width:100%;margin:12px 0;font-size:14px}:where(.puzzle-content-body) :where(td,th){border:1px solid rgba(26,26,26,.14);padding:6px 10px;vertical-align:top}:where(.puzzle-content-body) :where(th){background:#1a1a1a0a;font-weight:600}:where(.puzzle-content-body) :where(hr){border:none;border-top:1px solid rgba(26,26,26,.12);margin:16px 0}:where(.puzzle-content-body) :where(blockquote){border-left:3px solid rgba(0,0,0,.18);padding:8px 12px;background:#00000008;color:#000000c7}:where(.puzzle-content-body) :where(code){font-family:var(--mono);font-size:13px;background:#0000000a;padding:1px 6px;border-radius:6px}:where(.puzzle-content-body) :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-body) :where(pre code){background:transparent;padding:0;border-radius:0;white-space:pre}:where(.puzzle-content-body) :where(.well){padding:12px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#00000008}:where(.puzzle-content-body) :where(details){border:1px solid rgba(0,0,0,.1);border-radius:10px;padding:10px 12px;background:#00000005}:where(.puzzle-content-body) :where(summary){cursor:pointer;font-weight:600;-webkit-user-select:none;user-select:none;color:#000000bf}:where(.puzzle-content-body) :where(details[open] summary){margin-bottom:10px}:where(.puzzle-content-body) :where(center){text-align:center}:where(.puzzle-content-body) :where(video){max-width:100%;height:auto;display:block;margin:12px 0}
