@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary-purple: #667eea;--secondary-purple: #764ba2;--light-gray: #6b7280;--border-gray: #e5e7eb;--background-white: #ffffff;--soft-white: #f9fafb;--accent-blue: #667eea;--hover-gray: #f3f4f6;--text-gray: #374151}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-family:"Source Sans 3",sans-serif}.app-header{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:1rem 0;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;color:#fff}.logo-icon{width:2rem;height:2rem;color:#60a5fa}.logo h1{font-size:1.75rem;font-weight:700;margin:0}.header-actions{display:flex;gap:1rem}.back-btn,.about-btn{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.2);border:none;color:#fff;padding:.75rem 1.5rem;border-radius:50px;font-weight:500;cursor:pointer;transition:all .2s ease}.back-btn:hover,.about-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}.back-icon,.about-icon{width:1.125rem;height:1.125rem}.app-main{flex:1;padding:2rem 0}.app-footer{background:rgba(0,0,0,.2);padding:1rem 0;text-align:center;color:#fffc;font-size:.875rem}.footer-credit{margin-top:.5rem;font-size:.75rem;color:#fff9}.footer-credit a{color:#fffc;text-decoration:none;transition:color .2s ease}.footer-credit a:hover{color:#fff;text-decoration:underline}.form-container{max-width:900px;margin:0 auto;padding:0 2rem}.surf-preferences-form{background:rgba(255,255,255,.95);border-radius:24px;padding:3rem;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-header{text-align:center;margin-bottom:3rem}.form-header h2{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-header p{font-size:1.125rem;color:#6b7280}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.form-group{display:flex;flex-direction:column}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-group .icon{width:1.25rem;height:1.25rem;color:#667eea}.form-group input,.form-group select{padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease;background:white}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.budget-slider-group{display:flex;flex-direction:column;gap:1rem}.budget-slider{width:100%}.budget-input-container{display:flex;align-items:center;justify-content:center;gap:.25rem;background:#f8fafc;border:2px solid #e5e7eb;border-radius:12px;padding:.5rem 1rem;max-width:200px;margin:0 auto}.budget-currency{font-size:1.125rem;font-weight:600;color:#374151}.budget-input{border:none;background:transparent;font-size:1.125rem;font-weight:600;text-align:center;width:80px;color:#374151}.budget-input:focus{outline:none}.budget-period{font-size:.875rem;color:#6b7280;font-weight:500}.tooltip-container{position:relative;display:inline-block;margin-left:.5rem}.tooltip-trigger{cursor:help}.help-icon{width:1rem;height:1rem;color:#9ca3af;transition:color .2s ease}.tooltip-trigger:hover .help-icon{color:#667eea}.tooltip-content{position:absolute;background:#1f2937;color:#fff;padding:.75rem;border-radius:8px;font-size:.8rem;z-index:9999;box-shadow:0 4px 12px #0003;max-width:280px;max-height:200px;white-space:normal;text-align:left;line-height:1.3;pointer-events:none;overflow-y:auto;word-wrap:break-word}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1f2937}.multi-select{position:relative}.multi-select-trigger{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;background:white;cursor:pointer;transition:all .2s ease;font-size:1rem}.multi-select-trigger:hover{border-color:#d1d5db}.multi-select-trigger:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.chevron{width:1.25rem;height:1.25rem;color:#6b7280;transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.multi-select-dropdown{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid #e5e7eb;border-top:none;border-radius:0 0 12px 12px;z-index:100;max-height:200px;overflow-y:auto}.multi-select-option{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f3f4f6}.multi-select-option:hover{background-color:#f9fafb}.multi-select-option:last-child{border-bottom:none}.multi-select-option input[type=checkbox]{margin:0;margin-right:.75rem;width:1rem;height:1rem}.option-content{display:flex;align-items:center;gap:.5rem}.option-icon{font-size:1.125rem}.temperature-slider{display:flex;flex-direction:column;gap:.75rem}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:5px;background:linear-gradient(to right,#3b82f6 0%,#10b981 25%,#f59e0b 50%,#ef4444 75%,#dc2626 100%);outline:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003;transition:all .2s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003;transition:all .2s ease}.temperature-display{text-align:center;font-weight:600;color:#374151;font-size:1rem;padding:.5rem;background:#f8fafc;border-radius:8px;cursor:pointer;transition:all .2s ease}.temperature-display:hover{transform:scale(1.05);background:#e2e8f0}.ability-slider{margin-top:.5rem}.ability-display{text-align:center}.ability-description{margin-top:.75rem;font-size:.8rem;color:#6b7280;text-align:center;line-height:1.4;padding:.5rem;background:rgba(102,126,234,.05);border-radius:8px;border-left:3px solid #667eea}background: #f8fafc; border-radius: 8px; margin-top: .5rem; } .travel-time-slider{margin-top:.5rem}.travel-time-display{text-align:center;font-weight:600;color:#374151;font-size:1rem;padding:.5rem;background:#f8fafc;border-radius:8px;margin-top:.5rem}.transport-travel-times{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.transport-time-estimate{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(102,126,234,.1);border-radius:8px;font-size:.875rem}.transport-time-icon{font-size:1rem;flex-shrink:0}.transport-time-text{color:#667eea;font-weight:500}.checkbox-group{grid-column:1 / -1}.checkbox-label{display:flex;align-items:center;gap:.75rem;font-weight:600;color:#374151;cursor:pointer;padding:1rem;background:#f8fafc;border-radius:12px;border:2px solid #e5e7eb;transition:all .2s ease}.checkbox-label:hover{background:#f1f5f9;border-color:#d1d5db}.checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:#667eea;cursor:pointer}.checkbox-label .checkmark{width:1.25rem;height:1.25rem}.checkbox-label .icon{color:#667eea}.card-forecast{padding:1.5rem;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-bottom:1px solid #e5e7eb}.forecast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.forecast-header h4{font-size:1rem;font-weight:600;color:#374151;margin:0}.forecast-refresh-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease}.forecast-refresh-btn:hover{background:rgba(0,0,0,.1)}.forecast-refresh{width:1rem;height:1rem;color:#6b7280;transition:transform .2s ease}.forecast-refresh.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.forecast-loading{display:flex;align-items:center;gap:.75rem;color:#6b7280;font-size:.875rem}.loading-spinner{width:1rem;height:1rem;border:2px solid #e5e7eb;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.forecast-error{color:#ef4444;font-size:.875rem;text-align:center;padding:.5rem}.forecast-content{display:flex;flex-direction:column;gap:1rem}.forecast-rating{display:flex;align-items:center;gap:.75rem}.rating-badge{color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:.875rem;font-weight:700;min-width:2.5rem;text-align:center}.rating-text{font-size:.875rem;color:#374151;font-weight:500}.forecast-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.forecast-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem;background:white;border-radius:8px;border:1px solid #e5e7eb}.forecast-icon{width:1.25rem;height:1.25rem;color:#667eea;margin-bottom:.25rem}.forecast-label{font-size:.75rem;color:#6b7280;font-weight:500;margin-bottom:.25rem}.forecast-value{font-weight:700;color:#1f2937;font-size:.875rem}.forecast-updated{text-align:center;font-size:.75rem;color:#9ca3af;font-style:italic}.square-card{width:100%;aspect-ratio:1;position:relative;cursor:pointer;perspective:1000px;transition:transform .2s ease;overflow:hidden;border-radius:16px}.square-card:hover{transform:scale(1.02)}.card-side{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 8px 25px #00000026;transition:transform .6s ease}.card-front{transform:rotateY(0)}.card-back{transform:rotateY(180deg);background:white}.square-card.flipped .card-front{transform:rotateY(-180deg)}.square-card.flipped .card-back{transform:rotateY(0)}.square-rank{position:absolute;top:1rem;left:1rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.5rem .75rem;border-radius:50px;font-weight:700;font-size:1rem;z-index:10;box-shadow:0 4px 12px #0000004d}.square-image{width:100%;height:100%;background-size:cover;background-position:center;position:relative;overflow:hidden;border-radius:16px}.square-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,rgba(0,0,0,.1) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.8) 100%);display:flex;flex-direction:column;justify-content:space-between;padding:4rem 1.5rem 1.5rem}.square-title{color:#fff;text-align:center}.square-title h3{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.square-title p{font-size:1rem;margin:0;opacity:.9;text-shadow:0 1px 2px rgba(0,0,0,.5)}.quick-stats{display:flex;justify-content:space-between;align-items:center}.quick-stat{display:flex;align-items:center;gap:.25rem;background:rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem .75rem;border-radius:50px;color:#fff;font-weight:600;font-size:.875rem;position:relative}.cost-stat{display:flex!important;align-items:center!important;gap:.25rem!important;cursor:help}.cost-daily{cursor:help}.numbeo-link{margin-left:.5rem;padding:.25rem;color:#60a5fa!important;text-decoration:none;border-radius:4px;transition:all .2s ease;background:rgba(96,165,250,.1)!important;border:1px solid rgba(96,165,250,.3)!important;display:inline-flex!important;align-items:center!important;justify-content:center!important}.numbeo-link:hover{color:#fff!important;background:#60a5fa!important;transform:scale(1.1)}.numbeo-icon{width:1.25rem!important;height:1.25rem!important;display:block!important;color:#1d4ed8!important;stroke-width:2.5!important;opacity:1!important;visibility:visible!important}.back-cost-stat{display:flex!important;align-items:center!important;gap:.5rem!important;justify-content:flex-start!important}.numbeo-link-back{margin-left:.5rem!important;padding:.5rem!important;color:#1d4ed8!important;text-decoration:none!important;border-radius:6px!important;background:#dbeafe!important;border:2px solid #3b82f6!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;width:36px!important;height:36px!important;position:relative!important;z-index:100!important;opacity:1!important;visibility:visible!important}.numbeo-link-back:hover{color:#fff!important;background:#60a5fa!important;transform:scale(1.1)}.travel-stat{background:rgba(34,197,94,.2)!important;border:1px solid rgba(34,197,94,.3)}.date-range-picker{width:100%}.date-range-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.date-input-group{display:flex;flex-direction:column;gap:.5rem}.date-input-group label{font-size:.875rem;font-weight:600;color:#374151}.date-input{padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease;background:white}.date-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-input:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed;border-color:#d1d5db}.date-display{font-size:.875rem;color:#667eea;font-weight:500;margin-top:.25rem}.date-duration{text-align:center;font-size:.875rem;color:#667eea;font-weight:600;padding:.5rem;background:rgba(102,126,234,.1);border-radius:8px;margin-top:.5rem}.calendar-group{grid-column:1 / -1}.full-calendar{background:white;border:2px solid #e5e7eb;border-radius:12px;padding:1rem;margin-top:.5rem}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav-btn{background:none;border:none;padding:.5rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;transition:background-color .2s ease}.calendar-nav-btn:hover{background:#f3f4f6}.calendar-nav-icon{width:1.25rem;height:1.25rem;color:#667eea}.calendar-month-title{font-size:1.125rem;font-weight:600;color:#374151;margin:0}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.calendar-weekday{text-align:center;font-size:.875rem;font-weight:600;color:#6b7280;padding:.5rem 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-day{aspect-ratio:1;border:none;background:white;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.calendar-day:hover:not(.disabled){background:#f3f4f6}.calendar-day.other-month{color:#d1d5db}.calendar-day.today{background:#667eea;color:#fff}.calendar-day.selected{background:#10b981;color:#fff}.calendar-day.in-range{background:rgba(16,185,129,.2);color:#065f46}.calendar-day.disabled{color:#d1d5db;cursor:not-allowed}.calendar-day.disabled:hover{background:white}.calendar-summary{margin-top:1rem;padding:1rem;background:rgba(102,126,234,.1);border-radius:8px;text-align:center}.date-range-summary{font-weight:600;color:#667eea;margin-bottom:.25rem}.trip-duration{font-size:.875rem;color:#374151}.dual-calendar-group{grid-column:1 / -1}.dual-calendar{background:white;border:2px solid #e5e7eb;border-radius:12px;padding:1rem;margin-top:.5rem}.dual-calendar-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mini-calendar{background:#f9fafb;border-radius:8px;padding:.75rem}.mini-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.mini-calendar-title{font-size:.875rem;font-weight:600;color:#667eea;margin:0}.mini-calendar-nav-btn{background:none;border:none;padding:.25rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;transition:background-color .2s ease}.mini-calendar-nav-btn:hover{background:#e5e7eb}.mini-calendar-nav-icon{width:1rem;height:1rem;color:#667eea}.mini-calendar-month{font-size:.75rem;font-weight:500;color:#374151;text-align:center;margin-bottom:.5rem}.mini-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.125rem;margin-bottom:.25rem}.mini-calendar-weekday{text-align:center;font-size:.625rem;font-weight:600;color:#6b7280;padding:.25rem 0}.mini-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.125rem}.mini-calendar-day{aspect-ratio:1;border:none;background:white;border-radius:4px;cursor:pointer;font-size:.625rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:1.5rem}.mini-calendar-day:hover:not(.disabled){background:#f3f4f6}.mini-calendar-day.other-month{color:#d1d5db}.mini-calendar-day.today{background:#667eea;color:#fff}.mini-calendar-day.selected{background:#10b981;color:#fff}.mini-calendar-day.in-range{background:rgba(16,185,129,.2);color:#065f46}.mini-calendar-day.disabled{color:#d1d5db;cursor:not-allowed}.mini-calendar-day.disabled:hover{background:white}.dual-calendar-summary{margin-top:1rem;padding:.75rem;background:rgba(102,126,234,.1);border-radius:8px;text-align:center}.dual-date-range-summary{font-weight:600;color:#667eea;margin-bottom:.25rem;font-size:.875rem}.dual-trip-duration{font-size:.75rem;color:#374151}.transport-options{display:flex;flex-wrap:wrap;gap:.5rem;max-width:300px}.transport-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;flex:0 0 calc(50% - .25rem);max-width:140px;box-sizing:border-box;min-height:80px}.transport-option:hover{border-color:#667eea;background:rgba(102,126,234,.05)}.transport-option input[type=checkbox]{position:absolute;opacity:0;cursor:pointer}.transport-option input[type=checkbox]:checked+.transport-checkmark{background:#667eea;border-color:#667eea}.transport-option input[type=checkbox]:checked+.transport-checkmark:after{display:block}.transport-option input[type=checkbox]:checked~.transport-emoji,.transport-option input[type=checkbox]:checked~.transport-label{color:#667eea}.transport-checkmark{position:absolute;top:.5rem;right:.5rem;width:1.25rem;height:1.25rem;background:white;border:2px solid #d1d5db;border-radius:4px;transition:all .2s ease}.transport-checkmark:after{content:"";position:absolute;display:none;left:.25rem;top:.125rem;width:.375rem;height:.625rem;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.transport-emoji{font-size:1.5rem;transition:color .2s ease}.transport-label{font-size:.875rem;font-weight:500;color:#374151;transition:color .2s ease}.quick-icon{width:1rem;height:1rem}.difficulty-badge-square{width:3rem;height:2.5rem;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.75rem;box-shadow:0 2px 8px #0000004d;padding:.25rem}.back-content{padding:1.5rem;height:100%;display:flex;flex-direction:column;gap:.75rem}.back-header{text-align:center;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.back-header h4{font-size:1.25rem;font-weight:700;margin:0 0 .25rem;color:#1f2937}.back-region{font-size:.875rem;color:#6b7280}.seasonal-forecast{background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border:1px solid #3b82f6;border-radius:12px;padding:1rem}.seasonal-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.seasonal-icon{width:1rem;height:1rem;color:#3b82f6}.seasonal-title{font-weight:600;color:#1e40af;font-size:.875rem}.seasonal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.seasonal-stat{text-align:center}.seasonal-waves,.seasonal-consistency,.seasonal-crowd{display:block;font-weight:700;color:#1e40af;font-size:.875rem}.seasonal-label{display:block;font-size:.75rem;color:#6b7280;margin-top:.25rem}.current-conditions-small{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:rgba(107,114,128,.1);border-radius:8px;font-size:.75rem}.seasonal-conditions-small{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2);border-radius:8px;font-size:.75rem}.seasonal-conditions-small .seasonal-label{color:#1e40af;font-weight:600}.seasonal-conditions-small .seasonal-waves,.seasonal-conditions-small .seasonal-consistency,.seasonal-conditions-small .seasonal-crowd{color:#374151;font-weight:500}.current-label{color:#6b7280;font-weight:500}.current-waves{color:#374151;font-weight:600}.current-rating{font-weight:600;font-size:.75rem}.forecast-info-link{margin-left:auto;padding:.125rem;color:#6b7280;text-decoration:none;border-radius:3px;transition:all .2s ease}.forecast-info-link:hover{color:#374151;background:rgba(107,114,128,.1)}.forecast-info-icon{width:.875rem;height:.875rem}.back-forecast{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-radius:12px}.back-forecast.loading{flex-direction:row;align-items:center;justify-content:center;gap:.5rem;color:#6b7280;font-size:.875rem}.forecast-spinner{width:1rem;height:1rem}.forecast-rating-back{display:flex;align-items:center;gap:1rem}.rating-circle{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;flex-shrink:0}.forecast-details{display:flex;flex-direction:column;gap:.25rem}.wave-height{font-size:1.125rem;font-weight:700;color:#1f2937}.wave-period{font-size:.875rem;color:#6b7280}.weather-info{display:flex;gap:1rem}.weather-item{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#374151}.weather-icon{width:1rem;height:1rem;color:#667eea}.back-stats{display:flex;flex-direction:column;gap:.75rem}.back-stat{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151}.back-icon{width:1rem;height:1rem;color:#667eea;flex-shrink:0}.back-highlights{display:flex;flex-wrap:wrap;gap:.5rem}.highlight-tag{background:#e0e7ff;color:#667eea;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:500}.click-hint{margin-top:auto;text-align:center;padding-top:.5rem;border-top:1px solid #e5e7eb}.click-hint span{font-size:.75rem;color:#9ca3af;font-style:italic}.hover-details{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.98);opacity:0;visibility:hidden;transition:all .3s ease;padding:1.5rem;overflow:hidden;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px}.square-card.hovered .hover-details{opacity:1;visibility:visible}.hover-content{height:100%;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;overflow-x:hidden}.hover-header{text-align:center;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.hover-header h4{font-size:1.25rem;font-weight:700;margin:0 0 .25rem;color:#1f2937}.hover-region{font-size:.875rem;color:#6b7280}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:white;border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px #0000004d}.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,.5);border:none;color:#fff;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background-color .2s ease}.modal-close:hover{background:rgba(0,0,0,.7)}.close-icon{width:1.25rem;height:1.25rem}.modal-rank{position:absolute;top:1rem;left:1rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.5rem 1rem;border-radius:50px;font-weight:700;font-size:1.125rem;z-index:10;box-shadow:0 4px 12px #0000004d}.modal-image{height:250px;background-size:cover;background-position:center;position:relative;border-radius:20px 20px 0 0}.modal-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.8) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;color:#fff}.modal-image-overlay h2{font-size:2rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.modal-image-overlay p{font-size:1.125rem;margin:0;opacity:.9;text-shadow:0 1px 2px rgba(0,0,0,.5)}.modal-body{padding:2rem}.modal-forecast{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);padding:1.5rem;border-radius:16px;margin-bottom:2rem}.modal-forecast h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#374151}.modal-forecast-grid{display:flex;gap:1.5rem;align-items:center;margin-bottom:1rem}.forecast-main{display:flex;align-items:center;gap:1rem}.modal-rating-badge{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem}.forecast-primary{display:flex;flex-direction:column;gap:.25rem}.modal-wave-height{font-size:1.5rem;font-weight:700;color:#1f2937}.modal-wave-period{font-size:.875rem;color:#6b7280}.forecast-secondary{display:flex;flex-direction:column;gap:.75rem}.modal-weather-stat{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151}.modal-weather-icon{width:1rem;height:1rem;color:#667eea}.modal-conditions{font-style:italic;color:#6b7280;margin:0}.modal-seasonal-forecast{background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border:1px solid #3b82f6;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}.modal-seasonal-forecast h3{margin:0 0 1rem;color:#1e40af;font-size:1.25rem;font-weight:700}.modal-seasonal-grid{margin-bottom:1rem}.seasonal-main{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.seasonal-metric{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:rgba(255,255,255,.8);border-radius:12px;text-align:center}.seasonal-emoji{font-size:1.5rem;display:block;margin-bottom:.5rem}.seasonal-label{font-size:.875rem;color:#6b7280;font-weight:500}.seasonal-value{font-size:1.125rem;font-weight:700;color:#1e40af}.modal-seasonal-note{font-size:.875rem;color:#4b5563;font-style:italic;text-align:center;margin:0}.modal-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.modal-stat{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #e5e7eb}.modal-stat-emoji{font-size:1.5rem;display:block;margin-bottom:.5rem;flex-shrink:0}.modal-stat-emoji-icon{width:1.5rem;height:1.5rem;color:#667eea;display:block;margin-bottom:.5rem;flex-shrink:0}.modal-stat-label{font-size:.875rem;color:#6b7280;margin-right:auto}.modal-stat-value{font-weight:600;color:#1f2937;font-size:.875rem}.modal-cost-container{display:flex;align-items:center;gap:.5rem}.modal-numbeo-link{padding:.375rem;color:#3b82f6!important;text-decoration:none!important;border-radius:6px!important;background:#dbeafe!important;border:2px solid #3b82f6!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;transition:all .2s ease}.modal-numbeo-link:hover{color:#fff!important;background:#3b82f6!important;transform:scale(1.05)}.modal-numbeo-icon{width:1rem!important;height:1rem!important;color:inherit!important}.modal-lifeguard-container{display:flex;align-items:center;gap:.5rem}.modal-lifeguard-link{display:flex;align-items:center;color:#3b82f6!important;text-decoration:none;transition:color .2s ease}.modal-lifeguard-link:hover{color:#1d4ed8!important}.modal-lifeguard-icon{width:.875rem;height:.875rem;color:inherit}.modal-difficulty{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem;background:#f8fafc;border-radius:12px}.modal-difficulty-label{font-weight:600;color:#374151}.modal-difficulty-badge{color:#fff;padding:.5rem 1rem;border-radius:50px;font-size:.875rem;font-weight:600;text-transform:capitalize}.modal-break-type{margin:1.5rem 0;padding:1rem;background:rgba(102,126,234,.05);border-radius:12px;border-left:4px solid #667eea}.modal-break-type h4{margin:0 0 .5rem;color:#667eea;font-size:1rem;font-weight:600}.modal-break-explanation{margin:0;color:#374151;font-size:.875rem;line-height:1.5}.reddit-quotes{display:flex;flex-direction:column;gap:1rem}.reddit-quote{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;border-left:4px solid #ff4500}.quote-text{margin:0 0 .75rem;color:#374151;font-size:.875rem;line-height:1.5;font-style:italic}.quote-attribution{display:flex;align-items:center}.quote-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:#ff4500;font-size:.75rem;font-weight:500;transition:color .2s ease}.quote-link:hover{color:#dc2626}.quote-author{font-weight:600}.quote-subreddit{color:#6b7280;font-weight:400}.quote-external-icon{width:.75rem;height:.75rem;color:inherit}.modal-section{margin-bottom:2rem}.modal-section h4{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 .75rem}.modal-section p{color:#6b7280;line-height:1.6;margin:0}.modal-highlights,.modal-accommodation{display:flex;flex-wrap:wrap;gap:.5rem}.modal-highlight-tag,.modal-accommodation-tag{background:#e0e7ff;color:#667eea;padding:.5rem 1rem;border-radius:50px;font-size:.875rem;font-weight:500}.modal-accommodation-tag{background:#f0fdf4;color:#16a34a}.location-autocomplete{position:relative;width:100%}.location-input-container{position:relative;display:flex;align-items:center}.location-search-icon{position:absolute;left:.75rem;width:1rem;height:1rem;color:#6b7280;z-index:1}.location-input{width:100%;padding:.875rem 3.5rem .875rem 2.5rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease;background:white}.location-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.location-detect-btn{position:absolute;right:.5rem;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:8px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.location-detect-btn:hover{background:rgba(102,126,234,.1)}.location-pin-icon{width:1.25rem;height:1.25rem;color:#667eea}.location-dropdown{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid #e5e7eb;border-top:none;border-radius:0 0 12px 12px;z-index:100;max-height:300px;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.location-dropdown-header{padding:.75rem 1rem;font-size:.875rem;font-weight:600;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb}.location-option{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:none;background:none;cursor:pointer;transition:background-color .2s ease;text-align:left;border-bottom:1px solid #f3f4f6}.location-option:hover{background:#f9fafb}.location-option:last-child{border-bottom:none}.location-option-icon{width:1.25rem;height:1.25rem;color:#667eea;flex-shrink:0}.location-option-content{display:flex;flex-direction:column;gap:.125rem}.location-name{font-weight:500;color:#1f2937;font-size:.875rem}.location-country{font-size:.75rem;color:#6b7280}.location-no-results{padding:1rem;text-align:center;color:#9ca3af;font-size:.875rem}.submit-btn{width:100%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea66}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea80}.results-container{max-width:1400px;margin:0 auto;padding:0 2rem}.destination-grid{width:100%}.grid-header{text-align:center;margin-bottom:3rem;color:#fff}.grid-header h2{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.grid-header p{font-size:1.125rem;color:#fffc}.cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem}.square-cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;max-width:1400px;margin:0 auto}.destination-card{background:white;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #00000026;transition:all .3s ease;position:relative}.destination-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0003}.card-rank{position:absolute;top:1rem;left:1rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.5rem 1rem;border-radius:50px;font-weight:700;font-size:1.125rem;z-index:10;box-shadow:0 4px 12px #0003}.card-image{height:200px;position:relative;overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.destination-card:hover .card-image img{transform:scale(1.05)}.card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:2rem 1.5rem 1.5rem;color:#fff}.location-info h3{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.location-info p{font-size:1rem;opacity:.9}.card-stats{padding:1.5rem}.stat-row{display:flex;justify-content:space-between;margin-bottom:1rem}.stat-full{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#f8fafc;border-radius:8px}.stat{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1}.stat-icon{width:1.25rem;height:1.25rem;color:#667eea;margin-bottom:.25rem}.stat-full .stat-icon{margin-bottom:0}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500;margin-bottom:.25rem}.stat-full .stat-label{font-size:.875rem;margin-bottom:0;margin-right:.5rem}.stat-value{font-weight:700;color:#1f2937;font-size:.875rem}.stat-full .stat-value{font-size:.875rem}.difficulty-badge{color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600;text-transform:capitalize}.card-highlights{padding:0 1.5rem;margin-bottom:1.5rem}.card-highlights h4{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.75rem}.card-highlights ul{list-style:none;margin:0;padding:0}.card-highlights li{color:#6b7280;font-size:.875rem;position:relative;padding:.25rem 0 .25rem 1rem}.card-highlights li:before{content:"•";color:#667eea;font-weight:700;position:absolute;left:0}.card-description{padding:0 1.5rem;margin-bottom:1.5rem}.card-description p{color:#6b7280;font-size:.875rem;line-height:1.6}.card-accommodation{padding:0 1.5rem 1.5rem}.accommodation-label{font-size:.75rem;color:#6b7280;font-weight:500;display:block;margin-bottom:.5rem}.accommodation-tags{display:flex;flex-wrap:wrap;gap:.5rem}.accommodation-tag{background:#e0e7ff;color:#667eea;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:500}.no-results{display:flex;justify-content:center;align-items:center;min-height:300px;color:#fff;text-align:center}.no-results-content h3{font-size:1.5rem;margin-bottom:.5rem}.no-results-content p{font-size:1rem;opacity:.8}@media (max-width: 768px){.header-content{padding:0 1rem}.logo h1{font-size:1.5rem}.form-container,.results-container{padding:0 1rem}.surf-preferences-form{padding:1.5rem}.form-header h2{font-size:1.75rem}.form-header p{font-size:1rem}.form-grid{grid-template-columns:1fr;gap:1.5rem}.cards-container{grid-template-columns:1fr}.square-cards-container{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.grid-header h2{font-size:2rem}.ability-description{font-size:.75rem;padding:.4rem;margin-top:.5rem}.transport-options{max-width:100%!important;gap:.5rem!important}.transport-option{padding:.6rem!important;min-height:70px!important;flex:0 0 calc(50% - .25rem)!important;max-width:none!important}.dual-calendar-container{grid-template-columns:1fr;gap:1rem}.mini-calendar{padding:1rem}.budget-input-container{max-width:100%}.travel-time-display{font-size:.875rem;padding:.375rem}.transport-travel-times{grid-template-columns:1fr;gap:.5rem}.transport-time-estimate{padding:.375rem .5rem;font-size:.8rem}.temperature-display{font-size:.875rem;padding:.375rem}}@media (max-width: 480px){.surf-preferences-form{padding:1rem}.form-header h2{font-size:1.5rem}.form-header p{font-size:.875rem}.form-grid{gap:1rem}.budget-group{flex-direction:column}.transport-options{max-width:100%!important;gap:.4rem!important}.transport-option{padding:.5rem!important;min-height:65px!important;font-size:.875rem!important}.transport-emoji{font-size:1.25rem}.transport-label{font-size:.75rem}.stat-row{flex-direction:column;gap:.75rem}.stat{flex-direction:row;justify-content:space-between;text-align:left}.checkbox-group{grid-column:1}.temperature-slider{gap:.5rem}.temperature-display{font-size:.875rem}.multi-select-dropdown{max-height:150px}.tooltip-content{max-width:240px;max-height:120px;font-size:.75rem;padding:.5rem;line-height:1.2}.forecast-stats{grid-template-columns:1fr;gap:.5rem}.forecast-stat{padding:.5rem}.forecast-header h4{font-size:.875rem}.card-forecast{padding:1rem}.form-group label{font-size:.875rem;margin-bottom:.375rem}.form-group input,.form-group select{padding:.75rem;font-size:.875rem}.submit-btn{padding:.875rem 1.5rem;font-size:1rem}.ability-description{font-size:.7rem;padding:.3rem;line-height:1.3}.budget-input-container{padding:.375rem .75rem;max-width:160px}.budget-currency,.budget-input{font-size:1rem}.budget-period{font-size:.75rem}.dual-calendar,.mini-calendar{padding:.75rem}.mini-calendar-title{font-size:.8rem}.mini-calendar-weekday{font-size:.6rem;padding:.2rem 0}.mini-calendar-day{font-size:.6rem;min-height:1.25rem}.dual-calendar-summary{padding:.5rem}.dual-date-range-summary{font-size:.8rem}.dual-trip-duration{font-size:.7rem}}.about-page{min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.about-container{max-width:1000px;margin:0 auto;padding:2rem;color:#fff}.about-back{margin-bottom:2rem}.about-header{text-align:center;margin-bottom:3rem}.about-logo{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.about-logo-icon{width:3rem;height:3rem;color:#60a5fa}.about-header h1{font-size:3rem;font-weight:700;margin:0;background:linear-gradient(45deg,#60a5fa,#a78bfa);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.about-subtitle{font-size:1.25rem;opacity:.9;margin:0}.about-content{display:flex;flex-direction:column;gap:3rem}.about-section{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;border:1px solid rgba(255,255,255,.2)}.about-section h2{color:#60a5fa;font-size:2rem;margin-bottom:1rem;font-weight:600}.about-section p{font-size:1.125rem;line-height:1.6;opacity:.9;margin-bottom:1rem}.how-to-steps{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.step{display:flex;align-items:flex-start;gap:1rem}.step-number{width:2.5rem;height:2.5rem;background:linear-gradient(45deg,#60a5fa,#a78bfa);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.step-content h3{color:#60a5fa;margin:0 0 .5rem;font-size:1.25rem}.step-content p{margin:0;opacity:.9}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.feature{background:rgba(255,255,255,.05);border-radius:15px;padding:1.5rem;text-align:center;border:1px solid rgba(255,255,255,.1)}.feature-icon{width:3rem;height:3rem;color:#60a5fa;margin-bottom:1rem}.feature h3{color:#60a5fa;margin-bottom:.75rem;font-size:1.25rem}.feature p{margin:0;opacity:.9;font-size:1rem}.for-nerds{background:rgba(139,92,246,.1)!important;border:1px solid rgba(139,92,246,.3)!important}.nerds-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease}.nerds-header:hover{transform:translateY(-2px)}.nerds-header h2{margin:0;display:flex;align-items:center;gap:.5rem}.nerds-header p{margin:.5rem 0 0;font-size:1rem;opacity:.8}.nerds-content{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.2)}.nerd-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}.nerd-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.nerd-section h3{color:#a78bfa;font-size:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.tech-explanation h4{color:#60a5fa;font-size:1.25rem;margin:1.5rem 0 1rem}.tech-explanation h5{color:#fbbf24;font-size:1.125rem;margin:1.25rem 0 .75rem}.tech-explanation ul{margin:.75rem 0;padding-left:1.5rem}.tech-explanation li{margin-bottom:.5rem;line-height:1.5;opacity:.9}.tech-explanation li.indent{margin-left:1rem;opacity:.8}.tech-explanation code{background:rgba(255,255,255,.1);padding:.25rem .5rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#fbbf24}.transport-mode{background:rgba(255,255,255,.05);border-radius:10px;padding:1rem;margin:1rem 0}.example{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:10px;padding:1rem;margin:1rem 0}.forecast-data{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);border-radius:10px;padding:1rem;margin:1rem 0}.ability-levels{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin:1rem 0}.ability-level{border-radius:10px;padding:1rem;border:1px solid rgba(255,255,255,.2)}.ability-level.beginner{background:rgba(34,197,94,.1);border-color:#22c55e4d}.ability-level.intermediate{background:rgba(245,158,11,.1);border-color:#f59e0b4d}.ability-level.advanced{background:rgba(239,68,68,.1);border-color:#ef44444d}.ability-level.expert{background:rgba(139,92,246,.1);border-color:#8b5cf64d}.ability-level h5{margin:0 0 .75rem;font-size:1.125rem}.ability-level ul{margin:0;padding-left:1.25rem}.ability-level li{margin-bottom:.25rem;font-size:.875rem;opacity:.9}@media (max-width: 768px){.about-container{padding:1rem}.about-header h1{font-size:2rem}.about-section{padding:1.5rem}.features-grid{grid-template-columns:1fr}.how-to-steps{gap:1rem}.step{flex-direction:column;text-align:center}.ability-levels{grid-template-columns:1fr}.tech-explanation h4{font-size:1.125rem}.tech-explanation h5{font-size:1rem}}.recommendation-explanation{background:#f8fafc;border-radius:12px;padding:1rem;margin:1rem 0}.simple-explanation{width:100%}.detailed-explanation{background:#f9fafb;border-radius:8px;padding:1rem;margin-top:1rem}.factor-item{margin-bottom:1rem}.factor-item:last-child{margin-bottom:0}.preference-weight-controls{margin:1rem 0;background:linear-gradient(135deg,#ffffff 0%,#f8fafc 100%);border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .3s ease}.preference-weight-controls:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.factor-control{margin-bottom:1rem}.preference-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:12px;border-radius:6px;outline:none;transition:all .3s ease;cursor:pointer}.preference-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:white;cursor:pointer;border:3px solid #3b82f6;box-shadow:0 4px 12px #3b82f64d;transition:all .2s ease}.preference-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 6px 20px #3b82f666}.preference-slider::-webkit-slider-thumb:active{transform:scale(1.05)}.preference-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:white;cursor:pointer;border:3px solid #3b82f6;box-shadow:0 4px 12px #3b82f64d;transition:all .2s ease}.preference-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 6px 20px #3b82f666}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:#e5e7eb;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003}.enhanced-destination-card{transition:all .3s ease;border:1px solid #e5e7eb}.enhanced-destination-card:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-2px)}.detailed-card{margin-bottom:2rem}.booking-options{background:#f8fafc;border-radius:12px;padding:1rem;margin:1rem 0}.booking-type-group{margin-bottom:1.5rem}.booking-type-group:last-child{margin-bottom:0}.booking-option-card{transition:all .2s ease;cursor:pointer}.booking-option-card:hover{background:#f0f9ff!important;border-color:#3b82f6!important;transform:translateY(-1px)}.feedback-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.feedback-modal-content{background:white;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.star-rating{margin:1rem 0}.star-rating button{background:none;border:none;cursor:pointer;transition:color .2s ease}.expected-rating{margin:1rem 0}.expected-rating input[type=range]{width:100%;margin:.5rem 0}@media (max-width: 768px){.enhanced-destination-card{margin-bottom:1rem}.detailed-explanation{padding:.75rem}.factor-breakdown{gap:.75rem}.preference-weight-controls .grid.lg\\:grid-cols-4{grid-template-columns:repeat(2,1fr)}.preference-weight-controls .grid.lg\\:grid-cols-2{grid-template-columns:1fr}.preference-weight-controls .grid.grid-cols-2{grid-template-columns:1fr}.factor-control{margin-bottom:.75rem}.preference-slider{height:14px}.preference-slider::-webkit-slider-thumb{width:28px;height:28px;border:4px solid #3b82f6}.preference-slider::-moz-range-thumb{width:28px;height:28px;border:4px solid #3b82f6}.booking-option-card{padding:.75rem!important;flex-direction:column;align-items:flex-start;text-align:left}.booking-option-card>div:last-child{margin-top:.5rem;align-self:stretch;text-align:center}.grid-header .flex{flex-direction:column;gap:1rem;align-items:stretch}.grid-header .flex>div:first-child{text-align:center}.grid-header .flex>div:last-child{justify-content:center}.grid-header .flex.items-center.gap-4{flex-direction:column;gap:.5rem;text-align:center}.feedback-modal{padding:.5rem}.feedback-modal-content{margin:0;border-radius:8px}.star-rating{flex-wrap:wrap;justify-content:center}.star-rating button{width:32px;height:32px}}@media (max-width: 480px){.recommendation-explanation{padding:.75rem}.simple-reasons ul{padding-left:1rem}.detailed-explanation{padding:.5rem}.factor-item{margin-bottom:.75rem}.preference-weight-controls{margin:.5rem 0}.preference-weight-controls .p-6{padding:1rem}.preference-weight-controls .mt-6{margin-top:1rem}.preference-weight-controls .space-y-6>*+*{margin-top:1rem}.preference-weight-controls .gap-6{gap:1rem}.preference-slider{height:16px}.preference-slider::-webkit-slider-thumb{width:32px;height:32px;border:5px solid #3b82f6}.preference-slider::-moz-range-thumb{width:32px;height:32px;border:5px solid #3b82f6}.booking-options{padding:.75rem}.booking-type-group{margin-bottom:1rem}.enhanced-destination-card .grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.enhanced-destination-card .text-center{text-align:left}.enhanced-destination-card .text-center .flex{justify-content:flex-start}.star-rating button{width:28px;height:28px}.star-rating .flex{gap:.25rem}}@media (hover: none){.booking-option-card:hover{background:initial!important;border-color:initial!important;transform:none!important}.booking-option-card:active{background:#f0f9ff!important;border-color:#3b82f6!important;transform:scale(.98)}.enhanced-destination-card:hover{box-shadow:initial;transform:none}.enhanced-destination-card:active{transform:scale(.98)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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 0%,#764ba2 100%);min-height:100vh}#root{min-height:100vh}
