.home{min-height:100vh;padding:20px;display:flex;align-items:center;justify-content:center}.container{max-width:1200px;width:100%;margin:0 auto}.header{text-align:center;margin-bottom:3rem}.title{font-size:3.5rem;font-weight:800;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.subtitle{font-size:1.25rem;color:#fffffff2;font-weight:300}.jca-highlight{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-radius:20px;padding:3rem;margin-bottom:3rem;text-align:center;box-shadow:0 20px 60px #0000004d;border:3px solid rgba(255,255,255,.2);position:relative;overflow:hidden}.jca-highlight:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.jca-badge{display:inline-block;background:#fbbf24;color:#1e3a8a;padding:.5rem 1.5rem;border-radius:50px;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;position:relative;z-index:1}.jca-highlight h2{font-size:2.5rem;color:#fff;margin-bottom:1rem;font-weight:700;position:relative;z-index:1}.jca-description{font-size:1.125rem;color:#fffffff2;margin-bottom:2rem;position:relative;z-index:1}.jca-button{display:inline-block;background:#fff;color:#1e3a8a;padding:1rem 2.5rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:1.125rem;transition:all .3s ease;box-shadow:0 4px 15px #0003;position:relative;z-index:1}.jca-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d;background:#fbbf24}.regions-section{background:#fffffff2;border-radius:20px;padding:3rem;margin-bottom:2rem;box-shadow:0 20px 60px #0003}.section-title{font-size:2rem;color:#1e3a8a;margin-bottom:.5rem;font-weight:700;text-align:center}.section-description{font-size:1.125rem;color:#64748b;text-align:center;margin-bottom:2.5rem}.regions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.region-card{background:#fff;border:2px solid #e2e8f0;border-radius:15px;padding:2rem;text-decoration:none;color:inherit;transition:all .3s ease;position:relative;overflow:hidden}.region-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.region-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026;border-color:#667eea}.region-card:hover:before{transform:scaleX(1)}.region-name{font-size:1.5rem;color:#1e293b;margin-bottom:.75rem;font-weight:700}.region-description{font-size:1rem;color:#64748b;line-height:1.6;margin-bottom:1rem}.region-arrow{font-size:1.5rem;color:#667eea;font-weight:700;transition:transform .3s ease;display:inline-block}.region-card:hover .region-arrow{transform:translate(5px)}.region-card-disabled{cursor:default;opacity:.85}.region-card-disabled:hover{transform:none;box-shadow:none;border-color:#e2e8f0}.region-card-disabled:before{display:none}.footer{text-align:center;color:#ffffffe6;padding:2rem 0}.footer p{margin-bottom:.5rem;font-size:.95rem}.footer-note{font-size:.875rem;color:#ffffffbf}@media (max-width: 768px){.title{font-size:2.5rem}.subtitle{font-size:1rem}.jca-highlight{padding:2rem}.jca-highlight h2{font-size:1.75rem}.jca-description{font-size:1rem}.regions-section{padding:2rem}.section-title{font-size:1.5rem}.section-description{font-size:1rem}.regions-grid{grid-template-columns:1fr}}@media (max-width: 480px){.home{padding:10px}.title{font-size:2rem}.jca-button{padding:.875rem 2rem;font-size:1rem}.region-card{padding:1.5rem}}.kansai-page{min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.kansai-container{max-width:1000px;width:100%;margin:0 auto;padding-bottom:2rem}.kansai-header{text-align:center;margin-bottom:3rem;padding-top:2rem}.kansai-header h1{font-size:3rem;font-weight:800;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.kansai-header .subtitle{font-size:1.25rem;color:#fffffff2;font-weight:300}.content-card{background:#fff;border-radius:15px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 10px 30px #0003;transition:transform .3s ease,box-shadow .3s ease}.content-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #0000004d}.card-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.content-card h2{font-size:1.75rem;color:#1e3a8a;margin-bottom:1rem;font-weight:700;text-align:center}.card-description{font-size:1.125rem;color:#475569;line-height:1.7;margin-bottom:1.5rem;text-align:center}.card-actions{display:flex;justify-content:center;gap:1rem}.action-button{display:inline-block;padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:1.125rem;transition:all .3s ease;box-shadow:0 4px 15px #0003}.action-button.primary{background:linear-gradient(135deg,#059669,#10b981);color:#fff}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #05966966;background:linear-gradient(135deg,#047857,#059669)}.play-card{border-top:5px solid #3b82f6}.register-card{border-top:5px solid #f59e0b}.volunteer-card{border-top:5px solid #10b981}.kansai-footer{text-align:center;padding:2rem;color:#fff;font-size:1rem}.kansai-footer a{color:#fbbf24;text-decoration:none;font-weight:600;transition:color .3s ease}.kansai-footer a:hover{color:#fde047;text-decoration:underline}@media (max-width: 768px){.kansai-header h1{font-size:2rem}.kansai-header .subtitle{font-size:1rem}.content-card{padding:1.5rem}.content-card h2{font-size:1.5rem}.card-description{font-size:1rem}.action-button{padding:.875rem 1.5rem;font-size:1rem}}.umpiring-page{min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.umpiring-container{max-width:1200px;width:100%;margin:0 auto;padding-bottom:2rem}.umpiring-header{text-align:center;margin-bottom:2rem;padding-top:2rem}.umpiring-header h1{font-size:3rem;font-weight:800;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.umpiring-header .subtitle{font-size:1.25rem;color:#fffffff2;font-weight:300}.alert-box{background:linear-gradient(135deg,#dc2626,#ef4444);border-radius:15px;padding:2rem;margin-bottom:2rem;text-align:center;box-shadow:0 10px 30px #0000004d;border:3px solid rgba(255,255,255,.3)}.alert-box h2{font-size:1.75rem;color:#fff;margin-bottom:1rem;font-weight:700}.alert-text{font-size:1.125rem;color:#fff;line-height:1.8}.alert-text strong{font-weight:800;text-decoration:underline}.action-box{background:linear-gradient(135deg,#059669,#10b981);border-radius:15px;padding:2rem;margin-bottom:2rem;text-align:center;box-shadow:0 10px 30px #0000004d}.action-box h2{font-size:1.75rem;color:#fff;margin-bottom:1rem;font-weight:700}.action-box p{font-size:1.125rem;color:#fffffff2;margin-bottom:1.5rem}.nomination-button{display:inline-block;background:#fff;color:#059669;padding:1rem 2.5rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:1.25rem;transition:all .3s ease;box-shadow:0 4px 15px #0003}.nomination-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d;background:#fbbf24}.critical-notice{background:linear-gradient(135deg,#dc2626,#b91c1c);border:4px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;box-shadow:0 8px 25px #dc262666;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#fbbf24;box-shadow:0 8px 25px #dc262666}50%{border-color:#fde047;box-shadow:0 8px 30px #dc262699}}.critical-notice h3{font-size:1.5rem;color:#fff;margin:0 0 1rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.critical-notice p{font-size:1.25rem;color:#fff;margin:.5rem 0;line-height:1.6}.critical-notice p:first-of-type{font-size:1.4rem;font-weight:800}.content-section{background:#fff;border-radius:15px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 10px 30px #0003}.content-section h2{font-size:1.75rem;color:#1e3a8a;margin-bottom:1.5rem;font-weight:700;border-bottom:3px solid #e2e8f0;padding-bottom:.75rem}.content-section h3{font-size:1.25rem;color:#1e40af;margin:1.5rem 0 1rem;font-weight:600}.course-info{background:#f8fafc;border-radius:10px;padding:1.5rem;border-left:5px solid #3b82f6}.info-row{display:flex;padding:.75rem 0;border-bottom:1px solid #e2e8f0}.info-row:last-child{border-bottom:none}.info-label{font-weight:700;color:#1e40af;min-width:100px;margin-right:1rem}.info-value{color:#334155;flex:1}.map-link{color:#3b82f6;text-decoration:none;font-weight:600;transition:color .3s ease}.map-link:hover{color:#1e40af;text-decoration:underline}.teams-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.team-category{background:#f8fafc;border-radius:10px;padding:1.5rem;border-top:4px solid #3b82f6}.team-category h3{font-size:1.25rem;color:#1e40af;margin:0 0 1rem;font-weight:600}.team-category ul{list-style:none;padding:0;margin:0}.team-category li{padding:.5rem 0;color:#334155;border-bottom:1px solid #e2e8f0}.team-category li:last-child{border-bottom:none}.team-category li.not-required{color:#64748b;font-style:italic}.team-category .note{margin-top:1rem;font-size:.875rem;color:#64748b;font-style:italic}.new-teams-note{margin-top:1.5rem;padding:1rem 1.5rem;background:#dbeafe;border-left:4px solid #3b82f6;border-radius:8px;color:#1e40af;font-size:1rem}.new-teams-note strong{font-weight:700}.important-notes ul{list-style:none;padding:0;margin:1rem 0}.important-notes li{padding:.75rem 1rem;margin-bottom:.75rem;border-left:4px solid #f59e0b;border-radius:5px;color:#78350f}.rules-section{background:#eff6ff;border:2px solid #3b82f6}.rule-box{background:#fff;padding:1.5rem;border-radius:10px;border-left:5px solid #3b82f6}.rule-box p{margin:.75rem 0;color:#334155;line-height:1.6}.learning-section{background:#f0fdf4}.learning-intro{font-size:1.125rem;color:#166534;font-weight:600;margin-bottom:1.5rem}.course-order{display:flex;flex-direction:column;align-items:center;margin:2rem 0;padding:1.5rem;background:#fff;border-radius:10px}.course-step{display:flex;align-items:center;gap:1rem;background:#dcfce7;padding:1rem 2rem;border-radius:50px;border:2px solid #22c55e;min-width:300px}.step-number{background:#22c55e;color:#fff;width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem}.step-name{font-weight:600;color:#166534;flex:1}.arrow-down{font-size:2rem;color:#22c55e;margin:.5rem 0}.signup-steps{background:#fff;padding:1.5rem 2rem;border-radius:10px;margin:1rem 0;border-left:5px solid #22c55e}.signup-steps li{margin:.75rem 0;color:#334155;line-height:1.6}.signup-steps a{color:#3b82f6;font-weight:600;text-decoration:none}.signup-steps a:hover{text-decoration:underline}.japanese-note{background:#dbeafe;padding:1rem;border-radius:8px;margin-top:1rem;color:#1e40af;border-left:4px solid #3b82f6}.list-intro{color:#64748b;margin-bottom:1.5rem}.umpires-table{overflow-x:auto}.umpires-table table{width:100%;border-collapse:collapse;margin-top:1rem}.umpires-table thead{background:#1e40af;color:#fff}.umpires-table th{padding:1rem;text-align:left;font-weight:600}.umpires-table td{padding:.75rem 1rem;border-bottom:1px solid #e2e8f0;color:#334155}.umpires-table tbody tr:hover{background:#f8fafc}.umpires-table tbody tr:nth-child(2n){background:#f8fafc}.contact-section{background:#f0f9ff;border:2px solid #3b82f6}.contact-list{list-style:none;padding:0;margin:1rem 0}.contact-list li{padding:.5rem 0;color:#334155}.contact-list a{color:#3b82f6;text-decoration:none;font-weight:600}.contact-list a:hover{text-decoration:underline}.umpiring-footer{text-align:center;color:#ffffffe6;padding:2rem 0;margin-top:2rem}.umpiring-footer p{font-size:.95rem;margin:.25rem 0}.footer-address{font-size:.875rem;color:#ffffffbf}@media (max-width: 768px){.umpiring-header h1{font-size:2rem}.umpiring-header .subtitle{font-size:1rem}.alert-box,.action-box,.content-section{padding:1.5rem}.alert-box h2,.action-box h2,.content-section h2{font-size:1.5rem}.teams-grid{grid-template-columns:1fr}.course-step{min-width:auto;width:100%}.umpires-table{font-size:.875rem}.umpires-table th,.umpires-table td{padding:.5rem}}@media (max-width: 480px){.umpiring-page{padding:10px}.umpiring-header h1{font-size:1.5rem}.nomination-button{padding:.875rem 1.5rem;font-size:1rem}.info-row{flex-direction:column}.info-label{margin-bottom:.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}#root{min-height:100vh}
