:root{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f0f4f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}button{font-family:inherit}img{max-width:100%;height:auto}@media(hover:none)and (pointer:coarse){button{min-height:44px}}@media(max-width:380px){:root{font-size:14px}}.start-screen{max-width:480px;margin:0 auto;padding:2rem 1rem;text-align:center}.start-header{margin-bottom:2.5rem}.start-title{font-size:2rem;color:#2c3e50;margin:0 0 .5rem}.start-subtitle{font-size:1rem;color:#7f8c8d;margin:0}.difficulty-section{margin-bottom:1.5rem;background:#f1f5f9;border-radius:12px;padding:1rem}.difficulty-section h3{font-size:.9rem;color:#555;margin:0 0 .75rem}.difficulty-toggle{display:flex;gap:.75rem;justify-content:center}.difficulty-button{flex:1;max-width:160px;padding:.75rem .5rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.25rem}.difficulty-button:hover{border-color:#4f46e5}.difficulty-button.active{border-color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.difficulty-icon{font-size:1.25rem}.difficulty-label{font-size:.9rem;font-weight:700;color:#1e293b}.difficulty-desc{font-size:.7rem;color:#64748b}.difficulty-info{margin-top:.75rem;padding:.5rem;background:#4f46e51a;border-radius:6px}.difficulty-info p{margin:0;font-size:.7rem;color:#4f46e5;line-height:1.4}.question-count-section{margin-bottom:2rem}.question-count-section h3{font-size:1rem;color:#555;margin-bottom:1rem}.question-buttons{display:flex;gap:1rem;justify-content:center}.start-button{padding:1rem 2rem;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.start-button:hover{transform:translateY(-3px);box-shadow:0 6px 16px #3498db66}.stats-section{background-color:#f8fafc;border-radius:16px;padding:1.5rem}.stats-section h3{font-size:.9rem;color:#666;margin:0 0 1rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-item{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:#2c3e50}.stat-label{font-size:.75rem;color:#999}.stats-detail-button{margin-top:1rem;padding:.75rem 1.5rem;background:transparent;border:2px solid #4f46e5;color:#4f46e5;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.stats-detail-button:hover{background:#4f46e5;color:#fff}@media(max-width:480px){.start-screen{padding:1.5rem .75rem}.start-header{margin-bottom:1.5rem}.start-title{font-size:1.5rem}.start-subtitle{font-size:.875rem}.difficulty-section{padding:.75rem}.difficulty-toggle{gap:.5rem}.difficulty-button{padding:.625rem .375rem}.difficulty-icon{font-size:1rem}.difficulty-label{font-size:.8rem}.difficulty-desc{font-size:.65rem}.question-buttons{flex-wrap:wrap;gap:.75rem}.start-button{padding:.875rem 1.5rem;font-size:1rem;flex:1;min-width:80px}.stats-section{padding:1rem}.stats-grid{gap:.5rem}.stat-value{font-size:1.25rem}.stat-label{font-size:.7rem}.stats-detail-button{padding:.625rem 1rem;font-size:.8rem}}@media(max-width:360px){.start-title{font-size:1.25rem}.question-buttons{flex-direction:column}.start-button{width:100%}}.quiz-image-container{min-height:180px;max-height:40vh;background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000001f,0 1px 3px #00000014;position:relative}.quiz-image{width:100%;height:100%;object-fit:cover;object-position:center}.quiz-image--hidden{opacity:0;position:absolute}.quiz-image-loading{color:#94a3b8;font-size:.875rem;font-weight:500}.quiz-image-error{flex-direction:column;color:#94a3b8;font-size:.875rem}.error-filename{font-size:.6875rem;color:#64748b;margin-top:.5rem;word-break:break-all;padding:0 1rem;text-align:center}.quiz-image-placeholder{flex-direction:column;background:linear-gradient(135deg,#1e3a5f,#2d4a6f,#1e293b)}.placeholder-icon{color:#64b5f6;opacity:.8;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}.placeholder-text{color:#94a3b8;font-size:1rem;font-weight:500;text-align:center;margin:0}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@media(max-width:480px){.quiz-image-container{min-height:150px;max-height:35vh;border-radius:10px}.quiz-image-loading{font-size:.8rem}.placeholder-icon svg{width:48px;height:48px}.placeholder-text{font-size:.875rem}}@media(max-width:360px){.quiz-image-container{min-height:120px;max-height:30vh}}.choice-button{display:flex;align-items:center;width:100%;padding:.75rem .875rem;border:2px solid #e2e8f0;border-radius:10px;background-color:#fff;cursor:pointer;font-size:.9375rem;text-align:left;transition:all .15s ease;box-shadow:0 1px 3px #0000000a}.choice-button:hover:not(:disabled){border-color:#6366f1;background-color:#f8fafc;box-shadow:0 2px 6px #6366f11a;transform:translateY(-1px)}.choice-button--correct{border-color:#10b981;background:linear-gradient(135deg,#d1fae5,#ecfdf5);box-shadow:0 2px 8px #10b98126}.choice-button--incorrect{border-color:#ef4444;background:linear-gradient(135deg,#fee2e2,#fef2f2);box-shadow:0 2px 8px #ef444426}.choice-button--disabled{opacity:.6;cursor:not-allowed}.choice-label{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin-right:.75rem;background-color:#f1f5f9;border-radius:6px;font-weight:700;font-size:.8125rem;color:#64748b;flex-shrink:0;transition:all .15s ease}.choice-button--correct .choice-label{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 4px #10b98133}.choice-button--incorrect .choice-label{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 4px #ef444433}.choice-text{flex:1;line-height:1.5;color:#1e293b;font-weight:500}.quiz-card{flex:1;display:flex;flex-direction:column;width:100%;max-width:600px;margin:0 auto;min-height:0}.question-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem;flex-shrink:0}.question-title{text-align:center;font-size:1.0625rem;font-weight:600;color:#1e293b;margin:0;letter-spacing:-.01em;line-height:1.4}.difficulty-indicator{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0}.choices{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.result-section{padding:.875rem;border-radius:12px;background:#fff;flex-shrink:0;box-shadow:0 2px 8px #0000000f}.result-section--correct{border:2px solid #10b981;background:linear-gradient(135deg,#d1fae5,#fff)}.result-section--incorrect{border:2px solid #ef4444;background:linear-gradient(135deg,#fee2e2,#fff)}.result-header{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem}.result-badge{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:1.125rem;font-weight:700;box-shadow:0 2px 4px #0000001a}.result-section--correct .result-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.result-section--incorrect .result-badge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.result-text{font-size:1.0625rem;font-weight:700;letter-spacing:-.01em}.result-section--correct .result-text{color:#059669}.result-section--incorrect .result-text{color:#dc2626}.heritage-compact{padding:.625rem;background:#f8fafccc;border-radius:8px;margin-bottom:.5rem;border:1px solid rgba(148,163,184,.1)}.heritage-title{font-size:.9375rem;font-weight:700;color:#1e293b;margin-bottom:.25rem;letter-spacing:-.01em}.heritage-meta{font-size:.75rem;color:#64748b;line-height:1.5}.heritage-description{font-size:.8125rem;color:#475569;line-height:1.6;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(148,163,184,.2)}.next-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 2px 8px #4f46e533;letter-spacing:-.01em}.next-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4f46e54d}.next-button:active{transform:translateY(0);box-shadow:0 2px 6px #4f46e533}.image-container{position:relative;margin-bottom:.75rem;z-index:1}.image-toggle-button{position:absolute;bottom:12px;right:12px;padding:8px 16px;background:#4f46e5e6;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:24px;font-size:.8125rem;font-weight:700;cursor:pointer;transition:background .15s ease,transform .15s ease,box-shadow .15s ease;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0000004d}.image-toggle-button:hover{background:#4f46e5e6;transform:scale(1.05)}.image-toggle-button:active{transform:scale(.98)}.details-toggle{width:100%;padding:.5rem;background:transparent;color:#6366f1;border:1px dashed #c7d2fe;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;margin-bottom:.5rem;transition:background .15s ease,border-color .15s ease}.details-toggle:hover{background:#f5f3ff;border-color:#a5b4fc}.heritage-details{background:#f8fafc;border-radius:8px;padding:.75rem;margin-bottom:.5rem;border:1px solid #e2e8f0}.section-title{font-size:.75rem;font-weight:700;color:#475569;margin:0 0 .5rem;padding-bottom:.25rem;border-bottom:1px solid #e2e8f0}.criteria-section{margin-bottom:.75rem}.criteria-list{list-style:none;padding:0;margin:0}.criteria-item{display:flex;gap:.5rem;padding:.375rem 0;border-bottom:1px solid #f1f5f9}.criteria-item:last-child{border-bottom:none}.criteria-number{font-size:.6875rem;font-weight:700;color:#6366f1;background:#eef2ff;padding:.125rem .375rem;border-radius:4px;flex-shrink:0;height:fit-content}.criteria-content{flex:1}.criteria-name{font-size:.75rem;font-weight:600;color:#334155;display:block;margin-bottom:.125rem}.criteria-reason{font-size:.6875rem;color:#64748b;margin:0;line-height:1.5}.themes-section{margin-bottom:.75rem}.theme-tags{display:flex;flex-wrap:wrap;gap:.375rem}.theme-tag{font-size:.6875rem;font-weight:600;color:#0f766e;background:#ccfbf1;padding:.1875rem .5rem;border-radius:9999px}.similar-section{margin-bottom:0}.similar-list{list-style:none;padding:0;margin:0}.similar-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;border-bottom:1px solid #f1f5f9;gap:.5rem}.similar-item:last-child{border-bottom:none}.similar-name{font-size:.75rem;font-weight:600;color:#334155;flex:1}.similar-country{font-size:.6875rem;color:#94a3b8;flex-shrink:0}@media(max-width:480px){.question-header{margin-bottom:.5rem}.question-title{font-size:.9375rem}.difficulty-indicator{padding:.1rem .375rem;font-size:.625rem}.choices{gap:.375rem}.result-section{padding:.75rem}.result-badge{width:28px;height:28px;font-size:1rem}.result-text{font-size:.9375rem}.heritage-compact{padding:.5rem}.heritage-title{font-size:.875rem}.heritage-meta{font-size:.6875rem}.heritage-description{font-size:.75rem}.next-button{padding:.625rem;font-size:.875rem}.image-toggle-button{padding:6px 12px;font-size:.75rem;bottom:8px;right:8px}.details-toggle{padding:.375rem;font-size:.75rem}.heritage-details{padding:.625rem}.section-title{font-size:.6875rem}.criteria-number{font-size:.625rem;padding:.1rem .25rem}.criteria-name{font-size:.6875rem}.criteria-reason{font-size:.625rem}.theme-tag{font-size:.625rem;padding:.125rem .375rem}.similar-name{font-size:.6875rem}.similar-country{font-size:.625rem}}@media(max-width:360px){.question-title{font-size:.875rem}.heritage-title{font-size:.8125rem}}.quiz-complete{max-width:400px;margin:2rem auto;padding:2rem;text-align:center;background-color:#fff;border-radius:20px;box-shadow:0 8px 24px #0000001a}.complete-header h2{font-size:1.5rem;color:#2c3e50;margin:0 0 1.5rem}.score-display{margin-bottom:1.5rem}.grade{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;font-size:2.5rem;font-weight:700;border-radius:50%;margin-bottom:1rem}.grade--s{background:linear-gradient(135deg,gold,#fa0);color:#fff;box-shadow:0 4px 16px #fa06}.grade--a{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.grade--b{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.grade--c{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.grade--d{background:linear-gradient(135deg,#9e9e9e,#757575);color:#fff}.score-numbers{font-size:2rem;color:#333;margin-bottom:.25rem}.score-main{font-weight:700;color:#3498db}.score-divider{margin:0 .25rem;color:#999}.score-total{color:#666}.score-percentage{font-size:1.25rem;color:#666}.score-message{font-size:1.1rem;color:#555;margin-bottom:1.5rem}.cumulative-stats{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;padding:1rem;margin-bottom:1.5rem}.cumulative-stats h3{font-size:.9rem;color:#6c757d;margin:0 0 .75rem;font-weight:600}.stats-row{display:flex;justify-content:space-around;gap:.5rem}.cumulative-stats .stat-item{display:flex;flex-direction:column;align-items:center}.cumulative-stats .stat-value{font-size:1.25rem;font-weight:700;color:#4f46e5}.cumulative-stats .stat-label{font-size:.7rem;color:#6c757d;margin-top:.25rem}.restart-button{padding:1rem 2.5rem;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.restart-button:hover{transform:translateY(-3px);box-shadow:0 6px 16px #3498db66}.stats-screen{max-width:600px;margin:0 auto;padding:1rem;height:100%;display:flex;flex-direction:column}.stats-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.stats-header h2{margin:0;font-size:1.25rem;color:#1f2937}.stats-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem}.tab{flex:1;padding:.5rem 1rem;border:none;background:#f3f4f6;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s}.tab.active{background:#4f46e5;color:#fff}.stats-content{flex:1;overflow-y:auto}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.summary-card{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:12px;padding:1rem;text-align:center;color:#fff}.card-value{font-size:1.5rem;font-weight:700}.card-label{font-size:.7rem;opacity:.9;margin-top:.25rem}.country-collection-button{width:100%;padding:1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1rem;transition:transform .2s,box-shadow .2s}.country-collection-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.progress-overview{background:#f9fafb;border-radius:12px;padding:1rem;margin-bottom:1rem}.progress-overview h3{margin:0 0 .75rem;font-size:.9rem;color:#374151}.progress-bar-container{margin-bottom:.5rem}.progress-bar{height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;display:flex}.progress-segment{height:100%;transition:width .3s ease}.progress-segment.mastered{background:#10b981}.progress-segment.learning{background:#f59e0b}.progress-legend{display:flex;gap:1rem;font-size:.75rem;color:#6b7280;margin-top:.5rem}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.25rem}.dot.mastered{background:#10b981}.dot.learning{background:#f59e0b}.dot.not-started,.dot.level0{background:#9ca3af}.dot.level1{background:#3b82f6}.dot.level2{background:#8b5cf6}.dot.level3{background:#f59e0b}.dot.level4{background:#10b981}.difficulty-distribution{margin-bottom:.75rem}.difficulty-bar{height:16px;background:#e5e7eb;border-radius:8px;overflow:hidden;display:flex;margin-bottom:.75rem}.difficulty-segment{height:100%;transition:width .3s ease}.difficulty-segment.level4{background:#10b981}.difficulty-segment.level3{background:#f59e0b}.difficulty-segment.level2{background:#8b5cf6}.difficulty-segment.level1{background:#3b82f6}.difficulty-legend{display:flex;flex-direction:column;gap:.375rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.legend-label{color:#374151;flex:1}.legend-count{color:#6b7280;font-weight:600;min-width:30px;text-align:right}.level-explanation{background:#4f46e51a;border-radius:6px;padding:.5rem;margin-top:.5rem}.level-explanation p{margin:0;font-size:.7rem;color:#4f46e5;line-height:1.4}.weak-section,.strong-section{background:#fff;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.weak-section h3,.strong-section h3{margin:0 0 .75rem;font-size:.9rem;color:#374151;display:flex;align-items:center;gap:.5rem}.badge{background:#ef4444;color:#fff;padding:.125rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:400}.heritage-list{list-style:none;padding:0;margin:0}.heritage-list li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f3f4f6;font-size:.85rem}.heritage-list li:last-child{border-bottom:none}.heritage-name{color:#374151}.heritage-accuracy{font-weight:600}.heritage-accuracy.good{color:#10b981}.heritage-accuracy.bad{color:#ef4444}.review-button{width:100%;margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s}.review-button:hover{transform:translateY(-2px)}.category-section{background:#fff;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.category-section h3{margin:0 0 1rem;font-size:.9rem;color:#374151}.category-bars{display:flex;flex-direction:column;gap:.75rem}.category-row{display:grid;grid-template-columns:100px 1fr 80px;align-items:center;gap:.75rem}.category-name{font-size:.8rem;color:#374151}.category-bar-wrapper{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.category-bar{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:4px;transition:width .3s ease}.category-stat{font-size:.8rem;color:#4f46e5;font-weight:600;text-align:right}.category-stat small{color:#9ca3af;font-weight:400;margin-left:.25rem}.filters{display:flex;gap:.5rem;margin-bottom:1rem}.filters select{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:8px;font-size:.85rem;background:#fff}.progress-count{font-size:.8rem;color:#6b7280;margin-bottom:.5rem}.progress-list{list-style:none;padding:0;margin:0}.progress-item{background:#fff;border-radius:8px;padding:.75rem;margin-bottom:.5rem;box-shadow:0 1px 2px #0000000d}.progress-item-main{display:flex;align-items:center;gap:.5rem}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.progress-name{font-size:.9rem;color:#1f2937}.progress-item-sub{display:flex;justify-content:space-between;margin-top:.25rem;margin-left:1.25rem}.progress-country{font-size:.75rem;color:#9ca3af}.progress-accuracy{font-size:.75rem;color:#6b7280}.progress-accuracy.good{color:#10b981}.progress-accuracy.bad{color:#ef4444}.level-badge{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:700;color:#fff;min-width:40px;flex-shrink:0}.progress-stats{font-size:.75rem;color:#6b7280}@media(max-width:480px){.stats-screen{padding:.75rem}.stats-header h2{font-size:1.1rem}.stats-tabs{gap:.25rem}.tab{padding:.375rem .5rem;font-size:.8rem}.summary-cards{grid-template-columns:repeat(3,1fr);gap:.5rem}.summary-card{padding:.75rem .5rem}.card-value{font-size:1.25rem}.card-label{font-size:.625rem}.country-collection-button{padding:.75rem;font-size:.875rem}.progress-overview{padding:.75rem}.progress-overview h3{font-size:.8rem}.legend-item{font-size:.7rem}.legend-count{min-width:24px}.level-explanation p{font-size:.625rem}.weak-section,.strong-section{padding:.75rem}.weak-section h3,.strong-section h3{font-size:.8rem}.heritage-list li{font-size:.8rem;padding:.375rem 0}.review-button{padding:.625rem;font-size:.8rem}.category-section{padding:.75rem}.category-section h3{font-size:.8rem}.category-row{grid-template-columns:80px 1fr 60px;gap:.5rem}.category-name,.category-stat{font-size:.7rem}.category-stat small{display:none}.filters select{padding:.375rem;font-size:.8rem}.progress-item{padding:.625rem}.progress-name{font-size:.8rem}.progress-item-sub{margin-left:0;margin-top:.375rem}.progress-country,.progress-stats{font-size:.7rem}.level-badge{font-size:.625rem;padding:.1rem .375rem;min-width:36px}}@media(max-width:360px){.summary-cards{grid-template-columns:repeat(2,1fr)}.category-row{grid-template-columns:70px 1fr 50px}}.country-collection{max-width:600px;margin:0 auto;padding:1rem;height:100%;display:flex;flex-direction:column}.collection-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.collection-header h2{margin:0;font-size:1.25rem;color:#1f2937}.back-button{background:none;border:none;color:#4f46e5;font-size:1rem;cursor:pointer;padding:.5rem}.collection-summary{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:16px;padding:1.25rem;color:#fff;margin-bottom:1rem}.summary-main{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.trophy{font-size:2.5rem}.summary-text{display:flex;flex-direction:column}.summary-count{font-size:1.5rem;font-weight:700}.summary-total{font-size:.9rem;opacity:.9}.summary-progress{display:flex;align-items:center;gap:.75rem}.summary-progress .progress-bar{flex:1;height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden}.summary-progress .progress-fill{height:100%;background:#fbbf24;border-radius:4px;transition:width .5s ease}.progress-text{font-size:.85rem;white-space:nowrap}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem}.filter-tab{padding:.5rem .75rem;border:none;background:#f3f4f6;border-radius:20px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:all .2s}.filter-tab.active{background:#4f46e5;color:#fff}.country-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;flex:1;overflow-y:auto;padding-bottom:1rem}.country-card{background:#fff;border-radius:12px;padding:1rem;text-align:center;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .2s;position:relative;border:2px solid transparent}.country-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.country-card.completed{border-color:#fbbf24;background:linear-gradient(135deg,#fef3c7,#fde68a)}.country-card.in-progress{border-color:#4f46e5}.country-card.not-started{opacity:.7}.country-flag{font-size:2rem;margin-bottom:.25rem}.country-name{font-size:.9rem;font-weight:600;color:#1f2937;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.country-stars{font-size:.7rem;margin-bottom:.25rem;letter-spacing:-1px}.country-progress{font-size:.85rem;color:#4f46e5;font-weight:600}.country-badge{position:absolute;top:-8px;right:-8px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.65rem;font-weight:700;box-shadow:0 2px 4px #0003}.country-percent{font-size:.75rem;color:#6b7280}.country-new{font-size:.7rem;color:#9ca3af}.country-detail{height:100%;display:flex;flex-direction:column}.detail-header{margin-bottom:1rem}.detail-summary{text-align:center;margin-bottom:1.5rem}.detail-flag{font-size:4rem;margin-bottom:.5rem}.detail-summary h2{margin:0 0 .5rem;font-size:1.5rem;color:#1f2937}.detail-badge{display:inline-block;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:700}.detail-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.detail-stats .stat-item{background:#f9fafb;border-radius:12px;padding:1rem;text-align:center}.detail-stats .stat-value{display:block;font-size:1.25rem;font-weight:700;color:#4f46e5}.detail-stats .stat-label{font-size:.75rem;color:#6b7280}.quiz-button{width:100%;padding:1rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:1.5rem}.quiz-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4f46e566}.heritage-list-section{flex:1;overflow-y:auto}.heritage-list-section h3{margin:0 0 .75rem;font-size:1rem;color:#374151}.heritage-detail-list{list-style:none;padding:0;margin:0}.heritage-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff;border-radius:8px;margin-bottom:.5rem;box-shadow:0 1px 2px #0000000d}.heritage-item.mastered{background:#f0fdf4}.heritage-item.learning{background:#fefce8}.heritage-status-icon{font-size:1rem;flex-shrink:0}.heritage-item .heritage-name{flex:1;font-size:.85rem;color:#374151}.heritage-item .heritage-accuracy{font-size:.8rem;font-weight:600;color:#6b7280}.heritage-item .heritage-accuracy.good{color:#10b981}.heritage-item .heritage-accuracy.bad{color:#ef4444}.progress-container{width:100%;max-width:600px;margin:0 auto .75rem;flex-shrink:0}.progress-text{text-align:center;font-size:.8125rem;font-weight:600;color:#64748b;margin-bottom:.375rem;letter-spacing:-.01em}.progress-bar{height:6px;background-color:#e2e8f0cc;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 2px #0000000d}.progress-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#6366f1);border-radius:6px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #4f46e54d}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}.app{height:100vh;height:100dvh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f8fafc,#e0e7ff);overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app-header{background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;padding:.75rem 1rem;text-align:center;flex-shrink:0;box-shadow:0 2px 8px #4f46e526}.app-title{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.app-main{flex:1;display:flex;flex-direction:column;padding:.75rem;overflow:hidden;min-height:0}.app-footer{background-color:#0f172a08;color:#64748b;text-align:center;padding:.5rem;font-size:.75rem;flex-shrink:0;border-top:1px solid rgba(148,163,184,.1)}.app-footer p{margin:0}
