:root{--bg-color: #0f172a;--surface-color: #1e293b;--primary-color: #6366f1;--primary-color-rgb: 99, 102, 241;--primary-hover: #4f46e5;--accent-emerald: #10b981;--accent-color: #f59e0b;--text-primary: #f8fafc;--text-secondary: #94a3b8;--error-color: #ef4444;--font-family: "Inter", system-ui, -apple-system, sans-serif;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: 1rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;font-family:inherit}#root{width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.container{width:100%;max-width:640px;padding:1.5rem;margin:0 auto}.btn-primary{background:var(--primary-color);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%;font-size:1.125rem;box-shadow:0 4px 14px #6366f163}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f173;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#ffffff0d;color:var(--text-primary);padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:600;border:1px solid rgba(255,255,255,.1);transition:all .2s;width:100%;font-size:1.125rem}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-back{background:transparent;color:var(--text-secondary);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;display:flex;align-items:center;gap:.5rem;transition:all .2s;border:1px solid rgba(255,255,255,.1)}.btn-back:hover{color:var(--text-primary);background:#ffffff0d}@media(max-width:768px){.container{padding:.75rem}}.mahjong-tile{width:44px;height:60px;background-color:#fff;border-radius:4px;position:relative;box-shadow:1px 1px #ccc,2px 2px #ccc,3px 3px #aaa,3px 3px 5px #0000004d;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .1s,box-shadow .1s;display:flex;justify-content:center;align-items:center;margin:0 2px;background:#fdfbf7}.mahjong-tile:active{transform:translate(2px,2px);box-shadow:1px 1px #aaa}.mahjong-tile:hover{filter:brightness(1.05);margin-top:-4px}.tile-image{width:100%;height:100%;object-fit:contain;display:block}.quiz-container{width:100%;display:flex;flex-direction:column;align-items:center;position:relative}.status-bar{width:100%;display:flex;justify-content:center;gap:3rem;margin-bottom:2rem;font-size:1.25rem;color:var(--text-secondary)}.tehai-row{display:flex;flex-wrap:wrap;justify-content:center;gap:0;background:#15803d;padding:20px;border-radius:8px;box-shadow:inset 0 0 20px #00000080;border:4px solid #b45309}@media(max-width:768px){.tehai-row{flex-wrap:nowrap;padding:10px 5px;width:100%;box-sizing:border-box}.tehai-row .mahjong-tile{width:6.2vw;height:8.5vw;margin:0 1px;box-shadow:1px 1px #ccc;border-radius:2px}}.instruction{margin-bottom:1rem;font-weight:300;text-align:center}.feedback-overlay{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;pointer-events:none;z-index:10;animation:fadeIn .1s ease-out}.mark{font-size:8rem;text-shadow:0 0 20px rgba(0,0,0,.5)}.circle{color:#10b981}.cross{color:#ef4444}@keyframes fadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.explanation-container{line-height:1.6;word-break:break-all;display:block}.explanation-tiles{display:inline-flex;align-items:center;vertical-align:middle;margin:0 2px;gap:1px}.explanation-tiles .mahjong-tile{width:22px;height:30px;margin:0;cursor:default;box-shadow:1px 1px #ccc,1px 1px 2px #0003}.explanation-tiles .mahjong-tile:hover{margin-top:0;filter:none}.result-container{text-align:center}.result-summary-area{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;padding:2rem;background:#ffffff0d;border-radius:12px}.score-label{font-size:1.2rem;font-weight:700;letter-spacing:.1em;color:var(--text-secondary)}.score-value{font-size:4rem;font-weight:900;margin:.5rem 0;color:var(--accent-emerald)}.score-title-badge{display:inline-block;background:#1e293b;color:#f59e0b;padding:.4rem 1rem;border-radius:4px;font-size:1.4rem;font-weight:700;margin-bottom:.5rem;border:2px solid #f59e0b;text-transform:uppercase;letter-spacing:.1em}.share-area{margin-bottom:1rem}.btn-x-share{display:flex;align-items:center;justify-content:center;gap:8px;background-color:#000;color:#fff;border:1px solid #333;padding:.6rem 1.5rem;border-radius:9999px;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .2s,transform .1s}.btn-x-share:hover{background-color:#1a1a1a}.btn-x-share:active{transform:scale(.98)}.x-icon{width:18px;height:18px;fill:currentColor}.new-record-badge{background-color:#f59e0b;color:#fff;padding:.25rem .75rem;border-radius:9999px;font-size:.9rem;font-weight:700;margin-bottom:.5rem;animation:bounce 1s infinite}.best-score-display{font-size:1rem;color:var(--text-secondary);margin-top:-.5rem;margin-bottom:1rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.result-details{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;font-size:1.2rem}.detail-item{color:var(--text-secondary)}.error-text{color:var(--error-color)}.share-x-button{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.6rem 1.4rem;background-color:#000;color:#fff;border-radius:9999px;font-size:1rem;font-weight:700;text-decoration:none;transition:background-color .2s}.share-x-button:hover{background-color:#1a1a1a}.share-x-icon{width:1.1em;height:1.1em;fill:currentColor;flex-shrink:0}.result-section{text-align:left;margin-bottom:2rem}.history-list{max-height:300px;overflow-y:auto;background:var(--surface-color);padding:1rem;border-radius:8px}.history-item{border-bottom:1px solid #334155;padding:.5rem 0}.history-item-header{display:flex;justify-content:space-between;align-items:center}.result-history{margin-top:.5rem;margin-bottom:.5rem}.result-tehai{display:flex;gap:0;margin-top:.5rem;margin-bottom:.5rem;transform:scale(.8);transform-origin:left top;width:125%}.result-answer-area{display:flex;align-items:center;margin-top:.5rem}.result-answer-tehai{display:flex;transform:scale(.8);transform-origin:left center}.ranking-table{width:100%;border-collapse:collapse;color:var(--text-secondary)}.ranking-table th,.ranking-table td{padding:.5rem}.ranking-table tr{border-bottom:1px solid #1e293b}@media(max-width:768px){.history-list{padding:.5rem;max-height:none;overflow-y:visible}.history-item{padding:.5rem 0}.result-tehai{transform:none;width:100%;flex-wrap:nowrap;flex-shrink:0;align-items:center}.result-tehai .mahjong-tile{width:calc((100vw - 100px) / 14);height:auto;aspect-ratio:44 / 60;margin:0 1px;flex-shrink:0}.result-answer-tehai{transform:none;flex-wrap:nowrap;width:100%;align-items:center}.result-answer-tehai .mahjong-tile{width:calc((100vw - 100px) / 14);height:auto;aspect-ratio:44 / 60;margin:0 1px;flex-shrink:0}}.problem-list-container{padding:2rem;max-width:1000px;margin:0 auto}.problem-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.problem-list-header h2{margin:0}.about-problems-section{margin-bottom:1.5rem}.btn-about-problems{background:none;border:1px solid rgba(255,255,255,.2);color:var(--text-secondary);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-about-problems:hover{background:#ffffff0d;border-color:#fff6;color:#fff}.btn-about-problems.open{background:#ffffff1a;color:#fff;border-color:var(--primary-color)}.about-problems-content{margin-top:.75rem;padding:1rem;background:#0003;border-left:3px solid var(--primary-color);border-radius:4px;font-size:.9rem;line-height:1.6;color:var(--text-secondary);animation:fadeIn .3s ease-out}.about-problems-content p{margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.header-controls{display:flex;gap:1rem;align-items:center}.btn-sort-mobile{display:none;padding:.5rem .75rem;background:var(--surface-color);border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem}.btn-sort-mobile:hover{background:#ffffff1a}.table-wrapper{background:var(--surface-color);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0003}.problem-table{width:100%;border-collapse:collapse;text-align:left}.problem-table thead{background:#ffffff0d}.problem-table th{padding:1rem}.col-id.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s;position:relative;padding-right:1.5rem}.col-id.sortable:hover{background:#ffffff1a}.problem-table tr{border-bottom:1px solid rgba(255,255,255,.05)}.problem-table td{padding:1rem;vertical-align:top}.col-id{width:60px;font-weight:700}.col-problem{width:auto}.col-answer{width:140px}.answer-history{display:inline-flex;gap:1px;align-items:center}.history-mark{display:inline-flex;justify-content:center;align-items:center;width:1.1em;font-size:.9rem;font-weight:700}.problem-history{margin-bottom:.5rem}.history-mark.correct{color:var(--accent-emerald)}.history-mark.incorrect{color:var(--error-color)}.history-mark.empty{color:#ffffff40}.history-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:2px}.problem-tehai{display:flex;gap:0;margin-bottom:1rem;transform:scale(.8);transform-origin:left top;width:125%}.problem-explanation{font-size:.9rem;color:var(--text-secondary);background:#0003;padding:.75rem;border-radius:8px;white-space:normal;word-wrap:break-word}.answer-tehai{display:flex;gap:2px;transform:scale(.7);transform-origin:left top;width:142%}.pagination-container{display:flex;justify-content:center;align-items:center;margin-top:2rem;gap:1rem;flex-wrap:wrap}.btn-nav,.btn-page{padding:.5rem 1rem;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-page{width:30px;height:30px;display:flex;justify-content:center;align-items:center;padding:0}.btn-inactive{background:#ffffff1a}@media(max-width:768px){.problem-list-container{padding:.25rem;max-width:100vw;overflow-x:hidden}.problem-list-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.header-controls{width:100%;justify-content:space-between}.btn-sort-mobile{display:block}.problem-list-header .btn-back{align-self:flex-end}.table-wrapper{max-width:100%;overflow-x:hidden}.problem-table thead{display:none}.problem-table,.problem-table tbody{display:block;width:100%;box-sizing:border-box}.problem-table tr{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"id answer" "tehai answer" "explanation explanation";gap:.25rem .5rem;align-items:center;margin-bottom:1.5rem;background:#32323280;border-radius:8px;padding:.75rem;border:1px solid rgba(255,255,255,.1);box-sizing:border-box;width:100%}.problem-table td{padding:0;border:none}.col-id{grid-area:id;font-size:.8rem;color:var(--text-secondary);width:auto}.col-problem{display:contents}.problem-tehai{grid-area:tehai;transform:none;width:100%;min-width:0;flex-wrap:nowrap;margin-bottom:0;gap:2px}.problem-tehai .mahjong-tile{width:calc((100% - 26px) / 14);height:auto;aspect-ratio:44 / 60;margin:0}.col-answer{grid-area:answer;width:auto;margin-top:0}.answer-tehai{transform:none;width:auto;flex-wrap:nowrap;gap:2px}.answer-tehai .mahjong-tile{width:28px;height:38px}.problem-explanation{grid-area:explanation;min-width:0}.problem-explanation{font-size:.85rem;margin-top:.5rem;word-break:break-all;overflow-wrap:anywhere;max-width:100%}}.base-confirmation-container{padding:2rem;max-width:1200px;margin:0 auto}.base-confirmation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.base-problem-section{background:var(--surface-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 20px #0003}.base-problem-info{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.original-problem-display{margin-bottom:0}.variant-item{background:#ffffff0d;border-radius:8px;padding:1rem;border:1px solid rgba(255,255,255,.1)}.variations-grid{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.btn-toggle-modern{background:#6366f1!important;box-shadow:0 4px 12px #6366f14d!important}.btn-toggle-modern.active{background:#4f46e5!important}.variant-header{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.85rem;color:var(--text-secondary)}.variant-label{font-weight:700}.variant-pattern{font-family:monospace}.variant-content{display:flex;flex-wrap:wrap;align-items:center;gap:2rem}.variant-tehai{display:flex;gap:0;transform:scale(.75);transform-origin:left center;width:auto;margin-right:-100px}.variant-answer{display:flex;align-items:center;gap:.5rem}.answer-label{font-size:.9rem;color:var(--text-secondary)}.answer-tiles{display:flex;gap:2px;transform:scale(.7);transform-origin:left center}.variant-explanation{margin-top:1rem;font-size:.85rem;color:var(--text-secondary);background:#0000004d;padding:.75rem;border-radius:6px;line-height:1.5}.pagination-container{display:flex;justify-content:center;align-items:center;margin-top:2rem;gap:1rem}.page-numbers{display:flex;align-items:center;gap:.5rem}.pagination-ellipsis{color:var(--text-secondary)}.btn-nav,.btn-page{padding:.5rem 1rem;color:#fff;border:none;border-radius:4px;cursor:pointer;background:#ffffff1a}.btn-page{width:36px;height:36px;display:flex;justify-content:center;align-items:center;padding:0}.btn-active{background:var(--primary-color)}.btn-disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.base-confirmation-container{padding:.5rem}.variant-content{flex-direction:column;align-items:flex-start;gap:1rem}.variant-tehai{transform:scale(.65);margin-right:0;width:100%}.variant-answer{transform:scale(.8);transform-origin:left center}}.privacy-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem;text-align:left}.privacy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.privacy-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.privacy-content{line-height:1.8;color:var(--text-secondary)}.privacy-content section{margin-bottom:2rem}.privacy-content h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:.75rem;border-left:4px solid var(--primary-color);padding-left:.75rem}.privacy-content p{margin:0}@media(max-width:768px){.privacy-container{padding:1rem}.privacy-header h2{font-size:1.25rem}}.disclaimer-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem;text-align:left}.disclaimer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.disclaimer-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.disclaimer-content{line-height:1.8;color:var(--text-secondary)}.disclaimer-content section{margin-bottom:2rem}.disclaimer-content h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:.75rem;border-left:4px solid var(--primary-color);padding-left:.75rem}.disclaimer-content p{margin:0}.disclaimer-content p+p{margin-top:.5rem}@media(max-width:768px){.disclaimer-container{padding:1rem}.disclaimer-header h2{font-size:1.25rem}}.about-container{max-width:800px;margin:0 auto;padding:2rem 1.5rem;text-align:left}.about-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.about-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.about-content{line-height:1.8;color:var(--text-secondary)}.about-content section{margin-bottom:2rem}.about-content h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:.75rem;border-left:4px solid var(--primary-color);padding-left:.75rem}.about-content p{margin:0}.about-link{color:#3b82f6;text-decoration:none;transition:opacity .2s}.about-link:hover{text-decoration:underline;opacity:.8}@media(max-width:768px){.about-container{padding:1rem}.about-header h2{font-size:1.25rem}}.timeup-container{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.timeup-icon{font-size:5rem;margin-bottom:1rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-10px)}40%,80%{transform:translate(10px)}}.timeup-title{font-size:2.5rem;color:var(--error-color);margin-bottom:.5rem}.timeup-message{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2rem}.timeup-stats{display:flex;gap:3rem;margin-bottom:2rem;padding:1.5rem 2rem;background:var(--surface-color);border-radius:12px}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.stat-value.miss{color:var(--error-color)}.retry-button{padding:1rem 2rem;font-size:1.2rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .1s}.retry-button:hover{background:var(--primary-hover);transform:scale(1.02)}.retry-button:active{transform:scale(.98)}@media(max-width:768px){.timeup-icon{font-size:4rem}.timeup-title{font-size:2rem}.timeup-stats{gap:2rem;padding:1rem 1.5rem}.stat-value{font-size:1.5rem}.retry-button{padding:.8rem 1.5rem;font-size:1rem}}
