:root{--primary-color: #E60012;--bg-gradient: linear-gradient(135deg, #000000 0%, #1c1c1c 100%);--text-main: #ffffff;--font-main: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif}body{margin:0;padding:0;font-family:var(--font-main);background:var(--bg-gradient);color:var(--text-main);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}button{font-family:inherit}.people-selector-container{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);margin-bottom:2rem;color:#fff}.selector-label{display:block;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;opacity:.8;margin-bottom:.8rem}.select-wrapper{position:relative;width:100%}.people-select{width:100%;padding:1rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1.1rem;appearance:none;cursor:pointer;transition:all .3s ease}.people-select:hover{border-color:#ffffff80;background:#0006}.people-select:focus{outline:none;border-color:#e60012;box-shadow:0 0 0 2px #e6001233}.select-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);pointer-events:none;font-size:.8rem;opacity:.7}.selector-hint{margin-top:.8rem;font-size:.8rem;opacity:.5;text-align:right}.calendar-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 20px 50px #0000004d;color:#333}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;color:#1a1a1a}.month-title{font-size:1.5rem;font-weight:700;margin:0}.nav-btn{background:transparent;border:1px solid #eee;border-radius:50%;width:40px;height:40px;cursor:pointer;display:flex;justify-content:center;align-items:center;font-size:1.2rem;color:#333;transition:all .2s ease}.nav-btn:hover{background:#f5f5f5;border-color:#ddd}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.weekday{text-align:center;font-weight:700;color:#888;padding-bottom:.5rem;font-size:.9rem}.calendar-day{border:1px solid #eee;border-radius:8px;min-height:80px;padding:8px;display:flex;flex-direction:column;justify-content:space-between;transition:all .2s ease;cursor:pointer}.calendar-day.empty{border:none;background:transparent;cursor:default}.calendar-day:not(.empty):hover{border-color:#e60012;background:#fafafa;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.calendar-day.selected{border-color:#e60012;background:#ffe6e6;box-shadow:0 0 0 2px #e60012;transform:translateY(-2px)}.day-number{font-weight:600;font-size:1.1rem}.day-price{font-size:.8rem;color:#e60012;font-weight:600;align-self:flex-end}.price-display-container-fix{display:flex;flex-direction:column;gap:0;margin-top:4px;align-items:center;width:100%}.price-text-mobile-fix{font-size:.85rem;font-weight:700;line-height:1.1;white-space:nowrap}.price-daikoku-fix{color:#e60012}.price-umihotaru-fix{color:#06c}@media(max-width:600px){.calendar-container{padding:.5rem;border-radius:8px;width:100%;box-sizing:border-box}.calendar-header{margin-bottom:.8rem}.month-title{font-size:1.1rem}.calendar-grid{gap:2px}.calendar-day{min-height:55px;padding:2px 1px;border-radius:4px;align-items:center;justify-content:center;display:flex;flex-direction:column;overflow:hidden}.day-number{font-size:.9rem;margin-bottom:1px;line-height:1}.price-text-mobile-fix{font-size:10.5px!important;letter-spacing:-.5px;line-height:1.1;transform:none;display:block;width:100%;text-align:center}.price-display-container-fix{margin-top:1px;width:100%}}.options-container{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);color:#fff;width:100%}.options-intro{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.options-intro h3{font-size:1.1rem;font-weight:700;margin-bottom:.5rem;color:#fff}.options-intro p{font-size:.95rem;line-height:1.6;opacity:.9;color:#e0e0e0}.options-section-title{margin:1.5rem 0 1rem;font-size:1.1rem;font-weight:600;color:#ff4d4d;text-transform:uppercase;letter-spacing:1px;border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem}.options-section-title:first-child{border-top:none;padding-top:0;margin-top:0}.options-group{margin-bottom:2rem}.options-group-intro{font-size:.95rem;line-height:1.6;color:#ffffffe6;margin-bottom:1.5rem}.option-item{margin-bottom:1rem;display:flex;flex-direction:column}.checkbox-label{display:flex;align-items:center;cursor:pointer;padding:1rem;background:#0003;border-radius:8px;border:1px solid transparent;transition:all .2s ease}.checkbox-label:hover{background:#0000004d;border-color:#ffffff1a}.checkbox-label input{display:none}.checkbox-custom{width:24px;height:24px;border:2px solid rgba(255,255,255,.4);border-radius:4px;margin-right:1.2rem;position:relative;transition:all .2s;flex-shrink:0}.checkbox-label input:checked+.checkbox-custom{background:#e60012;border-color:#e60012}.checkbox-label input:checked+.checkbox-custom:after{content:"";position:absolute;left:7px;top:3px;width:6px;height:12px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.option-details{flex-grow:1;display:flex;flex-direction:column}.option-name{font-weight:600;font-size:1rem;margin-bottom:.2rem}.option-desc{font-size:.8rem;opacity:.6;line-height:1.4}.option-price{font-weight:700;color:#ff4d4d;margin-left:1rem;white-space:nowrap}.option-text-input{margin-top:.5rem;margin-left:1rem;margin-right:1rem;padding:.8rem;background:#0003;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:.95rem;animation:fadeIn .3s ease-out}.option-text-input:focus{outline:none;border-color:#e60012;background:#0000004d}.option-text-input::placeholder{color:#ffffff4d}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.options-group-note{font-size:.85rem;line-height:1.5;color:#fff9;font-style:italic;margin-top:1rem;margin-left:.5rem}@media(max-width:600px){.options-container{padding:.75rem}}.vehicle-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem}@media(max-width:600px){.vehicle-grid{gap:.8rem}}.guest-info-container{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0003;color:#333;width:100%}.section-title{font-size:1.4rem;font-weight:700;margin:0 0 1.5rem;color:#1a1a2e;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#4b5563}.required{color:#e53e3e;margin-left:.2rem}.helper-text{display:block;font-size:.85rem;color:#6b7280;margin-bottom:.5rem;margin-top:-.3rem}.form-group input{width:100%;padding:.8rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#f9fafb}.form-group input:focus{outline:none;border-color:#e60012;background:#fff;box-shadow:0 0 0 3px #e600121a}.form-group input::placeholder{color:#9ca3af}.booking-summary-sticky{position:sticky;top:1rem;z-index:100;background:#1a1a2ef2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem 1.5rem;margin-bottom:2rem;box-shadow:0 10px 30px #00000080;animation:slideDown .4s ease-out;width:100%;max-width:600px;pointer-events:none;pointer-events:auto}.summary-content{display:flex;justify-content:space-around;align-items:center}.summary-item{display:flex;flex-direction:column;align-items:center}.summary-label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:#ff4d4d;margin-bottom:.2rem}.summary-value{font-size:1.2rem;font-weight:700;color:#fff}.summary-value.date{font-family:monospace}.summary-value.price{color:#fff;text-shadow:0 0 10px rgba(165,180,252,.5)}.summary-divider{width:1px;height:40px;background:#fff3;margin:0 1.5rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.checkout-panel{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0003;color:#333;margin-top:2rem}.checkout-summary{margin-bottom:2rem}.summary-row{display:flex;justify-content:space-between;margin-bottom:.8rem;font-size:1rem}.summary-row.option{color:#666;font-size:.9rem}.summary-divider{height:1px;background:#eee;margin:1.5rem 0}.summary-row.total{font-weight:700;font-size:1.4rem;align-items:center}.price-highlight{color:#1a1a2e}.deposit-section{background:#f5f5f7;padding:1.5rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border:1px solid #e0e0e0}.deposit-info{display:flex;flex-direction:column}.deposit-label{font-weight:700;color:#333}.deposit-subtext{font-size:.8rem;color:#666;margin-top:.2rem}.deposit-amount{font-size:1.5rem;font-weight:800;color:#e60012}.checkout-btn{width:100%;padding:1.2rem;background:#e60012;color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.checkout-btn:hover:not(:disabled){background:#b3000e;transform:translateY(-2px);box-shadow:0 4px 15px #e6001266}.checkout-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.7}.date-warning{text-align:center;color:#e53e3e;font-size:.9rem;margin-top:1rem}.confirmation-container{display:flex;justify-content:center;align-items:center;min-height:60vh;width:100%;animation:fadeIn .8s ease-out}.confirmation-card{background:#fff;padding:3rem;border-radius:20px;box-shadow:0 20px 60px #0006;max-width:600px;width:100%;text-align:center;color:#333}.success-icon{width:80px;height:80px;background:#e60012;color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:3rem;font-weight:700;margin:0 auto 1.5rem;box-shadow:0 10px 20px #e600124d}.confirmation-card h2{color:#1a1a1a;margin-bottom:1rem;font-size:2rem}.confirmation-message{color:#666;margin-bottom:2rem;line-height:1.6}.details-summary{background:#f9fafb;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.detail-row{display:flex;justify-content:space-between;margin-bottom:.8rem;font-size:1rem;color:#555;border-bottom:1px solid #eee;padding-bottom:.5rem}.detail-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-row span:last-child{font-weight:700;color:#333}.detail-row.highlight span:last-child{color:#e60012}.next-steps{text-align:left;margin-bottom:2.5rem;padding:0 1rem}.next-steps h3{font-size:1.1rem;margin-bottom:1rem;color:#333}.next-steps ul{padding-left:1.2rem;color:#555}.next-steps li{margin-bottom:.5rem;line-height:1.5}.reset-btn{background:#1a1a1a;color:#fff;border:none;padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-btn:hover{background:#333;transform:translateY(-2px);box-shadow:0 5px 15px #0003}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-container{max-width:1200px;margin:0 auto;padding:2rem;min-height:100vh;display:flex;flex-direction:column}@media(max-width:600px){.app-container{padding:.5rem}}.app-header{text-align:center;margin-bottom:3rem;padding-top:2rem}.app-header h1{font-size:3rem;margin:0 0 .5rem;color:#e60012;font-weight:800;letter-spacing:-1px}.app-header .subtitle{font-size:1.1rem;color:#ffffffb3;font-weight:300}.main-content{display:flex;flex-direction:column;gap:2rem;align-items:center;padding-bottom:4rem}.control-panel{width:100%;max-width:500px;animation:fadeInDown .6s ease-out}.calendar-section{width:100%;max-width:900px;animation:fadeInUp .8s ease-out}.options-section{width:100%;max-width:1000px;margin-top:1rem;animation:fadeInUp 1s ease-out}.guest-info-section{width:100%;max-width:700px;animation:fadeInUp 1.1s ease-out}.checkout-section{width:100%;max-width:700px;animation:fadeInUp 1.2s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.driver-dashboard{max-width:800px;margin:0 auto;padding:.5rem;font-family:Inter,sans-serif}.driver-header{text-align:center;margin-bottom:2rem}.driver-header h1{font-size:1.5rem;color:#333}.vehicle-badge{display:inline-block;background:#f0f0f0;padding:.5rem 1rem;border-radius:8px;font-weight:700;margin-top:.5rem}.tabs-container{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem}.tab-button{padding:.8rem 1.5rem;border:none;border-radius:8px;background:#eee;color:#666;font-weight:700;cursor:pointer;transition:all .2s}.tab-button.active{background:#e60012;color:#fff}.calendar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-controls button{background:none;border:1px solid #ddd;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.driver-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.weekday{text-align:center;font-weight:700;color:#888;padding:.5rem}.driver-calendar-day{aspect-ratio:1;border:1px solid #e5e7eb;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .2s;background:#fff}.driver-calendar-day.empty{background:transparent;border:none;cursor:default}.driver-calendar-day.open{background:#dcfce7;border-color:#16a34a;color:#15803d}.driver-calendar-day.blocked{background:#fee2e2;border-color:#ef4444;color:#b91c1c}.driver-calendar-day.past{opacity:.4;filter:grayscale(100%);cursor:not-allowed;background:#f3f4f6;border-color:#e5e7eb}.day-number{font-size:.9rem;font-weight:800;margin-bottom:0}.status-text{font-size:.6rem;font-weight:900;text-transform:uppercase;line-height:1}.driver-calendar-day.open .status-text{color:#15803d}.driver-calendar-day.blocked .status-text{color:#b91c1c}.driver-footer{margin-top:2rem;display:flex;justify-content:center}.legend{display:flex;gap:1.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.dot{width:12px;height:12px;border-radius:50%}.dot.open{background:#10b981}.dot.blocked{background:#ef4444}
