:root{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#264653;background-color:#faf9f6;--section-max-width: min(100%, 860px)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,rgba(233,196,106,.12),transparent 55%),radial-gradient(circle at bottom right,rgba(42,157,143,.12),transparent 45%)}#app{min-height:100vh}.layout{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 4rem;display:flex;flex-direction:column;gap:2rem}.header{position:sticky;top:0;z-index:100;background:#ffffffe0;border-radius:18px;box-shadow:0 24px 45px -30px #2646538c;border:1px solid rgba(38,70,83,.06);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header--scrolled{border-radius:0 0 18px 18px;box-shadow:0 8px 24px -12px #26465366}.header-content{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem;align-items:flex-start;padding:1.75rem 2rem;transition:padding .3s ease}.header-content--collapsed{padding:1rem 2rem;justify-content:flex-end}.header-text{transition:opacity .3s ease,transform .3s ease,max-height .3s ease;overflow:hidden}.header-content--collapsed .header-text{opacity:0;transform:translateY(-10px);max-height:0;margin:0}.brand{margin:0;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.subtitle{margin:.25rem 0 0;color:#264653a6}.header-right{display:flex;align-items:center;gap:1.5rem}.profile-link{color:#2a9d8f;text-decoration:none;font-weight:600;font-size:.95rem;transition:color .2s ease;padding:.5rem 1rem;border-radius:8px;background:#2a9d8f1a}.profile-link:hover{color:#23877a;background:#2a9d8f26}.price{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;transition:transform .3s ease}.header-content--collapsed .price{flex-direction:row;align-items:center;gap:.75rem}.price-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.06em;color:#2646538c}.price-value{font-size:2rem;font-weight:700;color:#2a9d8f;transition:font-size .3s ease}.header-content--collapsed .price-value{font-size:1.5rem}.stepper{display:flex;justify-content:center}.progress{background:#ffffffe0;border-radius:18px;padding:1.75rem 2rem;box-shadow:0 24px 45px -28px #2646538c;border:1px solid rgba(38,70,83,.06);display:flex;flex-direction:column;gap:1.25rem;width:var(--section-max-width)}.progress-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.75rem}.progress-label{font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#2646538c}.progress-title{font-size:1.1rem;font-weight:600;color:#264653}.progress-bar__track{position:relative;height:8px;border-radius:999px;background:#2646531f;overflow:hidden}.progress-bar__fill{position:absolute;top:0;left:0;bottom:0;width:0;border-radius:inherit;background:linear-gradient(90deg,#2a9d8f,#e9c46a,#e76f51);transition:width .22s ease}.progress-bar__steps{display:flex;justify-content:space-between;gap:.5rem;margin-top:1rem}.progress-bar__step{background:none;border:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;flex:1;min-width:0}.progress-bar__step[disabled]{cursor:default}.progress-bar__number{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#faf9f6;border:2px solid rgba(38,70,83,.25);font-weight:600;color:#264653b3;transition:all .18s ease;box-shadow:0 10px 18px -16px #264653b3}.progress-bar__label{font-size:.85rem;font-weight:500;text-align:center;color:#2646538c;max-width:120px}.progress-bar__step--completed .progress-bar__number{background:#2a9d8f;color:#faf9f6;border-color:#2a9d8f;box-shadow:0 14px 26px -18px #2a9d8fbf}.progress-bar__step--completed .progress-bar__label{color:#264653e6}.progress-bar__step--active .progress-bar__number{background:#e76f51;color:#faf9f6;border-color:#e76f51;box-shadow:0 16px 28px -18px #e76f51bf;transform:scale(1.08)}.progress-bar__step--active .progress-bar__label{color:#264653}.content{display:flex;justify-content:center}.panel,.summary-panel{background:#ffffffe6;border-radius:18px;padding:2rem;box-shadow:0 24px 45px -32px #26465399;border:1px solid rgba(38,70,83,.06);width:var(--section-max-width)}.panel-section{display:grid;gap:1rem}.panel-section+.panel-section{margin-top:2rem}.panel-section__header h2{margin:0}.panel-section__header p{margin:.25rem 0 0}.cities-scroll{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.75rem;margin:0 -.5rem;padding-left:.5rem;scroll-snap-type:x proximity}.cities-scroll::-webkit-scrollbar{height:7px}.cities-scroll::-webkit-scrollbar-track{background:#2646531f;border-radius:999px}.cities-scroll::-webkit-scrollbar-thumb{background:#e76f51ad;border-radius:999px}.city-card{min-width:240px;border-radius:16px;border:1px solid rgba(38,70,83,.12);background:#faf9f6eb;box-shadow:0 16px 32px -28px #2646538c;display:flex;flex-direction:column;text-align:left;cursor:pointer;transition:all .16s ease;scroll-snap-align:start;overflow:hidden}.city-card:hover,.city-card:focus-visible{border-color:#e76f5199;box-shadow:0 18px 36px -28px #e76f51bf;transform:translateY(-2px)}.city-card--selected{border-color:#e76f51cc;background:#e76f512e;box-shadow:0 20px 36px -26px #e76f51cc}.city-card__image{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;object-position:center}.city-card__body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.25rem}.city-card__name{font-size:1.1rem;font-weight:700;color:#264653}.activities-scroll{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.75rem;margin:0 -.5rem;padding-left:.5rem;scroll-snap-type:x proximity}.activities-scroll::-webkit-scrollbar{height:8px}.activities-scroll::-webkit-scrollbar-track{background:#2646531a;border-radius:999px}.activities-scroll::-webkit-scrollbar-thumb{background:#2a9d8f99;border-radius:999px}.card{background:#faf9f6eb;border-radius:16px;border:1px solid rgba(38,70,83,.08);display:flex;flex-direction:column;cursor:pointer;transition:all .16s ease;outline:none;min-width:260px;scroll-snap-align:start;overflow:hidden}.card:hover,.card:focus-visible{border-color:#2a9d8f73;box-shadow:0 18px 38px -28px #2a9d8f99;transform:translateY(-2px)}.card--selected{border-color:#2a9d8fbf;background:#2a9d8f26}.card--disabled{opacity:.55;pointer-events:none}.card-image{position:relative;height:180px;background-size:cover;background-position:center}.card-image:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#2646530d,#26465366);opacity:.35;transition:opacity .16s ease}.card:hover .card-image:after,.card:focus-visible .card-image:after,.card--selected .card-image:after{opacity:.2}.card-duration{position:absolute;bottom:1rem;left:1rem;background:#faf9f6eb;color:#264653;box-shadow:0 12px 24px -18px #000000a6}.card-body{display:grid;gap:.75rem;padding:1.5rem}.card-title{margin:0;font-size:1.25rem}.card-header{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem}.card-header h2{margin:0;font-size:1.25rem}.badge{background:#e76f5126;color:#e76f51;border-radius:999px;padding:.35rem .75rem;font-size:.75rem;font-weight:600}.card-description{margin:0;color:#264653b3}.card-footer{display:flex;justify-content:space-between;align-items:center;font-weight:600}.card-price{color:#264653}.card-cta{color:#2a9d8f;font-size:.9rem}.form-grid{display:grid;gap:1.25rem}label{display:grid;gap:.5rem;font-weight:600}input[type=date],input[type=time],input[type=number]{font:inherit;padding:.8rem 1rem;border-radius:12px;border:1px solid rgba(38,70,83,.22);background:#fff;color:inherit;transition:border-color .16s ease,box-shadow .16s ease}input:focus{border-color:#2a9d8fb3;box-shadow:0 0 0 3px #2a9d8f2e;outline:none}.form-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end;margin-top:.5rem}button{border-radius:999px;border:none;padding:.75rem 1.6rem;font-weight:600;cursor:pointer;font:inherit;transition:transform .12s ease,box-shadow .16s ease}button:hover{transform:translateY(-1px)}.primary{background:linear-gradient(135deg,#e76f51,#d25a3d);color:#faf9f6;box-shadow:0 14px 28px -18px #e76f51bf}.primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.ghost{background:#26465312;color:#264653}.extras-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.extras-list{list-style:none;padding:0;margin:0;display:grid;gap:1rem}.extra-item{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;padding:1rem 1.25rem;border-radius:14px;border:1px solid rgba(38,70,83,.1);background:#faf9f6cc;cursor:pointer}.extra-item:hover{border-color:#2a9d8f73}.extra-title{margin:0;font-weight:600}.extra-description{margin:.15rem 0 0;color:#26465399;font-size:.9rem}.extra-price{font-weight:600;color:#2a9d8f}.payment h2,.summary-panel h2{margin-top:0}.muted{color:#2646538c}.summary{list-style:none;padding:0;margin:1.25rem 0;display:grid;gap:.75rem}.summary li{display:flex;justify-content:space-between;gap:1rem;font-size:.95rem}.summary li strong{font-weight:600;text-align:right}.price-breakdown{margin-top:2rem;display:grid;gap:.5rem}.summary-panel--bottom{width:var(--section-max-width);margin:0 auto 1rem}.price-line{display:flex;justify-content:space-between;color:#264653b3}.price-total{margin-top:.8rem;display:flex;justify-content:space-between;font-size:1.2rem;font-weight:700;color:#264653}@media(max-width:1024px){.summary-panel--bottom,.panel{max-width:100%}}.auth-modal{max-width:460px}.auth-modal-header{text-align:center;margin-bottom:2rem}.auth-modal-header h2{margin:0 0 .5rem;color:#264653;font-size:1.75rem}.auth-form{display:grid;gap:1.25rem}.form-group{display:grid;gap:.5rem}.form-group label{font-weight:600;color:#264653;font-size:.95rem}.form-group input{width:100%;padding:.875rem 1rem;border:1px solid rgba(38,70,83,.2);border-radius:10px;font:inherit;background:#faf9f6;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{border-color:#2a9d8fb3;box-shadow:0 0 0 3px #2a9d8f2e;outline:none}.form-group input:disabled{opacity:.6;cursor:not-allowed}.auth-error{padding:.875rem 1rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:10px;color:#721c24;font-size:.9rem;margin-bottom:.5rem}.auth-submit{width:100%;margin-top:.5rem}.auth-switch{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(38,70,83,.1)}.auth-switch p{margin:0;color:#264653b3;font-size:.9rem}.auth-link{background:none;border:none;color:#2a9d8f;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font:inherit;transition:color .2s ease}.auth-link:hover{color:#23877a;transform:none}.auth-link:disabled{opacity:.5;cursor:not-allowed}.modal-close{position:absolute;top:1rem;right:1rem;background:#2646531a;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;color:#264653;transition:background .2s ease;line-height:1}.modal-close:hover{background:#26465333}@media(max-width:640px){.layout{padding:2.5rem 1rem 3rem}.header,.panel,.summary-panel,.progress{padding:1.5rem}.city-card{min-width:170px}.summary-panel--bottom{margin-bottom:.5rem}.extras-header{flex-direction:column;align-items:flex-start;gap:.75rem}.extra-item{grid-template-columns:1fr}.price{align-items:flex-start}.auth-modal{max-width:100%;margin:1rem}}.modal-overlay{position:fixed;inset:0;background:#264653bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#faf9f6;border-radius:20px;max-width:520px;width:100%;box-shadow:0 32px 64px -24px #26465399;border:1px solid rgba(38,70,83,.1);animation:slideUp .3s ease;overflow:hidden;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,#e76f5126,#e9c46a26);padding:2rem 2rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(38,70,83,.08)}.modal-icon{font-size:2.5rem;line-height:1}.modal-title{margin:0;font-size:1.5rem;font-weight:700;color:#264653}.modal-body{padding:2rem;color:#264653;line-height:1.7}.modal-body p{margin:0 0 1.25rem;font-size:1rem}.modal-body p:last-child{margin-bottom:0}.modal-warning{font-weight:600;color:#e76f51!important;background:#e76f511a;padding:1rem;border-radius:10px;border-left:4px solid #e76f51}.modal-footer{padding:0 2rem 2rem;display:flex;justify-content:flex-end}.modal-footer button{min-width:140px}@media(max-width:640px){.modal-content{max-width:100%;margin:1rem}.modal-header{padding:1.5rem 1.5rem 1.25rem}.modal-icon{font-size:2rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.5rem}.modal-footer{padding:0 1.5rem 1.5rem}.modal-footer button{width:100%}.header-right{flex-direction:column;align-items:flex-end;gap:1rem}}.profile-container{min-height:100vh;background:radial-gradient(circle at top left,rgba(233,196,106,.12),transparent 55%),radial-gradient(circle at bottom right,rgba(42,157,143,.12),transparent 45%);padding:2rem 1rem}.profile-header{max-width:1200px;margin:0 auto 2rem}.back-button{background:#26465312;border:none;border-radius:8px;padding:.5rem 1rem;color:#264653;font-weight:600;cursor:pointer;margin-bottom:1rem;transition:background .2s ease}.back-button:hover{background:#2646531f}.profile-header-content{background:#ffffffe0;border-radius:18px;padding:2rem;box-shadow:0 24px 45px -30px #2646538c;border:1px solid rgba(38,70,83,.06);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.profile-header h1{margin:0;font-size:2rem;color:#264653}.profile-subtitle{margin:.5rem 0 0;color:#264653a6}.profile-user-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.profile-user-info span{color:#264653b3;font-size:.95rem}.profile-loading,.profile-empty{max-width:1200px;margin:0 auto;background:#ffffffe0;border-radius:18px;padding:4rem 2rem;text-align:center;box-shadow:0 24px 45px -30px #2646538c;border:1px solid rgba(38,70,83,.06)}.profile-empty-icon{font-size:4rem;margin-bottom:1rem}.profile-empty h2{margin:0 0 .5rem;color:#264653}.profile-empty p{margin:0 0 2rem;color:#264653a6}.profile-error{max-width:1200px;margin:0 auto 2rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:12px;padding:1rem 1.5rem;color:#721c24}.bookings-list{max-width:1200px;margin:0 auto;display:grid;gap:1.5rem}.booking-card{background:#ffffffe0;border-radius:18px;padding:2rem;box-shadow:0 24px 45px -30px #2646538c;border:1px solid rgba(38,70,83,.06);transition:transform .2s ease,box-shadow .2s ease}.booking-card:hover{transform:translateY(-2px);box-shadow:0 32px 60px -24px #264653a6}.booking-cancelled{opacity:.7;background:#fff9}.booking-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(38,70,83,.1)}.booking-card-header h3{margin:0 0 .25rem;font-size:1.5rem;color:#264653}.booking-location{margin:0;color:#264653a6;font-size:.95rem}.status-badge{padding:.375rem .875rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-confirmed{background:#d4edda;color:#155724}.status-cancelled{background:#f8d7da;color:#721c24}.booking-details{display:grid;gap:.75rem;margin-bottom:1.5rem}.booking-detail-row{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid rgba(38,70,83,.05)}.booking-detail-row:last-of-type{border-bottom:none}.detail-label{font-weight:600;color:#264653b3}.detail-value{color:#264653;text-align:right}.booking-amount{font-weight:600;color:#2a9d8f;font-size:1.1rem}.booking-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid rgba(38,70,83,.1)}.primary.danger{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 14px 28px -18px #dc3545bf}.primary.danger:hover{background:linear-gradient(135deg,#c82333,#bd2130)}@media(max-width:640px){.profile-header-content{flex-direction:column;align-items:flex-start}.profile-user-info{width:100%;justify-content:space-between}.booking-card{padding:1.5rem}.booking-card-header{flex-direction:column;gap:1rem}.booking-actions{flex-direction:column}.booking-actions button{width:100%}}.footer{margin-top:4rem;padding-top:2rem;border-top:1px solid rgba(38,70,83,.12)}.footer-content{display:flex;flex-direction:column;gap:2rem;align-items:center;text-align:center}.footer-logo{display:flex;justify-content:center;align-items:center}.footer-logo-img{max-width:100%;height:auto;max-height:60px;width:auto;object-fit:contain}.footer-links{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;align-items:center}.footer-link{color:#2a9d8f;text-decoration:none;font-weight:500;transition:color .2s ease}.footer-link:hover,.footer-link:focus{color:#e76f51;text-decoration:underline}.footer-copyright{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(38,70,83,.08);text-align:center}.footer-copyright p{margin:0;color:#26465399;font-size:.875rem}.terms-page{max-width:800px;margin:0 auto;padding:2rem 0}.terms-page h1{font-size:2rem;font-weight:700;color:#264653;margin-bottom:2rem;text-align:center}.terms-content{background:#faf9f6eb;border-radius:16px;padding:2.5rem;border:1px solid rgba(38,70,83,.12);box-shadow:0 16px 32px -28px #2646538c}.terms-content h2{font-size:1.5rem;font-weight:600;color:#264653;margin-top:2rem;margin-bottom:1rem}.terms-content h2:first-of-type{margin-top:0}.terms-content p{color:#264653cc;line-height:1.7;margin-bottom:1rem}.terms-content a{color:#2a9d8f;text-decoration:none;font-weight:500}.terms-content a:hover{color:#e76f51;text-decoration:underline}@media(max-width:768px){.footer{margin-top:3rem;padding-top:1.5rem}.footer-content{gap:1.5rem}.footer-logo-img{max-height:50px}.footer-links{flex-direction:column;gap:1rem}.terms-content{padding:1.5rem}.terms-page h1{font-size:1.75rem}.terms-content h2{font-size:1.25rem}}
