.ci{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.ci-reply{padding:10px 0;margin-left:16px;border-bottom:none}.ci-pending{opacity:.6}.ci-cancelled .ci-body{text-decoration:line-through;color:var(--text-muted)}.ci-schedule{display:flex;align-items:center;gap:6px;margin-bottom:4px}.ci-schedule-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ci-schedule-date{font-size:13px;font-weight:700;color:var(--text)}.ci-schedule-time{font-size:12px;color:var(--text-muted)}.ci-cancelled-badge{font-size:11px;color:#fff;background:#ef4444;border-radius:4px;padding:1px 6px;font-weight:700}.ci-content{flex:1 1;min-width:0}.ci-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.ci-date{font-size:12px;color:var(--text-muted)}.ci-pending-badge{font-size:11px;color:#f59e0b;font-weight:600}.ci-approve-btn{color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:1px 8px}.ci-approve-btn,.ci-delete-btn{font-size:11px;background:none;cursor:pointer}.ci-delete-btn{color:var(--text-muted);border:none;padding:2px 4px}.ci-delete-btn:hover{color:#ef4444}.ci-body{font-size:14px;line-height:1.6;color:var(--text);margin:4px 0;white-space:pre-wrap;word-break:break-word}.ci-actions{display:flex;align-items:center;gap:8px;margin-top:4px}.cc{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text);transition:border-color .15s;overflow:hidden}.cc:hover{border-color:var(--accent)}.cc-reason{display:block;font-size:11px;font-weight:700;color:var(--accent);padding:8px 14px 0}.cc-body{display:flex;gap:12px;padding:12px 14px}.cc-img{object-fit:cover}.cc-emoji,.cc-img{border-radius:8px;flex-shrink:0}.cc-emoji{display:flex;align-items:center;justify-content:center;background:var(--surface2)}.cc-info{flex:1 1;min-width:0}.cc-title{font-weight:700;margin:0 0 4px;color:var(--text)}.cc-desc{margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cc-desc,.cc-meta{color:var(--text-muted)}.cc-meta{font-size:12px;display:flex;align-items:center;gap:4px}.cc-sm .cc-body{padding:8px 10px;gap:8px}.cc-sm .cc-emoji,.cc-sm .cc-img{width:48px;height:48px}.cc-sm .cc-emoji{font-size:22px}.cc-sm .cc-title{font-size:13px;margin:0 0 2px}.cc-sm .cc-desc{font-size:11px;-webkit-line-clamp:1}.cc-md .cc-emoji,.cc-md .cc-img{width:72px;height:72px}.cc-md .cc-emoji{font-size:30px}.cc-md .cc-title{font-size:14px}.cc-md .cc-desc{font-size:12px}.cc-lg{display:flex;flex-direction:column}.cc-lg .cc-body{flex-direction:column;gap:0;padding:0}.cc-lg .cc-img{width:100%;height:180px;border-radius:0}.cc-lg .cc-emoji{width:100%;height:140px;font-size:48px;border-radius:0}.cc-lg .cc-info{padding:14px}.cc-lg .cc-title{font-size:16px}.cc-lg .cc-desc{font-size:13px}@media (max-width:640px){.cc-md .cc-emoji,.cc-md .cc-img{width:56px;height:56px}.cc-md .cc-emoji{font-size:24px}.cc-md .cc-title{font-size:13px}.cc-lg .cc-img{height:140px}.cc-lg .cc-emoji{height:100px;font-size:36px}}.event-row{display:flex;align-items:center;gap:8px;padding:6px 0}.event-row+.event-row{border-top:1px solid var(--border)}.event-row-cancelled,.event-row-cancelled .event-row-title{color:#ef4444}.event-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.event-row-title{font-size:14px;font-weight:700;color:var(--text);flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-row-badge-cancel{font-size:11px;color:#fff;background:#ef4444;border-radius:4px;padding:1px 6px;white-space:nowrap;font-weight:700}.event-row-date,.event-row-time{font-size:12px;color:var(--text-muted);white-space:nowrap}.event-row-likes{font-size:12px;color:#e74c3c;white-space:nowrap}.event-row-chats{font-size:12px;color:var(--accent);white-space:nowrap}.event-list{padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.event-list-title{font-size:14px;font-weight:700;color:var(--text-muted);margin:0 0 8px}.event-list-link{text-decoration:none;color:var(--text);display:block}.event-list-link:hover .event-row-title{color:var(--accent)}.event-list-static{cursor:default}.avatar-img{border-radius:50%;object-fit:cover}.avatar-letter{border-radius:50%;background:var(--accent);color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-link{text-decoration:none;color:inherit}.avatar-with-name{display:inline-flex;align-items:center;gap:6px}.avatar-name{font-size:13px;font-weight:700;color:var(--text)}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(253,246,255,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:64px;justify-content:space-between}.header-inner,.logo{display:flex;align-items:center}.logo{gap:10px;text-decoration:none}.logo-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff}.logo-text{font-size:13px;font-weight:700;letter-spacing:.15em;color:var(--text-muted)}.nav{display:flex;gap:24px}.nav a{color:var(--text-muted);text-decoration:none;font-size:14px;transition:color .2s}.nav a:hover{color:var(--text)}.header-auth{display:flex;align-items:center;gap:12px}.lang-switch{background:none;border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:12px;font-weight:700;color:var(--text-muted);cursor:pointer;position:relative;letter-spacing:.5px}.lang-switch:hover{color:var(--accent);border-color:var(--accent)}.lang-switch:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}.verified-badge{display:inline-block;width:16px;height:16px;margin-left:4px;vertical-align:middle;flex-shrink:0}.auth-tabs{gap:0;margin-bottom:16px;border-bottom:1px solid var(--border)}.auth-tab{border-bottom:2px solid transparent}.auth-tab.active{border-bottom-color:var(--accent)}.auth-modal-note{margin-bottom:12px;line-height:1.5}.auth-btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:20px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s}.auth-btn:hover{opacity:.85}.auth-btn-ghost{background:none;border:1px solid var(--border);border-radius:20px;padding:7px 16px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:border-color .2s}.auth-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.header-users-link{color:var(--text-muted);text-decoration:none;font-size:14px;font-weight:500;padding:4px 10px;border-radius:8px;transition:color .15s,background .15s}.header-users-link:hover{color:var(--text);background:var(--surface2)}.header-mobile-right{display:none;align-items:center;gap:4px}.hamburger{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text);padding:6px 8px;border-radius:8px;transition:background .2s;min-height:44px;display:inline-flex;align-items:center}.hamburger:hover{background:var(--surface2)}.header-mobile-menu{display:flex;flex-direction:column;background:rgba(253,246,255,.98);border-top:1px solid var(--border);padding:8px 24px 16px}.mobile-menu-link{display:block;padding:14px 0;font-size:15px;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border)}.mobile-menu-link:hover{color:var(--accent)}.mobile-menu-btn{display:block;width:100%;text-align:left;padding:14px 0;font-size:15px;color:var(--text);background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;font-family:inherit}.mobile-menu-btn:hover{color:var(--accent)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(253,246,255,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);justify-content:space-around;padding:6px 0 env(safe-area-inset-bottom,6px)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--text-muted);font-size:10px;padding:4px 12px;min-width:56px}.bottom-nav-item:active{color:var(--accent)}.bottom-nav-icon{font-size:20px;line-height:1}.bottom-nav-label{font-weight:600}@media (max-width:1024px){.mobile-bottom-nav{display:flex}}.footer{border-top:1px solid var(--border);padding:60px 24px}.footer-inner{max-width:1200px;margin:0 auto;text-align:center;display:flex;flex-direction:column;gap:8px}.footer-logo{font-size:13px;font-weight:700;letter-spacing:.15em;color:var(--text-muted)}.footer-note{font-size:14px;color:var(--text-muted)}.footer-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.footer-link{font-size:13px;color:var(--text-muted);text-decoration:none}.footer-link:hover{text-decoration:underline}.footer-copy{font-size:12px;color:rgba(100,60,140,.3);margin-top:8px}.modal-overlay{background:rgba(45,31,61,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.auth-modal{background:var(--surface);border-radius:var(--radius);padding:32px;width:100%;max-width:360px;position:relative;box-shadow:0 20px 60px rgba(45,31,61,.2)}.modal-close{top:12px;right:12px;background:none;font-size:18px;z-index:1;width:28px;height:28px}.modal-close:hover{color:var(--text);background:var(--surface2)}.auth-tabs{display:flex;gap:4px;margin-top:8px;margin-bottom:24px;background:var(--surface2);border-radius:10px;padding:4px}.auth-tab{flex:1 1;padding:8px;border:none;background:none;border-radius:8px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s}.auth-tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form-narrow{max-width:360px}.auth-modal-note{font-size:13px;color:var(--text-muted);margin-bottom:16px;line-height:1.6}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:13px;font-weight:600;color:var(--text-muted)}.auth-field input{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:16px;background:var(--bg);color:var(--text);outline:none;transition:border-color .2s}.auth-field input:focus{border-color:var(--accent)}.auth-error{font-size:13px;color:#e05;background:#fff0f3;padding:8px 12px;border-radius:8px}.auth-submit{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:10px;padding:12px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s}.auth-submit:hover:not(:disabled){opacity:.85}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.invite-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:24px}.invite-card{background:var(--surface);border-radius:var(--radius);padding:40px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(45,31,61,.12)}.invite-header{text-align:center;margin-bottom:32px}.invite-emoji{font-size:48px;display:block;margin-bottom:12px}.invite-title{font-size:22px;font-weight:800;margin-bottom:6px}.invite-agree-label{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text-muted);line-height:1.5;cursor:pointer}.invite-agree-label input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.invite-subtitle{font-size:14px;color:var(--text-muted)}.invite-form{display:flex;flex-direction:column;gap:16px}.invite-username-input{background:var(--surface2)!important;color:var(--accent)!important;font-weight:700!important;cursor:default!important}.invite-error-big,.invite-loading{color:var(--text-muted);text-align:center}.invite-error-big{font-size:15px;padding:16px}.profile-page{min-height:80vh;padding:40px 24px}.profile-inner{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:40px}.profile-hero{gap:20px}.profile-avatar,.profile-hero{display:flex;align-items:center}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:28px;font-weight:800;justify-content:center;flex-shrink:0}.profile-avatar-sm{width:40px;height:40px;font-size:18px}.profile-avatar-section{display:flex;flex-direction:column;align-items:center}.profile-avatar-input{display:none}.profile-avatar-edit{display:block;text-align:center;margin-top:6px;background:var(--accent);color:#fff;font-size:13px;font-weight:700;padding:6px 16px;border-radius:16px;border:none;cursor:pointer}.profile-avatar-edit:hover{opacity:.85}.avatar-editor-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.avatar-editor-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}.avatar-editor-content{position:relative;background:var(--surface);border-radius:16px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 32px rgba(0,0,0,.3)}.avatar-editor-canvas{border-radius:8px}.avatar-editor-slider{width:250px;accent-color:var(--accent)}.avatar-editor-actions{display:flex;gap:12px;width:100%}.avatar-editor-cancel{border:1px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-weight:600}.avatar-editor-cancel,.avatar-editor-save{flex:1 1;padding:10px;font-size:14px;cursor:pointer}.avatar-editor-save{border:none;border-radius:12px;background:var(--accent);color:#fff;font-weight:700}.avatar-editor-save:disabled{opacity:.5}.profile-name{font-size:24px;font-weight:800}.profile-joined{font-size:13px;color:var(--text-muted);margin-top:4px}.profile-section{background:var(--surface);border-radius:var(--radius);padding:24px;border:1px solid var(--border)}.profile-section-title{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}.profile-count{font-size:12px;background:var(--surface2);color:var(--text-muted);border-radius:20px;padding:2px 10px;font-weight:600}.profile-empty{font-size:14px;color:var(--text-muted)}.profile-list{list-style:none;display:flex;flex-direction:column;gap:8px}.profile-list-item{border-bottom:1px solid var(--border);padding-bottom:8px}.profile-list-item:last-child{border-bottom:none;padding-bottom:0}.profile-article-link{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-size:14px;font-weight:600;transition:color .2s}.profile-article-link:hover{color:var(--accent)}.profile-article-emoji{font-size:18px}.profile-comment-item{padding:12px 0;border-bottom:1px solid var(--border)}.profile-comment-item:last-child{border-bottom:none}.profile-comment-article{font-size:12px;color:var(--accent);text-decoration:none;font-weight:600;display:block;margin-bottom:4px}.profile-comment-article:hover{text-decoration:underline}.profile-comment-body{font-size:14px;color:var(--text);line-height:1.5}.profile-comment-date{font-size:11px;color:var(--text-muted);display:block;margin-top:4px}.profile-pw-form{display:flex;flex-direction:column;gap:14px}.profile-msg-ok{font-size:13px;color:#16a34a;background:#f0fdf4;padding:8px 12px;border-radius:8px}.invite-create-form{display:flex;flex-direction:column;gap:14px}.invite-create-row{display:flex;gap:12px;align-items:flex-end}.invite-field-name{flex:2 1}.invite-field-days{flex:1 1}.invite-days-select{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:15px;background:var(--bg);color:var(--text);outline:none;width:100%}.invite-result{margin-top:16px;padding:14px;background:var(--surface2);border-radius:10px}.invite-result-label{font-size:12px;color:var(--text-muted);margin-bottom:8px}.invite-result-url{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;color:var(--text);word-break:break-all}.invite-result-url span{flex:1 1}.invite-copy-btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.profile-logout{background:none;border:1px solid var(--border);border-radius:10px;padding:10px;font-size:14px;color:var(--text-muted);cursor:pointer;transition:all .2s;align-self:flex-start}.profile-logout:hover{border-color:#e05;color:#e05}.header-username{font-size:13px;font-weight:600;color:var(--accent);text-decoration:none}.header-username:hover{text-decoration:underline}.user-page{min-height:80vh;padding:40px 24px}.user-page-inner{max-width:720px;margin:0 auto}.follow-btn{padding:8px 22px;border-radius:100px;font-size:14px;font-family:var(--font);font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s;background:var(--accent);color:#fff;border:2px solid var(--accent);margin-top:8px;align-self:flex-start}.follow-btn.following{background:transparent;color:var(--accent);border-color:var(--accent)}.follow-btn:hover{opacity:.85}.follow-btn:disabled{opacity:.5;cursor:default}.users-list{list-style:none;display:flex;flex-direction:column;gap:8px}.users-list-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:12px;background:var(--surface);border:1px solid var(--border);text-decoration:none;color:var(--text);transition:background .15s,border-color .15s}.users-list-item:hover{background:var(--surface2);border-color:var(--accent)}.users-list-main{flex:1 1;min-width:0}.users-list-comment{font-size:12px;color:var(--text-muted);margin:4px 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:42px}.users-list-username{font-weight:600;font-size:15px;flex:1 1}.users-list-arrow{color:var(--text-muted);font-size:14px;flex-shrink:0}.usersearch-wrap{position:relative}.usersearch-icon{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .15s;line-height:1}.usersearch-icon:hover{background:var(--surface2)}.usersearch-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 32px rgba(140,80,200,.12);width:240px;padding:12px;z-index:200}.usersearch-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:16px;font-family:var(--font);background:var(--bg);color:var(--text);outline:none}.usersearch-input:focus{border-color:var(--accent)}.usersearch-results{list-style:none;margin-top:8px}.usersearch-result-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:14px;font-family:var(--font);color:var(--text);text-align:left;transition:background .15s}.usersearch-result-item:hover{background:var(--surface2)}.usersearch-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.usersearch-empty{color:var(--text-muted);font-size:13px;margin-top:8px;text-align:center}.hero{position:relative;overflow:hidden;padding:56px 24px 40px;text-align:center}.hero-inner{position:relative;z-index:1;max-width:800px;margin:0 auto}.hero-eyebrow{font-size:13px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;margin-bottom:20px;font-weight:600}.hero-title{font-size:clamp(56px,10vw,120px);font-weight:900;line-height:1;letter-spacing:-.03em;background:linear-gradient(135deg,#7c3aed,#db2777 60%,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px}.hero-sub{font-size:18px;color:var(--text-muted);max-width:480px;margin:0 auto}.hero-bg{inset:0;z-index:0;pointer-events:none}.blob,.hero-bg{position:absolute}.blob{border-radius:50%;filter:blur(80px);opacity:.25}.blob1{width:500px;height:500px;background:#d8b4fe;top:-150px;left:-100px}.blob2{width:400px;height:400px;background:#fbcfe8;top:-80px;right:-80px}.blob3{width:300px;height:300px;background:#fde68a;bottom:-100px;left:50%;transform:translateX(-50%)}.content-section{padding:48px 24px 80px}.section-inner{max-width:1200px;margin:0 auto}.section-title{font-size:28px;font-weight:800;margin-bottom:32px;letter-spacing:-.02em}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}.filter-btn{padding:6px 16px;border-radius:100px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;transition:all .2s;font-family:var(--font)}.filter-btn:hover{border-color:rgba(255,255,255,.2);color:var(--text)}.filter-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;color:#fff}.filter-btn-liked{border-color:#f472b6;color:#f472b6}.filter-btn-liked.active{background:linear-gradient(135deg,#f472b6,#fb923c)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:20px;gap:20px}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px 24px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-accent);opacity:.9}.card:hover{border-color:var(--card-accent);transform:translateY(-3px);box-shadow:0 8px 30px rgba(176,110,243,.12)}.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:max(40px,10vh) 16px 40px}.modal{background:var(--surface);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:40px;max-width:560px;width:100%;max-height:80vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:16px;right:16px;background:var(--surface2);border:none;color:var(--text-muted);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:rgba(255,255,255,.1)}.modal-emoji{font-size:48px;margin-bottom:16px}.modal-title{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:24px}.modal-body{display:flex;flex-direction:column;gap:14px}.modal-heading{font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:8px}.modal-p{font-size:15px;color:var(--text-muted);line-height:1.8}.modal-list{padding-left:20px;display:flex;flex-direction:column;gap:8px}.modal-list li{font-size:15px;color:var(--text-muted);line-height:1.7}.modal-link{display:inline-flex;margin-top:24px;font-size:14px;font-weight:600;color:var(--accent);text-decoration:none}.modal-link:hover{opacity:.7}.empty{text-align:center;color:var(--text-muted);padding:80px 0;line-height:2;font-size:15px}.empty code{background:var(--surface2);padding:2px 8px;border-radius:6px;font-size:13px;color:var(--accent)}.item-page{padding:60px 24px 100px;min-height:80vh}.item-page-inner{max-width:760px;margin:0 auto}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;margin-bottom:48px;padding:8px 14px;border-radius:100px;border:1.5px solid var(--border);background:var(--surface);transition:border-color .2s,color .2s}.back-link:hover{border-color:var(--accent);color:var(--accent)}.item-hero{padding-bottom:40px;border-bottom:1px solid var(--border);margin-bottom:48px;position:relative}.item-hero-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.item-emoji-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0}.item-emoji{font-size:32px;line-height:1}.item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.item-meta-row{display:flex;align-items:center;gap:8px}.item-tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 12px;border-radius:100px;border:1px solid}.item-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.item-author-link-row{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.item-author-link-row:hover .item-author-name{color:var(--accent)}.item-author-name{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap}.item-author-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;text-decoration:none;flex-shrink:0}.item-meta-sub{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.item-date{font-size:13px;color:var(--text-muted)}.item-meta-muted{font-size:12px;color:var(--text-muted)}.item-title{font-size:clamp(36px,6vw,60px);font-weight:900;letter-spacing:-.03em;line-height:1.1;margin-bottom:20px}.item-lead{font-size:18px;color:var(--text-muted);line-height:1.7}.item-body{display:flex;flex-direction:column;gap:20px}.item-heading{font-size:17px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-top:40px;padding-top:32px;border-top:2px solid var(--border);scroll-margin-top:80px}.item-heading:first-child{border-top:none;padding-top:0;margin-top:0}.item-heading-sub{font-size:14px;border-top:1px dashed var(--border);color:var(--text);margin-top:28px;padding-top:24px}.item-toc{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:24px}.item-toc-title{font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}.item-toc-list{list-style:none;counter-reset:toc;display:flex;flex-direction:column;gap:6px;padding:0}.item-toc-list li{counter-increment:toc}.item-toc-list li:before{content:counter(toc) ".";color:var(--accent);font-size:12px;font-weight:600;margin-right:8px;min-width:20px;display:inline-block}.item-toc-list a{color:var(--text);text-decoration:none;font-size:14px;line-height:1.6;transition:color .15s}.item-toc-list a:hover{color:var(--accent)}.item-toc-sub{padding-left:20px}.item-toc-sub:before{color:var(--text-muted)!important;font-size:11px!important}.item-toc-sub a{font-size:13px!important;color:var(--text-muted)!important}.item-toc-sub a:hover{color:var(--accent)!important}.scroll-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--accent);font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 2px 12px rgba(0,0,0,.08);transition:opacity .2s,transform .2s;z-index:90}.scroll-to-top:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}.item-p{font-size:15.5px;line-height:2;color:var(--text-muted);margin-bottom:4px}.item-eyecatch{width:100%;height:360px;object-fit:cover;border-radius:var(--radius);display:block;margin-bottom:48px}.item-figure{margin:16px 0}.item-image{width:100%;border-radius:var(--radius);display:block}.item-caption{font-size:13px;color:var(--text-muted);margin-top:6px;text-align:center}.item-list{padding-left:20px;margin:8px 0}.item-list li{font-size:15px;color:var(--text-muted);line-height:1.8}.adsense-wrap{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.item-stats{display:flex;align-items:center;gap:12px;margin-top:24px}.item-stat-like,.item-stat-views{font-size:13px;color:var(--text-muted)}.item-stat-like{display:inline-flex;align-items:center;gap:5px;font-family:var(--font);background:var(--surface);border:1.5px solid var(--border);border-radius:100px;padding:4px 14px;cursor:pointer;transition:border-color .2s,color .2s,background .2s}.item-stat-like.liked,.item-stat-like:hover{border-color:#f43f5e;color:#f43f5e}.item-stat-like.liked{background:rgba(244,63,94,.06)}.item-link-btn{display:inline-flex;margin-top:40px;padding:12px 24px;background:var(--accent);color:#fff;border-radius:100px;text-decoration:none;font-size:14px;font-weight:600;transition:opacity .2s}.item-link-btn:hover{opacity:.8}.pf-wrap{background:var(--surface2);border:1.5px solid var(--border);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:20px}.pf-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:12px}.pf-sep{color:var(--text-muted);margin:0 2px}.pf-crumb{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:4px;font-family:var(--font);transition:background .15s}.pf-crumb:hover{background:rgba(124,106,247,.15)}.pf-step{font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--accent);text-transform:uppercase}.pf-question{font-size:20px;font-weight:800;letter-spacing:-.01em;line-height:1.3}.pf-options{display:flex;flex-direction:column;gap:10px}.pf-option{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;font-family:var(--font);padding:14px 18px;text-align:left;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.pf-option:hover{border-color:var(--accent);background:rgba(176,110,243,.06);box-shadow:0 4px 12px rgba(176,110,243,.1)}.pf-result{background:var(--lv-bg);border:1px solid var(--lv-color);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:16px}.pf-result-title{font-size:20px;font-weight:800;color:var(--lv-color)}.pf-result-action{font-size:14px;color:var(--text-muted)}.pf-result-action strong{color:var(--text)}.pf-diseases{gap:10px}.pf-disease,.pf-diseases{display:flex;flex-direction:column}.pf-disease{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;gap:6px}.pf-disease-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.pf-disease-name{font-size:15px;font-weight:700}.pf-disease-prob{font-size:12px;font-weight:600}.pf-disease-desc{line-height:1.7}.pf-disease-desc,.pf-reset{font-size:13px;color:var(--text-muted)}.pf-reset{background:none;border:1px solid var(--border);border-radius:100px;font-family:var(--font);padding:8px 20px;cursor:pointer;align-self:flex-start;transition:border-color .2s,color .2s}.pf-reset:hover{border-color:rgba(255,255,255,.3);color:var(--text)}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.section-header-row .section-title{margin-bottom:0}.content-links-grouped{display:flex;flex-direction:column;gap:28px}.content-links-category-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 12px;display:flex;align-items:center;gap:6px}.content-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:10px;gap:10px;margin:16px 0}.content-cards.cards-sm{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.content-cards.cards-lg{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.content-card{background:var(--surface);border-radius:12px;padding:14px 12px;border:1px solid var(--border);border-top:3px solid var(--card-color,var(--accent))}.content-card-emoji{font-size:22px;display:block;margin-bottom:6px;line-height:1}.content-card-title{font-weight:700;font-size:13px;margin-bottom:4px;color:var(--text);line-height:1.3}.content-card-desc{font-size:12px;color:var(--text-muted);line-height:1.5}.content-card-sub{font-size:11px;color:var(--card-color,var(--accent));font-weight:600;margin-top:6px}.content-card.has-icon{background:var(--card-color,var(--accent));border-color:transparent}.content-card.has-icon .content-card-title{color:#fff}.content-card.has-icon .content-card-desc{color:rgba(255,255,255,.78)}.content-card.has-icon .content-card-sub{color:rgba(255,255,255,.6)}.content-card-icon{width:32px;height:32px;display:block;margin-bottom:8px;object-fit:contain}.content-timeline{margin:16px 0}.content-timeline-item{display:grid;grid-template-columns:72px 1fr;grid-gap:16px;gap:16px;padding-bottom:14px;position:relative}.content-timeline-item:not(:last-child):after{content:"";position:absolute;left:78px;top:20px;bottom:0;width:2px;background:var(--border)}.content-timeline-year{font-size:11px;font-weight:700;color:var(--accent);text-align:right;padding-top:3px;line-height:1.3;position:relative}.content-timeline-year:after{content:"";position:absolute;right:-10px;top:5px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--bg)}.content-timeline-text{font-size:13px;color:var(--text);line-height:1.6;padding-top:2px}.item-author-link{color:inherit;text-decoration:none;border-bottom:1px dotted;transition:color .15s}.item-author-link:hover{color:var(--accent)}.site-stats{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px 0}.site-stats-item{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;min-width:100px;flex:1 1}.site-stats-emoji{font-size:24px}.site-stats-value{font-size:28px;font-weight:800;color:var(--accent);line-height:1.2}.site-stats-label{font-size:12px;color:var(--text-muted);margin-bottom:8px}.site-stats-chart{width:100%;height:40px;display:block}.game-page{padding:8px 16px 60px;max-width:520px;margin:0 auto}.game-page-inner{width:100%}.game-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 0 4px}.game-title{font-size:18px;font-weight:800;margin:0;white-space:nowrap}.game-body{margin-bottom:16px}.quiz-wrap{margin:16px 0}.quiz-progress{font-size:12px;color:var(--text-muted);margin-bottom:8px}.quiz-question{font-size:16px;font-weight:700;margin-bottom:12px}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{padding:12px 16px;border:1.5px solid var(--border);border-radius:10px;background:var(--surface);font-size:14px;text-align:left;cursor:pointer;transition:border-color .15s}.quiz-option:hover:not(:disabled){border-color:var(--accent)}.quiz-option:disabled{cursor:default}.quiz-correct{border-color:#10b981;background:#ecfdf5}.quiz-wrong{border-color:#ef4444;background:#fef2f2}.quiz-feedback{margin-top:12px}.quiz-explanation{font-size:13px;color:var(--text-muted);margin-bottom:8px}.quiz-next-btn{padding:8px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-weight:700;cursor:pointer}.quiz-result{text-align:center;padding:24px}.quiz-result-score{font-size:36px;font-weight:800;color:var(--accent)}.quiz-result-rate{font-size:16px;color:var(--text-muted);margin:8px 0 16px}.quiz-retry-btn{padding:10px 24px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-weight:700;cursor:pointer}.vote-inline-btn{border:1.5px solid var(--border);background:var(--surface);border-radius:99px;padding:4px 14px;font-size:13px;cursor:pointer;color:var(--text-muted);transition:all .15s;white-space:nowrap}.vote-inline-btn:hover,.vote-inline-voted{border-color:var(--accent);color:var(--accent)}.vote-inline-voted{background:color-mix(in srgb,var(--accent) 10%,var(--surface));font-weight:600}.vote-inline-btn:disabled{opacity:.5;cursor:default}.vote-inline-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:4px 0}.vote-inline-users,.vote-result-users{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.vote-user-chip{gap:3px;font-size:12px}.vote-user-chip,.vote-user-icon{display:inline-flex;align-items:center;color:var(--text-muted)}.vote-user-icon{background:var(--surface2,#f3eaff);font-size:10px;font-weight:700;justify-content:center;flex-shrink:0}.vote-user-icon,.vote-user-icon-img{width:20px;height:20px;border-radius:50%}.vote-user-icon-img{object-fit:cover}.vote-results{margin:16px 0;display:flex;flex-direction:column;gap:8px}.vote-result-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.vote-result-rank{font-size:18px;font-weight:800;color:var(--accent);min-width:24px;text-align:center;flex-shrink:0}.vote-result-label{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;flex-shrink:0}.vote-result-users{margin-left:auto}.vote-no-votes{font-size:13px;color:var(--text-muted);text-align:center;padding:16px}.story-branch{margin:16px 0}.story-question{font-size:17px;font-weight:700;color:var(--text);margin-bottom:12px;text-align:center}.story-options{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px;margin-bottom:16px}.story-option{padding:14px 12px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;font-size:14px;font-weight:600;color:var(--text);transition:all .15s;text-align:center}.story-option-active,.story-option:hover{border-color:var(--accent);color:var(--accent)}.story-option-active{background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.story-content{animation:story-fade-in .4s ease-out}@keyframes story-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.story-spot-header{display:flex;gap:14px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;align-items:flex-start}.story-spot-thumb{width:min(400px,45%);aspect-ratio:4/3;border-radius:10px;object-fit:cover;flex-shrink:0}.story-spot-info{flex:1 1;min-width:0;padding-top:4px}.story-spot-name{font-size:16px;font-weight:700;color:var(--text)}.story-spot-detail{font-size:12px;color:var(--text-muted);margin-top:6px;line-height:1.6}@media (max-width:480px){.story-spot-header{flex-direction:column}.story-spot-thumb{width:100%}}.story-info{font-size:13px;color:var(--text-muted);margin-top:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}@media (max-width:480px){.story-options{grid-template-columns:1fr}}.sudoku-wrap{max-width:560px;margin:0 auto;padding-bottom:100px}.sudoku-timer{text-align:center;font-size:22px;font-weight:700;letter-spacing:2px;margin-bottom:12px;color:var(--text)}.sudoku-ranking{margin-top:24px}.sudoku-ranking-title{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-muted)}.sudoku-ranking-table{width:100%;border-collapse:collapse;font-size:14px}.sudoku-ranking-table td{padding:6px 8px;border-bottom:1px solid var(--border)}.sudoku-rank-num{color:var(--text-muted);width:32px}.sudoku-rank-name{font-weight:600}.sudoku-rank-time{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.sudoku-rank-top td{color:var(--accent)}.sudoku-tabs{display:flex;gap:8px;margin-bottom:16px}.sudoku-tab{flex:1 1;padding:6px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px}.sudoku-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sudoku-clear{text-align:center;font-size:20px;font-weight:700;color:var(--accent);margin-bottom:12px}.sudoku-grid{width:100%;aspect-ratio:1;display:flex;flex-direction:column;border:2px solid var(--text);border-radius:4px;margin-bottom:20px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sudoku-row{display:flex;flex:1 1;border-bottom:1px solid var(--border)}.sudoku-row:last-child{border-bottom:none}.sudoku-row.box-bottom{border-bottom:2px solid var(--text)}.sudoku-cell{flex:1 1;min-width:0;display:flex;align-items:center;justify-content:center;font-size:clamp(16px,5.5vw,28px);font-weight:500;border-right:1px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text);transition:background .1s}.sudoku-cell:last-child{border-right:none}.sudoku-cell.box-right{border-right:2px solid var(--text)}.sudoku-cell.fixed{font-weight:700;cursor:default}.sudoku-cell.selected{background:var(--accent)!important;color:#fff!important}.sudoku-cell.related{background:color-mix(in srgb,var(--accent) 12%,var(--surface))}.sudoku-cell.same-num{background:color-mix(in srgb,var(--accent) 25%,var(--surface))}.sudoku-cell.error{color:#ef4444}.sudoku-numpad{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:6px;gap:6px;margin-bottom:12px}.sudoku-num{padding:14px 0;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:20px;cursor:pointer;transition:background .1s}.sudoku-num:hover{background:color-mix(in srgb,var(--accent) 15%,var(--surface))}.sudoku-erase{color:#ef4444}.sudoku-candidates{line-height:1.1;letter-spacing:.5px;word-break:break-all;color:var(--text-muted)}.sudoku-candidates-sm{font-size:clamp(8px,2.5vw,13px)}.sudoku-candidates-xs{font-size:clamp(6px,1.8vw,9px)}.sudoku-btns{display:flex;gap:8px;margin-top:12px}.sudoku-btn{flex:1 1;padding:10px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:14px;cursor:pointer}.sudoku-btn.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.p2048-wrap{max-width:420px;margin:0 auto;padding-bottom:40px;touch-action:none}.p2048-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.p2048-logo{font-size:48px;font-weight:900;color:#776e65;line-height:1}.p2048-scores{display:flex;gap:8px}.p2048-score-box{background:#bbada0;border-radius:6px;padding:8px 16px;text-align:center;min-width:72px;position:relative}.p2048-score-label{font-size:11px;font-weight:700;color:#eee4da;text-transform:uppercase}.p2048-score-val{font-size:20px;font-weight:700;color:#fff;position:relative}.p2048-score-add{position:absolute;top:-12px;right:-8px;font-size:14px;font-weight:700;color:#776e65;animation:p2048-score-pop .6s ease-out forwards;pointer-events:none}@keyframes p2048-score-pop{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-24px)}}.p2048-hint{font-size:13px;color:var(--text-muted);margin-bottom:12px}.p2048-board{position:relative;background:#bbada0;border-radius:8px;aspect-ratio:1;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none}.p2048-bg-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);position:absolute;inset:0}.p2048-bg-cell{background:rgba(238,228,218,.35);border-radius:6px}.p2048-tile-layer{position:absolute;inset:0}.p2048-tile{position:absolute;display:flex;align-items:center;justify-content:center;border-radius:6px;font-weight:700;z-index:1}.p2048-tile-merged{animation:p2048-merge .15s ease-out;z-index:2}.p2048-tile-ghost{z-index:0}@keyframes p2048-merge{0%{scale:1}50%{scale:1.15}to{scale:1}}.p2048-overlay{position:absolute;inset:0;background:rgba(238,228,218,.73);border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:10;animation:p2048-fade-in .3s ease-out}@keyframes p2048-fade-in{0%{opacity:0}to{opacity:1}}.p2048-overlay-inner{text-align:center}.p2048-overlay-msg{font-size:32px;font-weight:900;color:#776e65;margin-bottom:8px}.p2048-overlay-score{font-size:18px;color:#776e65;margin-bottom:16px}.p2048-overlay-btns{display:flex;gap:8px;justify-content:center}.p2048-dpad{flex-direction:column;align-items:center;margin:12px 0 4px}.p2048-dpad,.p2048-dpad-row{display:flex;gap:4px}.p2048-dpad-btn{width:52px;height:44px;border:none;border-radius:8px;background:#bbada0;color:#f9f6f2;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s}.p2048-dpad-btn:hover{background:#a89a8c}.p2048-dpad-btn:active{background:#978a7c}.rap-wrap{max-width:560px;margin:0 auto;padding-bottom:60px}.rap-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.rap-title-logo{font-size:32px;font-weight:900;letter-spacing:2px;background:linear-gradient(135deg,#ff6b6b,#ffa502,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rap-status{display:flex;gap:12px;align-items:center}.rap-round{font-size:14px;font-weight:700;color:var(--text-muted)}.rap-pts{font-size:18px;font-weight:900;color:#ff6b6b}.rap-intro{text-align:center;padding:24px 0}.rap-intro-text{font-size:15px;color:var(--text);margin-bottom:20px;line-height:1.6}.rap-score-guide{display:inline-flex;flex-direction:column;gap:6px;text-align:left;font-size:13px;color:var(--text-muted);margin-bottom:24px}.rap-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.rap-dot-3{background:#ff6b6b}.rap-dot-2{background:#ffa502}.rap-dot-1{background:#a0a0a0}.rap-dot-0{background:#555}.rap-start-btn{padding:14px 48px;border:none;border-radius:12px;font-size:18px;font-weight:800;background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;cursor:pointer;letter-spacing:1px;transition:transform .1s}.rap-start-btn:active{transform:scale(.96)}.rap-battle{display:flex;flex-direction:column;gap:16px}.rap-ai-section,.rap-user-section{display:flex;flex-direction:column;gap:8px}.rap-speaker{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.rap-bubble{padding:14px 16px;border-radius:12px;font-size:14px;line-height:1.7;white-space:pre-wrap}.rap-ai-bubble{background:linear-gradient(135deg,#2d1b69,#1a1a2e);color:#e0d0ff;border:1px solid #3d2b79}.rap-typing{font-size:24px;text-align:center;animation:rap-blink .6s infinite}@keyframes rap-blink{0%,to{opacity:1}50%{opacity:.3}}.rap-options{display:flex;flex-direction:column;gap:8px}.rap-option{text-align:left;padding:12px 14px;border-radius:10px;border:2px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;line-height:1.6;transition:border-color .15s,background .15s,opacity .2s}.rap-option:hover:not(:disabled){border-color:#ff6b6b;background:color-mix(in srgb,#ff6b6b 8%,var(--surface))}.rap-option-picked{border-color:#ff6b6b!important;background:color-mix(in srgb,#ff6b6b 12%,var(--surface))!important}.rap-option-dim{opacity:.45}.rap-option-text{white-space:pre-wrap}.rap-option-score{margin-top:8px;font-size:13px;font-weight:700;padding-top:8px;border-top:1px solid var(--border)}.rap-score-fire{color:#ff6b6b}.rap-score-nice{color:#ffa502}.rap-score-meh{color:#a0a0a0}.rap-score-weak{color:#555}.rap-next-wrap{text-align:center;padding:8px 0}.rap-picked-label{font-size:20px;font-weight:900;margin-bottom:12px}.rap-result{text-align:center;padding:24px 0}.rap-result-title{font-size:28px;font-weight:900;color:var(--text);margin-bottom:8px}.rap-result-score{font-size:48px;font-weight:900;letter-spacing:2px;background:linear-gradient(135deg,#ff6b6b,#ffa502);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.rap-result-rating{font-size:22px;font-weight:800;color:#ff6b6b;margin-bottom:4px}.rap-result-msg{font-size:15px;color:var(--text-muted);margin-bottom:20px}.rap-result-history{display:flex;justify-content:center;gap:12px;margin-bottom:24px}.rap-result-round{display:flex;flex-direction:column;align-items:center;gap:4px}.rap-result-round-num{font-size:11px;color:var(--text-muted);font-weight:700}.rap-result-round-score{font-size:16px;font-weight:800}.pocoa-wrap{max-width:520px;margin:0 auto;padding-bottom:60px}.pocoa-header{margin-bottom:12px}.pocoa-title-logo{font-size:24px;font-weight:800}.pocoa-stats{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.pocoa-stat{flex:1 1;min-width:70px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 10px;text-align:center}.pocoa-stat-label{display:block;font-size:10px;color:var(--text-muted);font-weight:700;text-transform:uppercase}.pocoa-stat-val{font-size:18px;font-weight:800;color:var(--text)}.pocoa-coins{color:#f59e0b}.pocoa-total{color:var(--accent)}.pocoa-income-flash{text-align:center;font-size:14px;font-weight:700;color:#22c55e;margin-bottom:8px;animation:pocoa-flash 1.5s ease-out forwards}@keyframes pocoa-flash{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.pocoa-grid{margin-bottom:16px}.pocoa-row{display:flex;gap:4px;margin-bottom:4px}.pocoa-cell{flex:1 1;aspect-ratio:1;border:2px solid var(--border);border-radius:8px;background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,background .15s;padding:2px}.pocoa-cell-filled{cursor:default}.pocoa-cell-empty:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.pocoa-cell-img{width:clamp(28px,7vw,44px);height:clamp(28px,7vw,44px)}.pocoa-cell-income{font-size:11px;font-weight:700}.pocoa-shop-label{font-size:13px;color:var(--text-muted);font-weight:600;margin-bottom:8px}.pocoa-shop{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:6px;gap:6px;margin-bottom:8px}.pocoa-shop-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;border:2px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;transition:border-color .15s}.pocoa-shop-item:hover:not(:disabled){border-color:var(--accent)}.pocoa-shop-selected{border-width:3px;background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.pocoa-shop-disabled{opacity:.4;cursor:not-allowed}.pocoa-shop-img{width:36px;height:36px}.pocoa-shop-name{font-size:12px;font-weight:700;color:var(--text)}.pocoa-shop-cost{font-size:11px;font-weight:700;color:#f59e0b}.pocoa-shop-desc{font-size:10px;color:var(--text-muted);text-align:center;line-height:1.3}.pocoa-result{text-align:center;padding:24px 0}.pocoa-result-title{font-size:28px;font-weight:900;margin-bottom:8px}.pocoa-result-score{font-size:56px;font-weight:900;color:#f59e0b;margin-bottom:4px}.pocoa-result-sub{font-size:14px;color:var(--text-muted);margin-bottom:4px}.pocoa-result-combos{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:12px}.pocoa-result-detail{font-size:13px;color:var(--text-muted);margin-bottom:20px}.pocoa-cell-glow{animation:pocoa-glow 1.5s ease-in-out infinite;box-shadow:0 0 8px 2px rgba(255,215,0,.6)}@keyframes pocoa-glow{0%,to{box-shadow:0 0 8px 2px rgba(255,215,0,.4)}50%{box-shadow:0 0 16px 6px rgba(255,215,0,.8)}}.pocoa-active-combos{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.pocoa-combo-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;background:linear-gradient(135deg,#fff8e1,#ffe082);color:#6d4c00;border:1px solid #ffc107}.pocoa-combo-glow{animation:pocoa-badge-glow 1.2s ease-in-out infinite}@keyframes pocoa-badge-glow{0%,to{box-shadow:0 0 4px rgba(255,193,7,.3)}50%{box-shadow:0 0 12px rgba(255,193,7,.7)}}.pocoa-combo-guide{margin:12px 0;font-size:13px}.pocoa-combo-guide summary{cursor:pointer;font-weight:700;color:var(--text-muted);padding:6px 0}.pocoa-combo-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.pocoa-combo-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-size:12px;transition:background .2s,border-color .2s}.pocoa-combo-active{background:linear-gradient(135deg,#fff8e1,#fffde7);border-color:#ffc107;box-shadow:0 0 8px rgba(255,193,7,.3)}.pocoa-combo-emoji{font-size:16px}.pocoa-combo-name{font-weight:700;min-width:70px}.pocoa-combo-bonus{font-weight:800;color:#f59e0b;min-width:32px}.pocoa-combo-desc{color:var(--text-muted)}.pocoa-combo-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;background:rgba(0,0,0,.85);color:#ffd54f;padding:20px 32px;border-radius:16px;text-align:center;animation:pocoa-combo-pop 1.5s ease-out forwards;pointer-events:none}.pocoa-combo-popup-emoji{font-size:40px;display:block;margin-bottom:8px}.pocoa-combo-popup-name{font-size:24px;font-weight:900;display:block}.pocoa-combo-popup-bonus{font-size:18px;font-weight:700;color:#fff;display:block;margin-top:4px}@keyframes pocoa-combo-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-60%) scale(1)}}.pocoa-combo-reveal{text-align:center;padding:24px 0}.pocoa-combo-reveal-title{font-size:24px;font-weight:900;margin-bottom:16px}.pocoa-combo-reveal-item{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px;font-size:18px;animation:pocoa-combo-pop 1s ease-out both}.pocoa-combo-reveal-emoji{font-size:28px}.pocoa-combo-reveal-name{font-weight:800}.pocoa-combo-reveal-bonus{font-weight:800;color:#f59e0b}.pocoa-combo-reveal-total{font-size:20px;font-weight:900;color:var(--accent);margin-top:16px}.p2-wrap{max-width:520px;margin:0 auto;padding-bottom:60px}.p2-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.p2-title{font-size:24px;font-weight:800}.p2-stats{display:flex;gap:12px;font-size:13px;color:var(--text-muted)}.p2-stat b{color:var(--text)}.p2-hint{font-size:13px;color:var(--text-muted)}.p2-grid,.p2-hint{margin-bottom:12px}.p2-row{display:flex;gap:3px;margin-bottom:3px}.p2-cell{flex:1 1;aspect-ratio:1;border:2px solid var(--border);border-radius:6px;background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0;position:relative}.p2-cell-filled{cursor:default}.p2-cell-empty:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.p2-cell-terrain{font-size:clamp(16px,4vw,24px)}.p2-cell-monster{width:clamp(24px,6vw,38px);height:clamp(24px,6vw,38px)}.p2-cell-discovered{border-color:#ffd54f!important;background:linear-gradient(135deg,#fffde7,#fff8e1)!important;animation:p2-discover .5s ease-out}@keyframes p2-discover{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.p2-picker{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.p2-picker-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;border:2px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;transition:border-color .15s;flex:1 1;min-width:60px}.p2-picker-btn:hover{border-color:var(--accent)}.p2-picker-selected{border-width:3px}.p2-picker-emoji{font-size:22px}.p2-picker-name{font-size:10px;font-weight:700;color:var(--text-muted)}.p2-recipes{margin-top:16px}.p2-recipes-title{font-size:14px;font-weight:800;margin-bottom:8px}.p2-recipe{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;border:1px solid var(--border);margin-bottom:4px;background:var(--surface);transition:all .2s}.p2-recipe-found{background:linear-gradient(135deg,#fffde7,#fff8e1);border-color:#ffd54f}.p2-recipe-img-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center}.p2-recipe-img,.p2-recipe-img-wrap{width:36px;height:36px}.p2-recipe-unknown{font-size:24px;color:var(--text-muted);font-weight:800}.p2-recipe-info{flex:1 1;min-width:0}.p2-recipe-name{display:block;font-size:13px;font-weight:700}.p2-recipe-hint{display:block;font-size:11px;color:var(--text-muted)}.p2-recipe-pts{font-size:11px;font-weight:700;color:#f59e0b}.p2-recipe-check{color:#22c55e;font-size:18px;font-weight:900}.p2-result{text-align:center;padding:24px 0}.p2-result-title{font-size:28px;font-weight:900;margin-bottom:8px}.p2-result-score{font-size:56px;font-weight:900;color:#f59e0b;margin-bottom:4px}.p2-result-sub{font-size:14px;color:var(--text-muted);margin-bottom:12px}.p2-result-monsters{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:16px}.p2-result-monster{width:40px;height:40px}.p2-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;background:rgba(0,0,0,.85);color:#ffd54f;padding:24px 36px;border-radius:16px;text-align:center;animation:p2-pop 2s ease-out forwards;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.p2-popup-img{width:64px;height:64px}.p2-popup-name{font-size:22px;font-weight:900}.p2-popup-label{font-size:16px;color:#fff}.pq-wrap{max-width:480px;margin:0 auto;padding-bottom:60px;font-family:Courier New,monospace}.pq-title-screen{text-align:center;padding:40px 0;background:linear-gradient(180deg,#1a237e,#311b92 50%,#4a148c);border-radius:12px;color:#fff}.pq-logo{font-size:48px;font-weight:900;letter-spacing:4px;color:#ffd54f;text-shadow:3px 3px 0 #bf360c,-1px -1px 0 #ff6f00}.pq-logo-sub{font-size:14px;color:#b39ddb;margin:4px 0 20px}.pq-title-img{width:80px;height:80px;margin-bottom:24px;filter:drop-shadow(0 0 12px rgba(255,213,79,.5))}.pq-btn{display:block;width:100%;padding:10px 16px;margin:4px 0;border:2px solid #ffd54f;border-radius:6px;background:#1a1a2e;color:#ffd54f;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s}.pq-btn:hover{background:#2a2a4e}.pq-btn:disabled{opacity:.4;cursor:not-allowed}.pq-btn-start{width:auto;display:inline-block;padding:12px 32px;font-size:18px;text-align:center;background:#4a148c;border-color:#ffd54f}.pq-btn-advance{border-color:#4caf50;color:#4caf50}.pq-btn-back{border-color:#9e9e9e;color:#9e9e9e}.pq-status-bar{gap:12px;padding:8px 12px;background:#0d0d1a;color:#ffd54f;border:2px solid #ffd54f;border-radius:6px;font-size:13px;font-weight:700}.pq-map,.pq-status-bar{display:flex;margin-bottom:12px}.pq-map{flex-direction:column;gap:4px}.pq-area{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#1a1a2e;border:2px solid #333;border-radius:6px;transition:all .2s}.pq-area-current{border-color:#ffd54f;background:#2a2a4e}.pq-area-done{opacity:.5}.pq-area-locked{opacity:.3}.pq-area-icon{font-size:24px;width:32px;text-align:center}.pq-area-name{font-size:14px;font-weight:700;color:#fff}.pq-area-desc{font-size:11px;color:#9e9e9e}.pq-msg-box{padding:10px 14px;background:#0d0d1a;border:2px solid #ffd54f;border-radius:6px;color:#fff;font-size:13px;line-height:1.6;margin:8px 0;min-height:48px;white-space:pre-wrap}.pq-battle{background:linear-gradient(180deg,#1b5e20,#2e7d32 40%,#1a1a2e 60%);border-radius:12px;padding:16px}.pq-enemy-area{text-align:center;padding:12px 0}.pq-enemy-img{width:80px;height:80px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));animation:pq-enemy-idle 2s ease-in-out infinite}@keyframes pq-enemy-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.pq-enemy-name{font-size:16px;font-weight:800;color:#fff;margin-top:8px}.pq-enemy-hp-bar{width:60%;margin:6px auto;height:8px;background:#333;border-radius:4px;overflow:hidden}.pq-hp-fill{height:100%;background:#4caf50;border-radius:4px;transition:width .3s}.pq-enemy-hp-text{font-size:12px;color:#aaa}.pq-player-status{padding:6px 12px;background:#0d0d1a;border:2px solid #ffd54f;border-radius:6px;color:#ffd54f;font-size:13px;font-weight:700;margin:8px 0}.pq-battle-menu{display:flex;flex-direction:column;gap:2px}.pq-levelup{text-align:center;padding:30px 16px;background:linear-gradient(180deg,#1a237e,#311b92);border-radius:12px;color:#fff}.pq-levelup-title{font-size:28px;font-weight:900;color:#ffd54f;margin-bottom:12px}.pq-levelup-lv{font-size:36px;font-weight:900;color:#fff}.pq-levelup-stats{font-size:14px;color:#b39ddb;margin:8px 0}.pq-levelup-spell{font-size:16px;font-weight:700;color:#ffd54f;margin:8px 0}.pq-gameover{text-align:center;padding:40px 16px;background:#1a1a1a;border-radius:12px;color:#fff}.pq-gameover-title{font-size:32px;font-weight:900;color:#f44336;margin-bottom:12px}.pq-gameover-msg{font-size:15px;color:#999;margin-bottom:20px}.pq-clear{text-align:center;padding:40px 16px;background:linear-gradient(180deg,#1a237e,#0d47a1);border-radius:12px;color:#fff}.pq-clear-title{font-size:32px;font-weight:900;color:#ffd54f;margin-bottom:8px}.pq-clear-msg{font-size:14px;color:#b39ddb;margin-bottom:20px}.pq-clear-time{font-size:56px;font-weight:900;color:#ffd54f}.pq-clear-time-label{font-size:14px;color:#9e9e9e;margin-bottom:20px}.pq-field-actions{display:flex;flex-direction:column;gap:4px}.pq-map-canvas-wrap{display:flex;justify-content:center;margin-bottom:8px}.pq-map-canvas{border:3px solid #ffd54f;border-radius:8px;image-rendering:pixelated;max-width:100%}.pq-dpad{flex-direction:column;align-items:center;margin:8px 0}.pq-dpad,.pq-dpad-row{display:flex;gap:2px}.pq-dpad-btn{width:48px;height:44px;border:2px solid #ffd54f;border-radius:6px;background:#1a1a2e;color:#ffd54f;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.pq-dpad-btn:active{background:#3a3a5e}.pq-event{background:linear-gradient(180deg,#1a237e,#0d1b3e);border-radius:12px;padding:16px;color:#fff}.pq-event-title{font-size:20px;font-weight:800;color:#ffd54f;text-align:center;margin-bottom:12px}.td-wrap{max-width:560px;margin:0 auto;padding-bottom:60px}.td-header{margin-bottom:8px}.td-title{font-size:24px;font-weight:800}.td-hint{font-size:13px;color:var(--text-muted);margin-bottom:12px}.td-battle-field{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:12px}.td-vs{font-size:24px;font-weight:900;color:#f44336}.td-grid{flex:1 1;max-width:200px}.td-grid-label{text-align:center;font-size:12px;font-weight:800;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase}.td-grid-row{display:flex;gap:3px;margin-bottom:3px}.td-cell{flex:1 1;aspect-ratio:1;border:2px solid var(--border);border-radius:6px;background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:2px;position:relative}.td-cell-empty:hover,.td-cell-filled{border-color:var(--accent)}.td-cell-empty:hover{background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.td-cell-dead{opacity:.15;transition:opacity .3s}.td-cell-atk{animation:td-atk .3s ease-out}.td-cell-hit{animation:td-hit .3s ease-out}@keyframes td-atk{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes td-hit{0%{background:#ffcdd2}to{background:var(--surface)}}.td-cell-img{width:clamp(24px,8vw,40px);height:clamp(24px,8vw,40px)}.td-hp-bar{width:90%;height:4px;background:#e0e0e0;border-radius:2px;overflow:hidden}.td-hp-fill{height:100%;border-radius:2px;transition:width .3s}.td-dmg{position:absolute;top:-4px;right:-4px;font-size:12px;font-weight:900;color:#f44336;animation:td-dmg-pop .6s ease-out forwards;pointer-events:none}.td-dmg-super{color:#ff6f00;font-size:14px}.td-dmg-weak{color:#9e9e9e;font-size:10px}@keyframes td-dmg-pop{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-16px)}}.td-type-info{font-size:12px;color:var(--text-muted);text-align:center;margin-bottom:8px;font-weight:600}.td-picker{display:flex;gap:6px;flex-wrap:wrap;margin:12px 0}.td-pick-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;border:2px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;flex:1 1;min-width:60px}.td-pick-btn:hover,.td-pick-selected{border-color:var(--accent)}.td-pick-selected{border-width:3px;background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.td-pick-img{width:32px;height:32px}.td-pick-name{font-size:10px;font-weight:700}.td-pick-stats{font-size:9px;color:var(--text-muted)}.td-pick-disabled{opacity:.35;cursor:not-allowed}.td-action-log{text-align:center;font-size:13px;padding:8px;margin-bottom:8px;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.td-super{color:#ff6f00;font-weight:700}.td-weak{color:#9e9e9e}.td-result{text-align:center;padding:16px 0}.td-result-title{font-size:28px;font-weight:900;margin-bottom:8px}.td-win{color:#4caf50}.td-lose{color:#f44336}.td-result-detail{font-size:14px;color:var(--text-muted);margin-bottom:8px}.td-result-score{font-size:24px;font-weight:900;margin-bottom:12px}.td-match-info{font-size:13px}.td-match-info,.td-next-match{font-weight:700;color:var(--text-muted)}.td-next-match{text-align:center;font-size:16px;padding:16px}.td-history{display:flex;flex-direction:column;gap:4px;max-width:280px;margin:12px auto}.td-history-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;font-size:13px;font-weight:600}.td-history-win{background:#e8f5e9;color:#2e7d32}.td-history-lose{background:#ffebee;color:#c62828}.td-history-result{margin-left:auto;font-weight:800}.dodge-wrap{max-width:400px;margin:0 auto;padding-bottom:60px}.dodge-header{margin-bottom:8px}.dodge-title{font-size:24px;font-weight:800}.dodge-hint{font-size:13px;color:var(--text-muted);margin-bottom:12px}.dodge-canvas-wrap{position:relative;margin-bottom:16px}.dodge-canvas{width:100%;max-width:300px;display:block;margin:0 auto;border-radius:12px;border:2px solid var(--border);touch-action:none}.dodge-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(0,0,0,.3);border-radius:12px}.dodge-over-score{font-size:32px;font-weight:900;color:#fff}@keyframes p2-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-60%)}}.three-game-container{max-width:600px;margin:0 auto;position:relative}.three-game-canvas{border-radius:12px;overflow:hidden;touch-action:none;background:#0d1117}.three-game-canvas canvas{display:block;width:100%!important}.three-game-hud{position:relative;z-index:2}.three-game-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;pointer-events:none;background:rgba(0,0,0,.5);border-radius:12px;color:#fff;text-align:center;padding:24px}.three-game-overlay h2{font-size:28px;margin:0 0 12px}.three-game-overlay p{font-size:15px;margin:4px 0;opacity:.85}.three-game-start-hint{animation:tg-blink 1.5s infinite}@keyframes tg-blink{0%,to{opacity:.4}50%{opacity:1}}.three-game-final-score{font-size:36px!important;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.three-game-btn{pointer-events:auto;margin-top:16px;padding:10px 28px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer}.three-game-btn:hover{filter:brightness(1.15)}.three-game-score{position:absolute;top:12px;left:12px;z-index:10;background:rgba(0,0,0,.6);color:#fff;padding:6px 14px;border-radius:8px;font-size:14px;font-weight:600}.qa-container{margin:24px 0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.qa-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-bottom:1px solid var(--border)}.qa-header-icon{font-size:20px}.qa-header-text{font-size:15px;font-weight:700;color:var(--text);flex:1 1}.qa-reset{padding:4px 12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;font-size:12px;color:var(--text-muted);cursor:pointer;transition:background .15s}.qa-messages,.qa-reset:hover{background:var(--bg)}.qa-messages{padding:16px;display:flex;flex-direction:column;gap:16px}.qa-msg{display:flex;align-items:flex-start;gap:8px}.qa-msg-avatar{font-size:24px;flex-shrink:0;margin-top:4px}.qa-msg-bubble{max-width:85%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.6}.qa-msg-bubble p{margin:0 0 4px}.qa-msg-bubble p:last-child{margin:0}.qa-msg-bubble-ai{background:var(--surface);border:1px solid var(--border);color:var(--text)}.gb-entry{display:flex;flex-direction:column;gap:10px}.gb-figure{margin:0}.gb-image{width:100%;border-radius:10px}.gb-caption{font-size:11px;color:var(--text-muted);text-align:right;margin-top:4px}.gb-choices{display:flex;flex-wrap:wrap;gap:8px;padding-left:36px}.gb-choice{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:18px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.gb-choice:hover{opacity:.85;transform:translateY(-1px)}.gb-selected{padding-left:36px;font-size:13px;color:var(--accent);font-weight:600}.gb-selected:before{content:"→ "}@media (max-width:640px){.qa-msg-bubble{max-width:92%}.gb-choices,.gb-selected{padding-left:0}}.contributed-wrap{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:14px 18px;margin:8px 0}.contributed-note{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:8px;letter-spacing:.03em}.contributed-wrap .ci{padding:0;border:none;background:none}.contributed-wrap .ci-reply{padding:0}.notif-bell,.notif-wrap{position:relative}.notif-bell{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 10px;line-height:1;min-height:44px;display:flex;align-items:center}.notif-badge{position:absolute;top:-2px;right:-4px;background:#e05;color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:1px 5px;min-width:16px;text-align:center}.notif-dropdown{position:fixed;top:56px;right:8px;width:320px;max-width:calc(100vw - 16px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px rgba(45,31,61,.15);z-index:200;overflow:hidden}.notif-header{padding:12px 16px;font-weight:700;border-bottom:1px solid var(--border)}.notif-empty,.notif-header{font-size:13px;color:var(--text-muted)}.notif-empty{padding:20px 16px;text-align:center}.notif-list{list-style:none;max-height:360px;overflow-y:auto}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border)}.notif-item:last-child{border-bottom:none}.notif-item-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}.notif-commenter{font-size:13px;font-weight:700;color:var(--accent)}.notif-item-date{font-size:11px;color:var(--text-muted);margin-left:auto;white-space:nowrap}.notif-item-article{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.notif-item-article,.notif-item-tag,.notif-role{font-size:10px;font-weight:700;color:var(--accent);background:var(--surface2);border-radius:4px;padding:1px 6px}.notif-item-tag{display:inline-block;margin-bottom:4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item-body{font-size:13px;color:var(--text);line-height:1.5}.comment-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.comment-title{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px}.comment-count{font-size:13px;background:var(--surface2);color:var(--text-muted);border-radius:20px;padding:2px 10px;font-weight:600}.comment-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.comment-empty{font-size:14px;color:var(--text-muted);text-align:center;padding:24px 0}.comment-item{background:var(--surface2);border-radius:12px;padding:14px 16px}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.comment-username{font-size:13px;font-weight:700;color:var(--accent)}.comment-date{font-size:11px;color:var(--text-muted)}.comment-body{font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap}.comment-form{display:flex;flex-direction:column;gap:8px}.comment-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-size:16px;font-family:var(--font);background:var(--bg);color:var(--text);resize:vertical;outline:none;transition:border-color .2s}.comment-input:focus{border-color:var(--accent)}.comment-input[readonly]{cursor:pointer}.comment-form-footer{display:flex;justify-content:space-between;align-items:center}.comment-chars{font-size:12px;color:var(--text-muted)}.comment-submit{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:20px;padding:8px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.comment-submit:hover:not(:disabled){opacity:.85}.comment-submit:disabled{opacity:.4;cursor:not-allowed}.replies-list{margin-top:10px;margin-left:20px;display:flex;flex-direction:column;gap:8px;border-left:2px solid var(--border);padding-left:14px}.reply-item{background:var(--surface);border-radius:10px;padding:10px 14px}.reply-btn{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:4px 0;margin-top:4px}.reply-btn:hover{color:var(--accent)}.reply-form{margin-top:10px;display:flex;flex-direction:column;gap:6px}.reply-cancel-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-size:13px;padding:6px 14px;border-radius:8px;cursor:pointer}.longpress-overlay{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.3)}.longpress-menu{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--surface);border-radius:16px 16px 0 0;padding:8px 16px calc(env(safe-area-inset-bottom, 16px) + 8px);display:flex;flex-direction:column;gap:4px;animation:longpress-slide-up .2s ease-out}@keyframes longpress-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.longpress-menu-item{border:none;background:none;padding:14px;font-size:16px;color:var(--text-primary);cursor:pointer;border-radius:8px;text-align:center}.longpress-menu-item:hover{background:var(--bg-hover,rgba(0,0,0,.05))}.longpress-delete{color:#ef4444}.longpress-cancel{color:var(--text-muted);border-top:1px solid var(--border-color,rgba(0,0,0,.1));margin-top:4px;padding-top:14px}.context-menu{position:fixed;z-index:1000;background:var(--surface);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.15);padding:4px 0;min-width:120px;animation:context-pop .1s ease-out}@keyframes context-pop{0%{opacity:0;scale:.95}to{opacity:1;scale:1}}.context-menu-item{display:block;width:100%;border:none;background:none;padding:8px 16px;font-size:14px;text-align:left;color:var(--text-primary);cursor:pointer}.context-menu-item:hover{background:var(--bg-hover,rgba(0,0,0,.05))}.context-delete{color:#ef4444}.swipe-wrap{position:relative;overflow:hidden;border-radius:6px}.swipe-actions{position:absolute;right:0;top:0;height:100%;display:flex}.swipe-action-btn{flex:1 1;border:none;cursor:pointer;font-size:13px;font-weight:600;color:#fff;padding:0 12px}.swipe-edit{background:#3b82f6}.swipe-delete{background:#ef4444}.swipe-content{position:relative;background:inherit;z-index:1}.comment-delete-btn{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;padding:2px 6px;border-radius:4px}.comment-delete-btn:hover{color:#ef4444;background:rgba(239,68,68,.08)}.comment-pending{opacity:.7;border:1px dashed var(--border)}.comment-pending-badge{font-size:10px;color:#f59e0b;background:rgba(245,158,11,.12);border-radius:4px;padding:1px 6px;margin-left:4px}.comment-pending-count{font-size:13px;color:#f59e0b;font-weight:400}.comment-approve-btn{background:none;border:1px solid #22c55e;color:#22c55e;font-size:11px;cursor:pointer;padding:2px 8px;border-radius:4px;margin-left:4px}.comment-approve-btn:hover{background:rgba(34,197,94,.1)}.fchat-btn{position:fixed;bottom:28px;right:28px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.3);z-index:1000;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}.fchat-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(0,0,0,.4)}.fchat-btn-open{transform:scale(.92)}.fchat-panel{position:fixed;bottom:96px;right:28px;width:360px;max-height:520px;background:var(--surface2);border:1px solid var(--border);border-radius:18px;box-shadow:0 8px 40px rgba(0,0,0,.35);z-index:999;display:flex;flex-direction:column;overflow:hidden}.fchat-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px}.fchat-expand{margin-left:auto;font-size:12px;color:var(--text-muted);text-decoration:none}.fchat-expand:hover{color:var(--accent)}.fchat-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:0 0 0 4px}.fchat-list{flex:1 1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.fchat-item{background:var(--surface);border-radius:12px;padding:10px 12px}.fchat-item-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.fchat-username{font-size:13px;font-weight:700;color:var(--accent);text-decoration:none}.fchat-username:hover{text-decoration:underline}.fchat-date{font-size:11px;color:var(--text-muted);margin-left:auto}.fchat-body{font-size:13px;line-height:1.55;color:var(--text);white-space:pre-wrap}.fchat-reply-hint{font-size:11px;color:var(--text-muted);display:block;margin-top:4px}.fchat-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:16px 0}.fchat-form{padding:10px 14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.fchat-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:16px;font-family:var(--font);background:var(--bg);color:var(--text);resize:none;box-sizing:border-box}.fchat-input:focus{outline:none;border-color:var(--accent)}.fchat-form-footer{display:flex;justify-content:space-between;align-items:center}.fchat-submit{padding:6px 16px;font-size:13px}.fchat-login-hint{padding:12px 14px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);text-align:center}@media (max-width:640px){.fchat-panel{right:12px;left:12px;width:auto;bottom:110px}.fchat-btn{bottom:72px;right:20px}}.chats-page{min-height:80vh;padding:40px 24px}.chats-inner{max-width:640px;margin:0 auto}.chat-compose{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:24px}.chat-timeline{display:flex;flex-direction:column}.chat-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.chat-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-decoration:none}.chat-content{flex:1 1;min-width:0}.chat-item-header{display:flex;align-items:center;gap:7px;margin-bottom:4px;flex-wrap:wrap}.chat-username{font-size:14px;font-weight:700;color:var(--text);text-decoration:none}.chat-username:hover{color:var(--accent)}.chat-date{font-size:11px;color:var(--text-muted);margin-left:auto}.chat-item-badge{font-size:11px;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);border-radius:5px;padding:1px 7px;text-decoration:none;white-space:nowrap}.chat-item-badge:hover{opacity:.8}.chat-inline-link{color:var(--accent);text-decoration:underline}.chat-inline-link:hover{opacity:.8}.chat-body{font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap;margin-bottom:6px}.chat-body.no-mb{margin-bottom:0;word-break:break-word}.chat-actions{display:flex;align-items:center;gap:8px;margin-top:6px}.chat-like-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:13px;padding:2px 6px;border-radius:6px;transition:color .15s}.chat-like-btn:hover{color:#f43f5e}.chat-like-btn.others-liked{color:#f472b6}.chat-like-btn.liked{color:#fff;background:#f43f5e}.chat-cancel-btn{background:none;border:1px solid var(--border);color:var(--border);font-size:11px;font-weight:700;font-family:var(--font);padding:2px 8px;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.chat-cancel-btn:hover{border-color:#ef4444;color:#ef4444}.chat-cancel-btn.active{border-color:#ef4444;color:#fff;background:#ef4444}.chat-reply-btn{margin-top:0}.chat-reply-count{background:none;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;padding:0;margin-top:2px;display:block}.chat-reply-count:hover{color:var(--accent)}.chat-reply-item{display:flex;gap:8px}.chat-reply-avatar{width:28px;height:28px;border-radius:50%;background:var(--surface2);color:var(--accent);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-decoration:none}.chat-reply-content{flex:1 1;min-width:0}.chat-reply-header{display:flex;align-items:center;gap:7px;margin-bottom:2px}.recommend-section{margin-bottom:24px;display:flex;flex-direction:column;gap:16px}.recommend-label{font-size:13px;font-weight:700;color:var(--text-muted);margin-bottom:8px}.recommend-cards{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.recommend-card{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;white-space:nowrap;flex-shrink:0;transition:border-color .15s,background .15s}.recommend-card:hover{border-color:var(--accent);background:var(--surface2)}.recommend-emoji{font-size:18px}.recommend-title{font-size:13px;font-weight:600;color:var(--text)}@media (max-width:640px){.chats-page{padding:24px 16px}.recommend-cards{gap:6px}.recommend-card{padding:6px 10px}.recommend-title{font-size:12px}}