:root{--accent: #ff7a59}*{box-sizing:border-box}body,html,#root{height:100%;margin:0}.page{min-height:100vh;background:#f3f4f6;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:.25rem 2rem 2rem;font-family:var(--font, "Segoe UI", system-ui, -apple-system, sans-serif);max-width:520px;margin:0 auto;width:100%}.logo{max-height:180px;width:auto;margin-bottom:4px;object-fit:contain}.logo-placeholder{height:180px;margin-bottom:4px;padding:0 20px;border:2px dashed #d1d5db;border-radius:8px;color:#9ca3af;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.title{margin:0 0 2px;font-size:1.8rem}.subtitle{margin:0 0 12px;color:#6b7280}.form{display:flex;flex-direction:column;gap:10px}.form label{font-weight:600;font-size:.9rem}.form input,.form textarea,.form select,.panel input,.panel select{padding:8px 10px;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem}.row{display:flex;gap:12px}.row>div{flex:1}.button{margin-top:6px;border:none;border-radius:999px;padding:10px 16px;color:#fff;font-weight:700;cursor:pointer}.admin-dot{position:fixed;right:14px;bottom:14px;width:16px;height:16px;border-radius:50%;background:#0006;border:2px solid rgba(255,255,255,.8);z-index:5;cursor:pointer}.admin-dot:hover{background:#0009;border-color:#fff}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;padding:28px 24px 20px;max-width:340px;width:90%;text-align:center;box-shadow:0 8px 30px #0003}.modal p{margin:0 0 18px;font-size:1rem;color:#111827;line-height:1.5}.modal .button{width:100%}.panel{position:fixed;right:20px;top:80px;width:480px;max-height:85vh;background:#fff;padding:24px;border-radius:12px;z-index:6;box-shadow:0 8px 30px #00000026;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.panel:before{content:"";position:fixed;inset:0;background:#00000080;z-index:-1}.panel h3{margin:0 0 8px}.panel p{margin:0 0 12px;font-size:.9rem;color:#666}.panel label{display:block;margin-bottom:6px;font-weight:600;font-size:.9rem}.panel input,.panel select{width:100%}.panel-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px}.btn{padding:10px 12px;border-radius:8px;border:none;cursor:pointer;background:#111827;color:#fff;font-weight:600;width:100%}.btn.secondary{background:#6b7280}.btn.ghost{background:transparent;color:#111827;border:1px solid #e5e7eb}.children-ages{display:flex;flex-direction:column;gap:10px}.ages-row{display:flex;flex-wrap:wrap;gap:10px}.ages-row input{flex:1;min-width:140px}.airport-wrapper{position:relative;width:100%}.airport-wrapper input{width:100%;display:block;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.airport-wrapper input:focus{white-space:normal}.airport-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:10;box-shadow:0 4px 6px #0000001a}.airport-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6}.airport-item:hover{background:#f9fafb}.airport-item:last-child{border-bottom:none}.airport-item strong{color:#ff7a59;margin-right:8px}.date-range-container{position:relative;width:100%}.date-range-input{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem;cursor:pointer;box-sizing:border-box}.date-range-input:hover{background:#f9fafb}.calendar-popup{position:absolute;top:100%;left:0;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:20;padding:12px;margin-top:4px;width:320px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600;font-size:.9rem}.calendar-header button{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:4px 8px;color:#666}.calendar-header button:hover{color:#ff7a59}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;font-weight:600;font-size:.8rem;text-align:center;color:#666}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{padding:8px;text-align:center;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:.9rem;background:#f9fafb;transition:all .2s}.calendar-day.empty{cursor:default;background:transparent;border:none}.calendar-day:not(.empty):hover{background:#f3f4f6;border:1px solid #d1d5db}.calendar-day.in-range{background:#ffe9df}.calendar-day.selected{background:#ff7a59;color:#fff;font-weight:600;border:1px solid #ff7a59}.calendar-day.selected:hover{background:#ff6a45;border:1px solid #ff6a45}.row>div{display:flex;flex-direction:column;gap:6px}.nights-display{display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;gap:0;min-width:70px;height:fit-content;background:transparent}.nights-number{font-size:.95rem;font-weight:700;line-height:1;color:#111827}.tab-group{display:flex;gap:8px;flex-wrap:wrap}.tab-btn{padding:8px 18px;border-radius:999px;border:1px solid #d1d5db;background:#fff;font-size:.9rem;font-weight:600;cursor:pointer;color:#374151;transition:all .2s}.tab-btn:hover{border-color:#9ca3af;background:#f9fafb}.tab-btn.active{color:#fff;border-color:transparent}@media(max-width:768px){.page{padding:1rem;align-items:stretch;padding-bottom:0;max-width:100%}.card{padding:1rem 1.25rem;max-width:100%;width:100%;max-height:50vh;overflow-y:auto;border-radius:16px 16px 0 0;background:#fffffffa!important}.logo{max-height:132px}.logo-placeholder{height:132px}.title{font-size:1.3rem;margin-bottom:3px}.subtitle{font-size:.8rem;margin-bottom:10px}.form{gap:7px}.form label{font-size:.8rem;margin-bottom:2px}.form input,.form textarea,.form select{padding:6px 8px;font-size:.9rem}.button{padding:9px 14px}.row{flex-direction:column;gap:7px}.ages-row input{min-width:90px}.date-range-container{position:static}.calendar-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;margin-top:0}.panel{position:fixed;inset:0;width:100%;max-height:100vh;border-radius:0}}@media(max-width:480px){.card{padding:1.25rem}.title{font-size:1.3rem}.form input,.form textarea,.form select{font-size:.9rem}.calendar-popup{width:260px}.calendar-day{padding:6px;font-size:.85rem}}
