.landing-page{min-height:100vh;background:#fff;overflow-x:hidden}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{font-size:2.5rem;font-weight:700;color:#1f2937;margin:0 0 .75rem;letter-spacing:-.02em}.section-header p{font-size:1.1rem;color:#6b7280;margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;color:inherit;min-height:44px}.btn i{font-size:1.25rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 10px 25px -5px #667eea66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 15px 35px -5px #667eea80}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.btn-secondary:hover{background:#f5f3ff}.btn-secondary:active{background:#ede9fe}.btn-large{padding:1rem 2rem;font-size:1.1rem}.hero-section{position:relative;padding:6rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;opacity:.1;z-index:0}.hero-shape{position:absolute;border-radius:50%;background:#fff}.hero-shape-1{width:400px;height:400px;top:-100px;right:-100px}.hero-shape-2{width:300px;height:300px;bottom:-50px;left:50px}.hero-shape-3{width:200px;height:200px;top:50%;right:10%}.hero-content{max-width:900px;margin:0 auto;position:relative;z-index:1;text-align:center}.hero-badge{display:inline-block;background:#fff3;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:999px;font-size:.9rem;font-weight:600;margin-bottom:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-title{font-size:3.5rem;font-weight:800;margin:0 0 1.5rem;line-height:1.2;letter-spacing:-.02em}.hero-subtitle{font-size:1.3rem;margin:0 0 2rem;opacity:.9;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2rem;margin-top:3rem}.stat{text-align:center}.stat-value{font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:.9rem;opacity:.8}.features-section{padding:6rem 1.5rem;background:#f9fafb}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{background:#fff;padding:2rem;border-radius:12px;border:1px solid #e5e7eb;transition:all .3s ease;text-align:center}.feature-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0000001a;border-color:#667eea}.feature-icon{font-size:3rem;color:#667eea;margin-bottom:1rem}.feature-card h3{font-size:1.3rem;font-weight:700;color:#1f2937;margin:0 0 .75rem}.feature-card p{color:#6b7280;margin:0;line-height:1.6;font-size:.95rem}.demo-section{padding:6rem 1.5rem;background:#fff}.steps{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;max-width:1000px;margin:0 auto}.step{flex:1;min-width:250px;text-align:center}.step-number{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.8rem;font-weight:700;margin-bottom:1rem}.step h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.step p{color:#6b7280;margin:0;font-size:.95rem}.step-arrow{display:flex;align-items:center;justify-content:center;font-size:2rem;color:#667eea;flex-shrink:0}@media (max-width: 768px){.steps{gap:1rem}.step-arrow{display:none}.step{width:100%}}.usecases-section{padding:6rem 1.5rem;background:#f9fafb}.usecases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.usecase-card{background:#fff;padding:2rem;border-radius:12px;border:1px solid #e5e7eb;text-align:center;transition:all .3s ease}.usecase-card:hover{transform:scale(1.02);box-shadow:0 15px 35px #00000014}.usecase-icon{font-size:3rem;color:#764ba2;margin-bottom:1rem}.usecase-card h3{font-size:1.15rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.usecase-card p{color:#6b7280;margin:0;font-size:.9rem;line-height:1.6}.cta-section{padding:6rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.cta-content h2{font-size:2.5rem;font-weight:700;margin:0 0 1rem;letter-spacing:-.02em}.cta-content p{font-size:1.1rem;margin:0 0 2rem;opacity:.9}.faq-section{padding:6rem 1.5rem;background:#fff}.faq-list{max-width:700px;margin:0 auto}.faq-item{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1rem;overflow:hidden;transition:all .3s ease}.faq-item.expanded{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#fff;border:none;font-size:1rem;font-weight:600;color:#1f2937;cursor:pointer;transition:background .2s ease;text-align:left}.faq-question:hover{background:#f9fafb}.faq-question i{transition:transform .3s ease;color:#667eea}.faq-item.expanded .faq-question i{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease;border-top:1px solid #e5e7eb}.faq-item.expanded .faq-answer{max-height:500px}.faq-answer p{padding:1.25rem;margin:0;color:#6b7280;line-height:1.7}.footer-cta{padding:4rem 1.5rem;background:#f9fafb;border-top:1px solid #e5e7eb}.footer-cta-content{max-width:500px;margin:0 auto;text-align:center}.footer-cta-content h3{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.footer-cta-content p{color:#6b7280;margin:0 0 1.5rem}@media (max-width: 768px){.hero-section{padding:4rem 1.5rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.05rem}.section-header h2{font-size:2rem}.features-grid,.usecases-grid{grid-template-columns:1fr}.hero-buttons{flex-direction:column}.btn{width:100%}.features-section,.demo-section,.usecases-section,.faq-section,.cta-section{padding:4rem 1.5rem}.cta-content h2{font-size:1.8rem}}@media (max-width: 480px){.hero-section{padding:3rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:.95rem}.section-header h2{font-size:1.75rem}.section-header{margin-bottom:2rem}.features-grid,.usecases-grid{grid-template-columns:1fr;gap:1rem}.feature-card,.usecase-card{padding:1.5rem}.hero-stats{gap:1rem}.stat-value{font-size:1.4rem}.stat-label{font-size:.8rem}.faq-question{padding:1rem}.faq-answer p{padding:1rem;font-size:.9rem}.btn{padding:.75rem 1.25rem;font-size:.95rem}.btn i{font-size:1rem}}.wikipedia-panel{display:flex;flex-direction:column;gap:.75rem}.wiki-form{display:grid;gap:.75rem}.wiki-form label{display:flex;flex-direction:column;gap:.5rem}.wiki-form input,.wiki-form select{padding:.5rem .75rem;border:1px solid var(--border-color, #ccc);border-radius:6px;font-size:1rem}.wiki-form input:disabled,.wiki-form select:disabled{background:#0000000d}.wiki-form button{justify-self:flex-start}@media (max-width: 720px){.wikipedia-panel,.wiki-form{gap:.5rem}}.accordion{display:flex;flex-direction:column;gap:.75rem}.accordion-item{border-radius:16px;background:#ffffffd9;box-shadow:0 10px 32px -24px #0f172a73;overflow:hidden;border:1px solid rgba(148,163,184,.25);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.accordion-item.open{border-color:#2563eb59;box-shadow:0 24px 60px -40px #2563eb99}.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:1.15rem 1.35rem;border:none;background:transparent;color:inherit;text-align:left;cursor:pointer}.accordion-trigger:focus-visible{outline:3px solid rgba(37,99,235,.55);outline-offset:2px}.accordion-trigger-text{display:flex;flex-direction:column;gap:.35rem}.accordion-trigger-text h3{margin:0;font-size:1.05rem;font-weight:700;color:#1f2937}.accordion-trigger-text p{margin:0;font-size:.85rem;color:#4b5563}.accordion-trigger-meta{display:flex;align-items:center;gap:.6rem}.accordion-badge{background:#2563eb1f;color:#1d4ed8;font-weight:600;padding:.25rem .65rem;border-radius:999px;font-size:.82rem}.accordion-icon{font-size:1.2rem;color:#0f172a}.accordion-panel{border-top:1px solid rgba(148,163,184,.2)}.accordion-content{padding:1.15rem 1.35rem 1.35rem;display:flex;flex-direction:column;gap:1rem}.accordion-content .panel.panel-embedded{background:transparent;box-shadow:none;padding:0}.accordion-content .panel.panel-embedded .panel-inline-meta{display:flex;justify-content:flex-end;margin-bottom:.35rem}.accordion-content .panel.panel-embedded textarea{border-radius:12px;border:1px solid #d1d5db;background:#fff}.accordion-content .panel.panel-embedded button{margin-top:.75rem}@media (max-width: 720px){.accordion-item{border-radius:12px}.accordion-trigger,.accordion-content{padding:1rem}}.page-shell{min-height:calc(100vh - 160px);background-color:#f3f4f6;padding:3rem 1.5rem}.page-container{max-width:960px;margin:0 auto;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #0f172a14;padding:3rem 3rem 4rem}.page-container h1{margin-top:0;font-size:2rem;color:#111827;border-bottom:3px solid #3b82f6;padding-bottom:.75rem;margin-bottom:2rem}.page-container h2{font-size:1.25rem;margin-top:2.5rem;margin-bottom:1rem;color:#1f2937}.page-container p,.page-container li{color:#334155;line-height:1.8;font-size:.95rem}.page-container ul{padding-left:1.25rem}.page-meta{display:inline-block;background-color:#e0f2fe;color:#0369a1;padding:.5rem 1rem;border-radius:9999px;font-size:.85rem;margin-bottom:1.5rem}.page-back{margin-bottom:1.5rem}.page-back-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;background-color:#1d4ed8;color:#f8fafc;font-weight:600;text-decoration:none;box-shadow:0 10px 25px -15px #2563eba6;transition:transform .2s ease,box-shadow .2s ease}.page-back-link:hover{transform:translateY(-1px);box-shadow:0 16px 30px -20px #2563ebbf}.page-back-link:focus{outline:3px solid rgba(59,130,246,.35);outline-offset:2px}@media (max-width: 768px){.page-shell{padding:2rem 1rem}.page-container{padding:2rem 1.5rem 3rem}}.app-footer{margin-top:auto;background-color:#111827;color:#f9fafb}[data-theme=light] .app-footer{background-color:#f5f7fa;color:#111827}.footer-inner{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap}.footer-links a{color:#e5e7eb;text-decoration:none;font-size:.875rem}.footer-links a:hover{text-decoration:underline}[data-theme=light] .footer-links a{color:#374151}.footer-copy{font-size:.75rem;color:#9ca3af}[data-theme=light] .footer-copy{color:#6b7280}.footer-share{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.footer-share-label{font-size:.85rem;color:#d1d5db}.share-link{color:#fbbf24;font-weight:600;text-decoration:none;font-size:.85rem}.share-link:hover{text-decoration:underline}.share-button{padding:.35rem .9rem;border-radius:999px;border:1px solid rgba(248,250,252,.3);background:transparent;color:#f9fafb;font-size:.85rem;cursor:pointer;transition:background .2s ease}.share-button:hover{background:#f9fafc14}.theme-toggle button{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s ease}.theme-toggle button:hover{background:#ffffff1a}[data-theme=light] .theme-toggle button:hover{background:#0000001a}.product-hunt-badge{display:flex;align-items:center}.product-hunt-badge a{display:inline-block;transition:opacity .2s ease}.product-hunt-badge a:hover{opacity:.8}.product-hunt-badge img{max-width:100%;height:auto}@media (max-width: 768px){.footer-inner{flex-direction:column;align-items:flex-start}.product-hunt-badge{margin-top:1rem}.product-hunt-badge img{width:200px;height:auto}}@media (max-width: 480px){.product-hunt-badge img{width:180px}}.app-shell{display:flex;flex-direction:column;min-height:100vh;background:#fff;font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,Yu Gothic,sans-serif}.hero{padding:2rem 3rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;border-bottom:2px solid #e5e7eb;background:#f8fafc}.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}.hero-copy h1{margin:0 0 .25rem;font-size:2rem;color:#1f2937;font-weight:700}.hero-copy p{margin:0;color:#4b5563;font-size:1.1rem}.hero-actions{display:flex;gap:.75rem}.hero-actions button{padding:.75rem 1.5rem;border-radius:8px;border:2px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;min-height:44px}.hero-actions button:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px)}.hero-actions button:focus{outline:3px solid #3b82f6;outline-offset:2px}.hero-actions .print-button{background:#059669;border-color:#059669}.hero-actions .print-button:hover{background:#047857;border-color:#047857}.layout{display:grid;grid-template-columns:400px 1fr;gap:2rem;padding:2rem 3rem 4rem}.left-column,.right-column{display:flex;flex-direction:column;gap:1.5rem}.panel{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e5e7eb;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.panel h2{margin:0;font-size:1.3rem;color:#1f2937;font-weight:600}.panel textarea{width:100%;border-radius:8px;border:2px solid #d1d5db;padding:1rem;font-size:1rem;font-family:inherit;resize:vertical;min-height:120px}.panel textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.panel button{align-self:flex-start;padding:.75rem 1.5rem;border-radius:8px;border:2px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;min-height:44px;transition:all .2s ease}.panel button:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px)}.panel button:focus{outline:3px solid #3b82f6;outline-offset:2px}.panel button:disabled{opacity:.6;cursor:not-allowed;transform:none}.counter{font-size:.9rem;color:#6b7280}.counter.error{color:#dc2626;font-weight:600}.help-text{margin:0;color:#6b7280;font-size:.9rem}.upload-button{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:8px;background:#f97316;border:2px solid #f97316;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;min-height:44px;transition:all .2s ease}.upload-button.disabled{opacity:.6;cursor:not-allowed;pointer-events:none;transform:none}.upload-button:hover:not(.disabled){background:#ea580c;border-color:#ea580c;transform:translateY(-1px)}.upload-button:focus{outline:3px solid #fb923c;outline-offset:2px}.upload-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.upload-actions button{margin:0}.panel .button-outline{background:transparent;color:#1f2937;border-color:#d1d5db}.panel .button-outline:hover:not(:disabled){background:#f8fafc;border-color:#9ca3af}.status-message{margin:0;color:#059669;font-weight:600;font-size:1rem}.progress-container{background:#fff;padding:1rem;border-radius:8px;border:2px solid #e5e7eb;margin-bottom:1rem}.progress-bar{height:12px;background:#2563eb;border-radius:6px;transition:width .5s ease}.progress-text{display:block;margin-top:.5rem;font-size:.9rem;color:#374151}.error-message{margin:0;color:#dc2626;font-weight:600;font-size:1rem}.error-message.compact{font-size:.9rem}.filters .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.filters label{display:flex;flex-direction:column;gap:.4rem;font-size:1rem;color:#374151;font-weight:500}.filters select,.filters input{border-radius:8px;border:2px solid #d1d5db;padding:.75rem;font-size:1rem;font-family:inherit;min-height:44px}.filters select:focus,.filters input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.filters input[type=range]{padding:0}.timeline-section{background:#fff;border-radius:12px;border:2px solid #e5e7eb;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.timeline-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.timeline-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.category-summary{font-size:.9rem;color:#6b7280}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.95rem;color:#1f2937}th{text-align:left;font-size:.9rem;color:#374151;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:2px solid #e5e7eb}th,td{padding:.75rem .5rem;border-bottom:1px solid #e5e7eb;vertical-align:top}.timeline-section.striped tbody tr:nth-child(odd){background:#f8fafc}.importance-low{background:linear-gradient(90deg,#ef44441a,#ef44440d)}.importance-medium{background:linear-gradient(90deg,#f973161a,#f973160d)}.importance-high{background:linear-gradient(90deg,#eab3081a,#eab3080d)}.importance-very-high{background:linear-gradient(90deg,#22c55e1a,#22c55e0d)}.date-cell{display:flex;flex-direction:column;gap:.25rem}.date-cell .iso{font-size:.8rem;color:#6b7280}.description{margin:.25rem 0 0;color:#4b5563;line-height:1.5}.chip{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:999px;background:#e5e7eb;color:#374151;font-weight:500;font-size:.85rem}.stack{display:flex;flex-direction:column;gap:.4rem}.actions button{padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:.25rem;min-height:36px;transition:all .2s ease}.actions button:hover{background:#f8fafc;border-color:#9ca3af}.actions button:focus{outline:2px solid #2563eb;outline-offset:2px}.actions button.secondary{background:#f8fafc;border-color:#e5e7eb}.actions button.danger{background:#dc2626;border-color:#dc2626;color:#fff}.actions button.danger:hover{background:#b91c1c;border-color:#b91c1c}.placeholder{margin:2rem 0 0;color:#6b7280;text-align:center;font-size:1.1rem}@media (max-width: 1100px){.layout{grid-template-columns:1fr}.left-column,.right-column{order:initial}}@media (max-width: 768px){.hero{flex-direction:column;align-items:flex-start;gap:1.25rem;padding:1.75rem 1.5rem 1.25rem}.hero-top{flex-direction:column;align-items:flex-start;gap:1rem}.hero-actions{width:100%;flex-wrap:wrap;justify-content:flex-start}.hero-actions button{flex:1 1 calc(50% - .5rem);min-width:140px}.layout{padding:1.75rem 1.5rem 3rem;gap:1.5rem}.panel{padding:1.25rem}.filters .grid{grid-template-columns:1fr}.timeline-section{padding:1.25rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.panel textarea{min-height:120px}.upload-actions{flex-direction:column;align-items:stretch}.upload-actions button{width:100%}}@media (max-width: 480px){.hero{padding:1.5rem 1.25rem 1rem}.hero-copy h1{font-size:1.6rem}.hero-actions{gap:.5rem}.hero-actions button{flex:1 1 100%}.panel{padding:1rem;gap:.75rem}.panel textarea{min-height:160px}.layout{padding:1.5rem 1.25rem 2.5rem}table{font-size:.85rem}th,td{padding:.6rem .35rem}.panel button{width:100%}.filters label{font-size:.9rem}.chip{font-size:.8rem;padding:.2rem .5rem}}.app-root{min-height:100vh;display:flex;flex-direction:column;background:#fff}.timeline-chart-container{background:#fff;border-radius:12px;border:2px solid #e5e7eb;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem}.timeline-chart-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.timeline-chart-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.timeline-actions{display:flex;align-items:center;gap:1rem}.zoom-controls{display:flex;align-items:center;gap:.5rem;background:#f8fafc;border-radius:8px;padding:.25rem;border:1px solid #e5e7eb}.zoom-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:36px;min-height:36px}.zoom-button:hover:not(:disabled){background:#e5e7eb;color:#374151}.zoom-button:disabled{opacity:.5;cursor:not-allowed}.timeline-filters{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-label{font-size:.875rem;font-weight:600;color:#374151}.filter-select{padding:.5rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:.875rem;color:#374151}.filter-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.filter-range{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;-webkit-appearance:none}.filter-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#2563eb;cursor:pointer}.filter-range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#2563eb;cursor:pointer;border:none}.timeline-range{font-size:.9rem;color:#6b7280}.save-image-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;font-weight:500;cursor:pointer;font-size:.9rem;transition:all .2s ease;min-height:36px}.save-image-button:hover{background:#f8fafc;border-color:#9ca3af}.save-image-button:focus{outline:2px solid #2563eb;outline-offset:2px}.save-html-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;font-weight:500;cursor:pointer;font-size:.9rem;transition:all .2s ease;min-height:36px}.save-html-button:hover{background:#f8fafc;border-color:#9ca3af}.save-html-button:focus{outline:2px solid #2563eb;outline-offset:2px}.timeline-chart{position:relative;height:400px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;padding:2rem 1rem 1rem;overflow:hidden}.timeline-axis{position:absolute;bottom:0;left:0;right:0;height:40px;border-top:2px solid #d1d5db}.timeline-mark{position:absolute;bottom:0;display:flex;flex-direction:column;align-items:center;transform:translate(-50%)}.timeline-year{font-size:.8rem;color:#6b7280;font-weight:500;margin-bottom:.25rem}.timeline-tick{width:1px;height:8px;background:#d1d5db}.timeline-bar{position:relative;height:calc(100% - 40px)}.timeline-year-group{position:absolute;bottom:0;display:flex;flex-direction:column;gap:.25rem;transform:translate(-50%)}.timeline-event{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:20px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;min-width:120px;max-width:200px;opacity:0;transform:translateY(20px);animation:fadeInUp .6s ease forwards}.timeline-event:nth-child(1){animation-delay:.1s}.timeline-event:nth-child(2){animation-delay:.2s}.timeline-event:nth-child(3){animation-delay:.3s}.timeline-event:nth-child(4){animation-delay:.4s}.timeline-event:nth-child(5){animation-delay:.5s}.timeline-event:nth-child(6){animation-delay:.6s}.timeline-event:nth-child(7){animation-delay:.7s}.timeline-event:nth-child(8){animation-delay:.8s}.timeline-event:nth-child(9){animation-delay:.9s}.timeline-event:nth-child(10){animation-delay:1s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.timeline-event:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.event-dot{width:8px;height:8px;border-radius:50%;background:#fffc;flex-shrink:0}.event-content{flex:1;min-width:0}.event-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.event-category{font-size:.75rem;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e5e7eb}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937;line-height:1.3}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:44px;min-height:44px}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:1.5rem;flex:1}.event-meta-grid{display:grid;gap:1rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:.875rem;font-weight:600;color:#374151}.meta-value{font-size:1rem;color:#1f2937}.meta-secondary{font-size:.875rem;color:#6b7280}.importance-display{display:flex;align-items:center;gap:.75rem}.importance-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.event-description-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.event-description-section h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#374151}.event-description{margin:0;line-height:1.6;color:#4b5563;white-space:pre-wrap}.modal-footer{padding:1rem 1.5rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.modal-button{padding:.75rem 1.5rem;border-radius:8px;border:2px solid #d1d5db;background:#fff;color:#374151;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:44px}.modal-button.secondary{background:#f8fafc;border-color:#e5e7eb}.modal-button.secondary:hover{background:#e5e7eb;border-color:#9ca3af}@media (max-width: 768px){.modal-backdrop{padding:.5rem}.modal-content{max-width:100%;margin:auto}.modal-header{padding:1rem 1rem .75rem}.modal-body{padding:1rem}.modal-footer{padding:.75rem 1rem 1rem}}.timeline-legend h4{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#1f2937}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#4b5563}.timeline-event:focus{outline:3px solid #2563eb;outline-offset:2px}@media (max-width: 768px){.timeline-chart{height:300px;padding:1.5rem .75rem 1rem}.timeline-event{min-width:100px;max-width:160px;padding:.4rem .6rem;font-size:.8rem}.event-title{font-size:.8rem}.event-category{font-size:.7rem}.timeline-year{font-size:.75rem}.legend-items{gap:.75rem}.legend-item{font-size:.8rem}}@media (max-width: 480px){.timeline-chart{height:250px;padding:1rem .5rem .75rem}.timeline-event{min-width:80px;max-width:120px;padding:.3rem .5rem;font-size:.75rem}.event-dot{width:6px;height:6px}.timeline-actions{flex-direction:column;align-items:stretch;gap:.5rem}.timeline-range{font-size:.8rem;text-align:center}}.view-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.view-tab{padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem}.view-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}.view-tab:hover:not(.active){background:#f8fafc;border-color:#9ca3af}.view-tab:focus{outline:2px solid #2563eb;outline-offset:2px}.save-message{font-size:.875rem;font-weight:600;padding:.5rem .75rem;border-radius:6px;animation:slideIn .3s ease}.save-message.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.save-message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}:root{font-family:Noto Sans JP,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--heading-font-family: "M PLUS Rounded 1c", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;color:#111827;background-color:#f5f7fa}[data-theme=dark]{color:#e5e7eb;background-color:#111827}[data-theme=dark] body{background-color:#111827}body{margin:0;min-height:100vh}*{box-sizing:border-box}.app-root{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#f5f7fa,#fff)}h1,h2,h3,h4,h5,h6{font-family:var(--heading-font-family);letter-spacing:.02em}.accordion-trigger-text h3,.panel h2,.timeline-header h2,.hero-copy h1{font-family:var(--heading-font-family)}
