@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Noto+Sans+JP:wght@300;400;500;700&display=swap";:root{--primary-rgb: 46, 125, 50;--primary: rgb(var(--primary-rgb));--primary-hover: #1b5e20;--primary-light: #e8f5e9;--secondary-rgb: 2, 136, 209;--secondary: rgb(var(--secondary-rgb));--secondary-hover: #01579b;--secondary-light: #e1f5fe;--accent: #d84315;--accent-light: #fbe9e7;--background: #f8faf9;--surface: #ffffff;--text-main: #263238;--text-muted: #607d8b;--border: #cfd8dc;--border-light: #eceff1;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--shadow-sm: 0 2px 8px rgba(0,0,0,.04);--shadow-md: 0 8px 24px rgba(0,0,0,.06);--shadow-lg: 0 16px 40px rgba(0,0,0,.1);--font-sans: "Outfit", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--background);color:var(--text-main);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}.app-container{display:flex;flex-direction:column;min-height:100vh;position:relative;overflow-x:hidden}.main-header{background:rgba(255,255,255,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--primary);letter-spacing:-.5px}.logo-icon{width:32px;height:32px}.header-nav{display:flex;gap:1.5rem}.nav-link{font-weight:500;padding:.5rem 1rem;border-radius:var(--radius-sm);transition:var(--transition)}.nav-link:hover{background-color:var(--primary-light);color:var(--primary)}.nav-link.active{background-color:var(--primary);color:#fff}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2.5rem 1.5rem}.main-footer{background-color:var(--text-main);color:#cfd8dc;padding:3rem 1.5rem;text-align:center;border-top:1px solid rgba(255,255,255,.05)}.footer-content{max-width:600px;margin:0 auto}.footer-logo{color:#fff;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.footer-text{font-size:.875rem;opacity:.7}.hero{text-align:center;padding:4rem 1.5rem 6rem;position:relative;background:radial-gradient(circle at 80% 20%,var(--secondary-light) 0%,transparent 40%),radial-gradient(circle at 10% 80%,var(--primary-light) 0%,transparent 40%);border-radius:var(--radius-lg);margin-bottom:3rem}.hero-badge{display:inline-block;background-color:var(--primary-light);color:var(--primary);padding:.35rem 1rem;border-radius:50px;font-weight:600;font-size:.875rem;margin-bottom:1.5rem}.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.15;color:var(--text-main);margin-bottom:1.5rem}.hero-subtitle{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--text-muted);max-width:700px;margin:0 auto 2.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;padding:1rem 2rem;border-radius:50px;border:none;cursor:pointer;transition:var(--transition)}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(var(--primary-rgb),.3)}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--primary-rgb),.4)}.btn-secondary{background-color:var(--surface);color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover{background-color:var(--primary-light);transform:translateY(-2px)}.car-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;margin-top:2rem}.car-card{background-color:var(--surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:var(--transition)}.car-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--primary)}.car-image-container{height:200px;background-color:#f1f3f4;position:relative;overflow:hidden}.car-image{width:100%;height:100%;object-fit:cover}.car-class-badge{position:absolute;top:1rem;left:1rem;background-color:#ffffffe6;color:var(--text-main);padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600;box-shadow:var(--shadow-sm)}.car-info{padding:1.5rem}.car-name{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--text-main)}.car-desc{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:2.8rem}.car-price-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-light)}.price-item{text-align:center}.price-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:.2rem}.price-val{font-size:.95rem;font-weight:700;color:var(--primary)}.reserve-flow{max-width:800px;margin:0 auto;background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:2.5rem;border:1px solid var(--border-light)}.progress-bar-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;position:relative;padding:0 1rem}.progress-bar-container:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background-color:var(--border-light);z-index:1;transform:translateY(-50%)}.progress-step{width:40px;height:40px;border-radius:50%;background-color:var(--surface);border:2px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-weight:600;z-index:2;transition:var(--transition);position:relative}.progress-step.active{border-color:var(--primary);background-color:var(--primary);color:#fff;box-shadow:0 0 0 6px var(--primary-light)}.progress-step.completed{border-color:var(--primary);background-color:var(--primary);color:#fff}.progress-label{position:absolute;top:48px;font-size:.75rem;font-weight:600;width:80px;text-align:center;color:var(--text-muted)}.progress-step.active .progress-label{color:var(--primary)}.step-wrapper{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.calendar-widget{margin-top:1.5rem}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:var(--transition);border:1px solid transparent}.calendar-cell.day-name{font-size:.8rem;color:var(--text-muted);cursor:default;font-weight:600}.calendar-cell.empty{cursor:default}.calendar-cell.selectable:hover{background-color:var(--primary-light);color:var(--primary)}.calendar-cell.selected{background-color:var(--primary);color:#fff!important}.calendar-cell.disabled{color:#cfd8dc;cursor:not-allowed;background-color:#f5f7f8}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:1.5rem}.course-card{border:2px solid var(--border-light);border-radius:var(--radius-md);padding:1.5rem;cursor:pointer;transition:var(--transition);position:relative;background:var(--surface)}.course-card:hover:not(.disabled){border-color:var(--secondary);transform:scale(1.02)}.course-card.selected{border-color:var(--primary);background-color:var(--primary-light)}.course-card.disabled{opacity:.5;cursor:not-allowed;background-color:#f5f7f8}.course-name{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--text-main)}.course-time{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem}.course-status-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.course-status-badge.available{background-color:var(--primary-light);color:var(--primary)}.course-status-badge.full{background-color:#ffebee;color:#c62828}.car-select-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.car-select-item{display:flex;border:2px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:var(--transition);background-color:var(--surface)}@media (max-width: 600px){.car-select-item{flex-direction:column}.car-select-image{width:100%!important;height:160px!important}}.car-select-image{width:240px;height:160px;object-fit:cover;background-color:#f1f3f4}.car-select-info{flex:1;padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between}.car-select-item:hover{border-color:var(--primary);transform:translateY(-2px)}.car-select-item.selected{border-color:var(--primary);background-color:var(--primary-light)}.form-group{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:var(--text-main);font-size:.9rem}.form-control{padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:var(--transition);background-color:#fafbfc}.form-control:focus{border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 3px var(--primary-light)}.flow-actions{display:flex;justify-content:space-between;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border-light)}.success-container{max-width:600px;margin:4rem auto;text-align:center;background:var(--surface);padding:3rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}.success-icon{color:var(--primary);width:80px;height:80px;margin-bottom:1.5rem;animation:scaleUp .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes scaleUp{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.success-title{font-size:2rem;font-weight:700;margin-bottom:1rem;color:var(--text-main)}.success-message{color:var(--text-muted);margin-bottom:2.5rem}.summary-card{background-color:var(--background);border-radius:var(--radius-md);padding:1.5rem;text-align:left;margin-bottom:2.5rem;border:1px solid var(--border-light)}.summary-row{display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px dashed var(--border-light)}.summary-row:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.summary-label{color:var(--text-muted);font-size:.9rem}.summary-value{font-weight:600;color:var(--text-main)}.summary-value.price{color:var(--primary);font-size:1.2rem}.admin-container{display:flex;flex-direction:column;gap:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.admin-table-container{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;text-align:left;min-width:800px}.admin-table th,.admin-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--border-light)}.admin-table th{background-color:#fafbfc;font-weight:600;color:var(--text-muted);font-size:.85rem;text-transform:uppercase}.admin-table tr:hover{background-color:#fdfefe}.badge{display:inline-block;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600}.badge-confirmed{background-color:var(--primary-light);color:var(--primary)}.badge-pending{background-color:#fff9c4;color:#f57f17}.badge-cancelled{background-color:#ffebee;color:#c62828}.badge-paid{background-color:var(--secondary-light);color:var(--secondary)}.badge-unpaid{background-color:#eceff1;color:#546e7a}
