/* Memoroam — Trip Form */

/* ADD TRIP DRAWER */
.add-overlay{position:fixed;inset:0;background:rgba(20,15,10,.6);backdrop-filter:blur(10px);z-index:300;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.add-overlay.open{opacity:1;pointer-events:all;}
.add-sheet{width:100%;max-width:390px;background:#FDFAF7;border-radius:28px 28px 0 0;transform:translateY(100%);transition:transform .4s cubic-bezier(.32,.72,0,1);max-height:96vh;display:flex;flex-direction:column;overflow:hidden;}
.add-overlay.open .add-sheet{transform:translateY(0);}
.add-header{padding:16px 20px 0;flex-shrink:0;}
.add-handle{width:36px;height:4px;border-radius:2px;background:rgba(0,0,0,.15);margin:0 auto 18px;}
.add-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.add-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--text);}
.add-subtitle{font-size:12px;color:var(--muted);margin-bottom:4px;}
.add-close{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.07);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);}
.step-bar{display:flex;gap:6px;padding:14px 0 16px;}
.step-pip{flex:1;height:3px;border-radius:2px;background:rgba(0,0,0,.1);transition:background .3s,opacity .3s;}
.step-pip.done{background:var(--text);}
.step-pip.active{background:var(--text);opacity:.45;}
.add-body{flex:1;overflow-y:auto;padding:0 20px 8px;}
.step-page{display:none;animation:fadeUp .25s ease;}
.step-page.active{display:block;}
.field-group{margin-bottom:20px;}
.field-label{font-size:10.5px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:block;}
.field-tag{display:inline-block;padding:2px 7px;border-radius:50px;font-size:9px;font-weight:600;background:rgba(0,0,0,.06);color:var(--muted);margin-left:6px;letter-spacing:0;}

/* Airport search — fullscreen panel approach */
.airport-input-btn{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--border);background:white;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);outline:none;cursor:pointer;text-align:left;display:flex;align-items:center;justify-content:space-between;transition:border-color .2s;}
.airport-input-btn.filled{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;}
.airport-input-btn.empty{color:var(--muted);}
.airport-input-btn:hover{border-color:rgba(0,0,0,.22);}
.airport-input-btn svg{color:var(--muted);flex-shrink:0;}

/* Airport search panel (full-sheet overlay within drawer) */
.apt-search-panel{position:absolute;inset:0;background:#FDFAF7;border-radius:28px 28px 0 0;z-index:10;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);}
.apt-search-panel.open{transform:translateY(0);}
.apt-panel-header{padding:16px 20px 12px;flex-shrink:0;}
.apt-panel-top{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.apt-back-btn{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.07);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted);}
.apt-panel-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--text);}
.apt-search-bar{display:flex;align-items:center;gap:10px;background:white;border-radius:14px;border:1.5px solid var(--border);padding:0 14px;transition:border-color .2s;}
.apt-search-bar:focus-within{border-color:rgba(0,0,0,.3);}
.apt-search-bar svg{color:var(--muted);flex-shrink:0;}
.apt-search-inp{flex:1;padding:14px 0;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--text);outline:none;}
.apt-search-inp::placeholder{color:var(--muted);}
.apt-results{flex:1;overflow-y:auto;padding:0 20px 20px;}
.apt-section-lbl{font-size:10px;font-weight:600;letter-spacing:1.4px;color:var(--muted);text-transform:uppercase;padding:12px 0 8px;display:flex;align-items:center;justify-content:space-between;}
.apt-section-lbl-clear{font-size:10px;font-weight:600;letter-spacing:.3px;text-transform:none;color:var(--muted);opacity:.55;cursor:pointer;display:flex;align-items:center;gap:4px;padding:2px 4px;border-radius:6px;transition:opacity .15s;}
.apt-section-lbl-clear:active{opacity:.85;}
.apt-section-lbl-clear svg{flex-shrink:0;}
.apt-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;transition:opacity .12s;}
.apt-item:last-child{border-bottom:none;}
.apt-item:hover{opacity:.7;}
.apt-flag{font-size:24px;flex-shrink:0;width:32px;text-align:center;}
.apt-code{font-family:'IBM Plex Mono',monospace;font-size:15px;font-weight:600;color:var(--text);width:38px;flex-shrink:0;}
.apt-info{flex:1;}
.apt-name{font-size:13px;font-weight:500;color:var(--text);line-height:1.3;}
.apt-sub{font-size:11px;color:var(--muted);margin-top:1px;}
.apt-empty{text-align:center;padding:32px 20px;color:var(--muted);font-size:13px;}

/* Route preview */
.route-preview{background:white;border-radius:16px;padding:14px 16px;margin-top:4px;border:1.5px solid rgba(0,0,0,.07);}
.rp-row{display:flex;align-items:center;gap:8px;}
.rp-code{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:600;color:var(--text);}
.rp-sep{color:var(--muted);}
.rp-meta{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);margin-top:5px;}

/* Calendar */
.cal-wrap{background:white;border-radius:16px;padding:16px;border:1.5px solid var(--border);}
.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.cal-nav button{background:none;border:none;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s;}
.cal-nav button:hover{background:rgba(0,0,0,.07);}
.cal-month{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--text);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-day-name{font-size:9.5px;font-weight:600;color:var(--muted);text-align:center;padding:4px 0;letter-spacing:.5px;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:12.5px;font-weight:500;color:var(--text);cursor:pointer;transition:background .12s;}
.cal-day:hover:not(.empty):not(.selected):not(.return-selected){background:rgba(0,0,0,.07);}
.cal-day.empty{cursor:default;}
.cal-day.today{color:#C96B72;font-weight:700;}
.cal-day.selected{background:var(--text);color:white;}
.cal-day.in-range{background:rgba(74,140,138,.1);}
.cal-day.return-selected{background:#4A8C8A;color:white;}
.sel-date-display{margin-top:10px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);}
.sel-date-display .sel-nights{color:#4A8C8A;font-weight:600;}

/* Duration input */
.duration-input-wrap{display:flex;align-items:center;gap:10px;background:white;border-radius:14px;border:1.5px solid var(--border);padding:14px 16px;}
.dur-hrs-inp{width:52px;border:none;background:none;font-family:'IBM Plex Mono',monospace;font-size:22px;font-weight:600;color:var(--text);outline:none;text-align:center;-moz-appearance:textfield;}
.dur-hrs-inp::-webkit-outer-spin-button,.dur-hrs-inp::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.dur-unit{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.5px;}
.dur-preview{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);font-weight:500;}

/* Dep time only */
.dep-time-wrap{background:white;border-radius:14px;border:1.5px solid var(--border);overflow:hidden;}
.dep-time-inner{display:flex;align-items:center;gap:12px;padding:14px 16px;}
.dep-time-inner svg{color:var(--muted);flex-shrink:0;}
.dep-time-inp{flex:1;border:none;background:none;font-family:'IBM Plex Mono',monospace;font-size:18px;font-weight:600;color:var(--text);outline:none;}
.dep-time-lbl{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);}
.calc-arr-row{padding:10px 16px 14px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.calc-arr-lbl{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.calc-arr-val{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:600;color:var(--text);}

/* Return date card */
.return-date-wrap{background:white;border-radius:14px;border:1.5px solid var(--border);overflow:hidden;transition:border-color .2s;}
.return-date-wrap.has-date{border-color:rgba(74,140,138,.35);}
.return-date-inner{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;transition:background .15s;}
.return-date-inner:active{background:#f9f6f2;}
.return-date-inner svg{color:var(--muted);flex-shrink:0;}
.return-date-lbl{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);}
.return-date-val{font-family:'IBM Plex Mono',monospace;font-size:15px;font-weight:600;color:var(--text);flex:1;}
.return-date-val.empty{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:400;color:var(--muted);}
.return-date-clear{background:rgba(0,0,0,.07);border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);padding:0;flex-shrink:0;transition:background .15s;}
.return-date-clear:active{background:rgba(0,0,0,.14);}
.return-nights-row{padding:9px 16px 12px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.return-nights-lbl{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.return-nights-val{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;color:#4A8C8A;}

/* Trip type toggle */
.trip-type-toggle{display:flex;gap:8px;}
.trip-type-btn{flex:1;padding:11px 0;border:1.5px solid var(--border);border-radius:50px;background:white;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;letter-spacing:.2px;}
.trip-type-btn.active{border-color:var(--text);color:var(--text);background:rgba(0,0,0,.03);}
.trip-type-btn:not(.active):hover{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.15);}

/* Seat */
.seat-input{width:100%;padding:16px;border-radius:14px;border:1.5px solid var(--border);background:white;font-family:'IBM Plex Mono',monospace;font-size:24px;font-weight:600;color:var(--text);outline:none;letter-spacing:4px;text-transform:uppercase;text-align:center;transition:border-color .2s;}
.seat-input:focus{border-color:rgba(0,0,0,.3);}
.seat-input::placeholder{font-size:14px;letter-spacing:0;font-family:'DM Sans',sans-serif;font-weight:400;text-transform:none;}

/* Airline cards */
.airline-hint{font-size:12px;color:var(--muted);margin-bottom:14px;line-height:1.5;}
.airline-grid{display:flex;flex-direction:column;gap:8px;padding-bottom:8px;}
.airline-card{background:white;border-radius:14px;padding:12px 14px;border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .15s;}
.airline-card:hover{background:#FAFAF7;}
.airline-card.selected-airline{border-color:var(--text);background:#F5F0EA;}
.ac-logo{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.ac-info{flex:1;min-width:0;}
.ac-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ac-code-lbl{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);margin-top:2px;}
.ac-check{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;}
.airline-card.selected-airline .ac-check{background:var(--text);border-color:var(--text);}
.no-airlines{text-align:center;padding:28px 16px;color:var(--muted);font-size:13px;}
.airline-section-label{font-size:9.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);padding:16px 2px 8px;display:flex;align-items:center;gap:8px;}
.airline-section-label:first-child{padding-top:4px;}
.airline-section-label::after{content:'';flex:1;height:1px;background:var(--border);}
.airline-search-wrap{position:relative;display:flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:12px;padding:0 12px;margin-bottom:12px;transition:border-color .2s;}
.airline-search-wrap:focus-within{border-color:rgba(0,0,0,.3);}
.airline-search-wrap svg{color:var(--muted);flex-shrink:0;}
.airline-search-inp{flex:1;padding:11px 0;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);outline:none;}
.airline-search-inp::placeholder{color:var(--muted);}
.airline-search-clear{background:rgba(0,0,0,.08);border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);padding:0;flex-shrink:0;}

/* Footer */
.add-footer{padding:14px 20px 32px;flex-shrink:0;border-top:1px solid var(--border);background:#FDFAF7;}
.btn-row{display:flex;gap:10px;}
.btn-back{flex:0 0 52px;height:52px;border-radius:14px;border:1.5px solid var(--border);background:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:background .15s;}
.btn-back:hover{background:rgba(0,0,0,.06);}
.btn-next{flex:1;height:52px;border-radius:14px;border:none;background:var(--text);color:white;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,opacity .15s;}
.btn-next:hover{opacity:.86;}

/* City search (trip creation step 1) */
.city-search-wrap{display:flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:12px;padding:0 12px;transition:border-color .2s;}
.city-search-wrap:focus-within{border-color:rgba(0,0,0,.3);}
.city-search-wrap svg{color:var(--muted);flex-shrink:0;}
.city-search-inp{flex:1;padding:11px 0;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);outline:none;}
.city-search-inp::placeholder{color:var(--muted);}
.city-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;}
.city-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 10px 7px 12px;border-radius:50px;background:var(--text);color:white;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.2px;}
.city-chip-remove{background:rgba(255,255,255,.2);border:none;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;padding:0;flex-shrink:0;transition:background .15s;}
.city-chip-remove:active{background:rgba(255,255,255,.4);}
.city-results{display:flex;flex-direction:column;gap:0;max-height:260px;overflow-y:auto;}
.city-result-item{display:flex;align-items:center;gap:10px;padding:12px 4px;border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:500;color:var(--text);transition:opacity .12s;}
.city-result-item:last-child{border-bottom:none;}
.city-result-item:active{opacity:.7;}
.city-result-item.selected{color:#4A8C8A;font-weight:600;}
.city-result-check{width:18px;font-size:13px;color:#4A8C8A;flex-shrink:0;text-align:center;}
.city-hint{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.5;}

/* ── Dark Mode ── */
[data-theme="dark"] .add-sheet,
[data-theme="dark"] .apt-search-panel,
[data-theme="dark"] .add-footer{background:var(--card);}
[data-theme="dark"] .airport-input-btn,
[data-theme="dark"] .apt-search-bar,
[data-theme="dark"] .route-preview,
[data-theme="dark"] .cal-wrap,
[data-theme="dark"] .duration-input-wrap,
[data-theme="dark"] .dep-time-wrap,
[data-theme="dark"] .return-date-wrap,
[data-theme="dark"] .trip-type-btn,
[data-theme="dark"] .seat-input,
[data-theme="dark"] .airline-card,
[data-theme="dark"] .airline-search-wrap,
[data-theme="dark"] .city-search-wrap{background:var(--card);}
[data-theme="dark"] .route-preview{border-color:var(--border);}
