:root{--color-primary: #003366;--color-secondary: #00ACC1;--color-accent: #f0a500;--color-text: #333333;--color-text-light: #ffffff;--color-background: #ffffff;--color-background-alt: #f5f5f5;--color-border: #e0e0e0;--font-base: "Noto Sans JP", sans-serif;--font-heading: "Montserrat", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 2rem;--spacing-xl: 4rem;--transition-fast: .2s ease;--transition-normal: .3s ease}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-base);color:var(--color-text);background-color:var(--color-background);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.3}a{text-decoration:none;color:inherit;transition:opacity var(--transition-fast)}a:hover{opacity:.8}ul{list-style:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;border:none;background:none;font-family:inherit}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeIn .5s ease-out forwards}.header{position:fixed;top:0;left:0;width:100%;height:80px;background-color:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;box-shadow:0 2px 10px #0000000d;display:flex;align-items:center}.header-container{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.logo h1{font-size:1.5rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px}.nav-list{display:flex;gap:var(--spacing-lg);align-items:center}.nav-list a{font-size:.95rem;font-weight:500;color:var(--color-text);position:relative}.nav-list a:not(.btn):after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background-color:var(--color-secondary);transition:width .3s ease}.nav-list a:not(.btn):hover:after,.nav-list a.active:not(.btn):after{width:100%}.btn-primary-outline{border:2px solid var(--color-primary);padding:.5rem 1.2rem;border-radius:4px;color:var(--color-primary)!important;font-weight:600;transition:all .3s ease}.btn-primary-outline:hover{background-color:var(--color-primary);color:#fff!important;opacity:1}.menu-toggle{display:none;flex-direction:column;cursor:pointer;gap:6px;z-index:1001}.menu-toggle .bar{width:25px;height:3px;background-color:var(--color-text);transition:all .3s ease;border-radius:3px}@media (max-width: 900px){.menu-toggle{display:flex}.menu-toggle.open .bar:nth-child(1){transform:rotate(45deg) translate(5px,6px)}.menu-toggle.open .bar:nth-child(2){opacity:0}.menu-toggle.open .bar:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}.nav{position:fixed;top:0;right:-100%;width:100%;height:100vh;background-color:#fffffffa;display:flex;justify-content:center;align-items:center;transition:right .4s ease;box-shadow:-5px 0 15px #0000001a}.nav.active{right:0}.nav-list{flex-direction:column;text-align:center;gap:2rem}.nav-list a{font-size:1.2rem;color:var(--color-text)}}.footer{background-color:var(--color-primary);color:#fff;padding:var(--spacing-xl) 0 var(--spacing-lg);margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.footer-col h3{font-family:var(--font-heading);margin-bottom:var(--spacing-md);color:var(--color-secondary)}.footer-col h4{margin-bottom:var(--spacing-md);font-size:1.1rem}.footer-col ul li{margin-bottom:var(--spacing-sm)}.footer-col a{opacity:.8}.footer-col a:hover{opacity:1;color:var(--color-secondary)}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:var(--spacing-lg);text-align:center;font-size:.9rem;opacity:.6}@media (max-width: 768px){.footer-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.layout{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:80px}.hero{position:relative;height:100vh;min-height:600px;background-image:url(https://images.unsplash.com/photo-1544551763-46a013bb70d5?q=80&w=2070&auto=format&fit=crop);background-size:cover;background-position:center;background-attachment:fixed;display:flex;align-items:center;justify-content:center;color:#fff;margin-top:-80px;padding-top:80px}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#003366b3,#00acc166);z-index:1}.hero-content{position:relative;z-index:2;text-align:center;max-width:800px}.hero-title{display:flex;flex-direction:column;margin-bottom:var(--spacing-lg)}.hero-title-main{font-family:var(--font-heading);font-size:4rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--spacing-xs);text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-title-sub{font-size:1.5rem;font-weight:500;opacity:.9}.hero-description{font-size:1.1rem;line-height:1.8;margin-bottom:var(--spacing-xl);opacity:.9}.hero-actions{display:flex;gap:var(--spacing-md);justify-content:center}.btn{display:inline-block;padding:.8rem 2rem;border-radius:50px;font-weight:600;text-align:center;transition:all .3s ease;cursor:pointer}.btn-primary{background-color:var(--color-secondary);color:#fff;box-shadow:0 4px 15px #00acc166}.btn-primary:hover{background-color:#00bcd4;transform:translateY(-2px);box-shadow:0 6px 20px #00acc199}.btn-outline-white{border:2px solid white;color:#fff}.btn-outline-white:hover{background-color:#fff;color:var(--color-primary)}@media (max-width: 768px){.hero-title-main{font-size:2.5rem}.hero-title-sub{font-size:1.1rem}.hero-actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:280px}}.section{padding:5rem 1rem}.section-white{background-color:var(--color-background)}.section-alt{background-color:var(--color-background-alt)}.section-header{text-align:center;margin-bottom:3rem;max-width:800px;margin-left:auto;margin-right:auto}.section-title{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem;position:relative;display:inline-block}.section-title:after{content:"";display:block;width:60px;height:3px;background-color:var(--color-secondary);margin:.5rem auto 0}.section-subtitle{font-size:1rem;color:#666;margin-top:1rem}.hero-placeholder{height:80vh;background:linear-gradient(#0369,#0369),url(https://images.unsplash.com/photo-1544551763-46a013bb70d5?q=80&w=2070&auto=format&fit=crop);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center}.hero-placeholder h2{font-size:3rem;margin-bottom:1rem}.section-spacing{padding:4rem 1rem}.page-header{background:linear-gradient(#036c,#036c),url(https://images.unsplash.com/photo-1682687220063-4742bd7fd538?q=80&w=2070&auto=format&fit=crop);background-size:cover;background-position:center;color:#fff;padding:8rem 0 4rem;text-align:center;margin-bottom:2rem}.page-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;letter-spacing:2px}.page-header p{font-size:1.1rem;opacity:.9}.intro-content{max-width:800px;margin:0 auto;text-align:center;line-height:2;font-size:1.05rem}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:1rem}.course-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 20px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.course-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.course-image{height:200px;background-size:cover;background-position:center}.rank-ow{background-image:url(/images/course/clownfish.png)}.rank-aow{background-image:url(https://images.unsplash.com/photo-1544551763-46a013bb70d5?q=80&w=2070&auto=format&fit=crop)}.course-content{padding:2rem}.course-content h3{color:var(--color-primary);margin-bottom:.5rem;font-size:1.25rem}.course-badge{display:inline-block;background-color:var(--color-secondary);color:#fff;font-size:.8rem;padding:.2rem .8rem;border-radius:50px;margin-bottom:1rem}.course-content p{font-size:.95rem;color:#666;margin-bottom:1.5rem;line-height:1.6}.course-features{border-top:1px solid var(--color-border);padding-top:1rem}.course-features li{font-size:.9rem;color:var(--color-text);margin-bottom:.5rem;padding-left:1.5rem;position:relative}.course-features li:before{content:"✓";position:absolute;left:0;color:var(--color-secondary);font-weight:700}.cta-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}@media (max-width: 600px){.cta-buttons{flex-direction:column;align-items:center}}.page-header-simple{background-color:var(--color-primary);color:#fff;padding:6rem 0 3rem;text-align:center}.page-header-simple h1{font-size:2rem;margin-bottom:.5rem}.flow-steps{max-width:800px;margin:0 auto;position:relative}.flow-steps:before{content:"";position:absolute;top:0;left:50px;width:4px;height:100%;background-color:var(--color-border);z-index:0}.flow-step{position:relative;margin-bottom:3rem;padding-left:120px;z-index:1}.step-number{position:absolute;left:0;top:0;width:100px;text-align:right;font-weight:700;color:var(--color-secondary);font-family:var(--font-heading);padding-right:20px}.step-number:after{content:"";position:absolute;top:5px;right:-6px;width:16px;height:16px;background-color:var(--color-secondary);border-radius:50%;border:3px solid white}.flow-step{display:flex;align-items:flex-start;margin-bottom:4rem;position:relative;padding-left:0}.flow-steps:before{left:40px}.step-number{position:absolute;top:-25px;left:12px;width:auto;font-size:.9rem;background-color:var(--color-secondary);color:#fff;padding:2px 10px;border-radius:12px;z-index:2;text-align:center}.step-content{display:flex;background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;width:100%;margin-left:80px;box-shadow:0 4px 15px #00000008;align-items:center;position:relative}.step-content:before{content:"";position:absolute;left:-10px;top:30px;border-top:10px solid transparent;border-bottom:10px solid transparent;border-right:10px solid white;filter:drop-shadow(-1px 0 0 var(--color-border))}.step-icon{font-size:2.5rem;margin-right:1.5rem;background-color:var(--color-background-alt);width:70px;height:70px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.step-text h3{margin-bottom:.5rem;color:var(--color-primary)}.step-text p{font-size:.95rem;color:#666}.flow-step:before{content:"";position:absolute;left:31px;top:35px;width:18px;height:18px;background-color:#fff;border:4px solid var(--color-primary);border-radius:50%;z-index:1}@media (max-width: 600px){.flow-steps:before{left:20px}.flow-step:before{left:11px}.step-content{margin-left:50px;flex-direction:column;text-align:center;padding:1.5rem 1rem}.step-icon{margin-right:0;margin-bottom:1rem}.step-number{left:0}}.price-table-container{overflow-x:auto}.price-table{width:100%;max-width:900px;margin:0 auto;border-collapse:collapse;background:#fff;box-shadow:0 4px 15px #0000000d}.price-table th,.price-table td{padding:1.2rem;text-align:left;border-bottom:1px solid var(--color-border)}.price-table th{background-color:var(--color-primary);color:#fff;font-weight:600;white-space:nowrap}.price-table th:nth-child(2),.price-table td:nth-child(2){white-space:nowrap;min-width:80px}.price-table tr:last-child td{border-bottom:none}.price-table tr:hover{background-color:#f9f9f9}.price-note{max-width:900px;margin:1rem auto 0;font-size:.9rem;color:#666;text-align:right}.price-cards{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.price-card{background:#fff;padding:2.5rem 2rem;border-radius:12px;width:100%;max-width:320px;text-align:center;box-shadow:0 4px 20px #0000000d;transition:transform .3s ease;border:1px solid var(--color-border)}.price-card:hover{transform:translateY(-5px)}.price-card.featured{border:2px solid var(--color-secondary);position:relative;overflow:hidden}.price-card.featured:before{content:"RECOMMENDED";position:absolute;top:15px;right:-30px;background-color:var(--color-secondary);color:#fff;padding:.3rem 2.5rem;transform:rotate(45deg);font-size:.7rem;font-weight:700}.price-card h3{font-size:1.2rem;margin-bottom:1rem;color:var(--color-text)}.price-card .price{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:1rem;font-family:var(--font-heading)}.price-card .unit{font-size:.9rem;color:#888;font-weight:400}.price-card p{font-size:.95rem;color:#666}.rental-list{max-width:800px;margin:0 auto;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 15px #0000000d}.rental-item{display:flex;justify-content:space-between;padding:1.2rem 2rem;border-bottom:1px solid var(--color-border)}.rental-item:last-child{border-bottom:none}.rental-item span:first-child{font-weight:500}.rental-item span:last-child{font-weight:700;color:var(--color-primary)}@media (max-width: 600px){.price-table{font-size:.9rem}.price-table th,.price-table td{padding:.8rem}}.staff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem;justify-content:center}.staff-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 15px #0000000d;transition:transform .3s ease;border:1px solid var(--color-border)}.staff-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.staff-image-wrapper{height:300px;overflow:hidden}.staff-image{width:100%;height:100%;object-fit:contain;transition:transform .5s ease}.staff-card:hover .staff-image{transform:scale(1.05)}.staff-content{padding:1.5rem;text-align:center}.staff-name{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-primary);margin-bottom:.2rem}.staff-title{color:var(--color-secondary);font-weight:600;font-size:.9rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px}.staff-bio{font-size:.95rem;color:#666;line-height:1.6;margin-bottom:1.5rem}.staff-specialty{display:inline-block;background-color:var(--color-background-alt);padding:.3rem .8rem;border-radius:4px;font-size:.85rem;color:var(--color-text);border:1px solid var(--color-border)}.faq-list{max-width:800px;margin:0 auto}.faq-item{border-bottom:1px solid var(--color-border);margin-bottom:1rem}.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;cursor:pointer;transition:color .3s ease}.faq-question:hover{color:var(--color-secondary)}.faq-question h3{font-size:1.1rem;font-weight:600;margin:0;padding-right:2rem;line-height:1.5}.faq-toggle{font-size:1.5rem;font-weight:300;color:var(--color-secondary);flex-shrink:0}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease;opacity:0}.faq-item.open .faq-answer{max-height:300px;padding-bottom:1.5rem;opacity:1}.faq-answer p{color:#666;line-height:1.8;font-size:.95rem}.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.shop-info h2{font-size:2rem;margin-bottom:1rem;color:var(--color-primary)}.shop-desc{margin-bottom:2rem;color:#666}.info-list{display:grid;grid-template-columns:auto 1fr;gap:1rem 2rem;border-top:1px solid var(--color-border);padding-top:2rem}.info-list dt{font-weight:700;color:var(--color-text);min-width:100px}.info-list dd{color:#555;margin-left:0}.map-container{height:400px;background-color:#eee;border-radius:12px;overflow:hidden}.map-frame{width:100%;height:100%}.map-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#e0e0e0;color:#888;font-weight:600}@media (max-width: 768px){.access-grid{grid-template-columns:1fr;gap:2rem}.map-container{height:300px;order:-1}}.contact-container{max-width:700px;margin:0 auto}.contact-intro{text-align:center;margin-bottom:3rem;line-height:1.8}.contact-form{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 20px #0000000d;border:1px solid var(--color-border)}.form-group{margin-bottom:2rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text)}.required{display:inline-block;background-color:#ff5252;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:4px;margin-left:8px;vertical-align:middle}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.8rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #00acc11a}.form-submit{text-align:center;margin-top:2rem}.btn-block{width:100%;padding:1rem;font-size:1.1rem}@media (max-width: 600px){.contact-form{padding:1.5rem}}
