/*
  BAG·INTEL — Terminal aesthetic CSS (auth screens + dashboard)
  Loaded directly in layout.tsx via a <link> tag to avoid
  being processed by Tailwind's @import chain.
*/

/* ── Terminal palette ──────────────────────────────────────────────────── */
:root {
  --bg:   #050810;
  --bg2:  #080d1a;
  --bg3:  #0d1628;
  --sf:   rgba(13,22,40,.9);
  --sf2:  rgba(17,28,52,.9);
  --bd:   rgba(0,212,255,.12);
  --bd2:  rgba(0,212,255,.28);
  --acc:  #00d4ff;
  --grn:  #00ff9d;
  --amb:  #ffbe00;
  --red:  #ff4d4d;
  --txt:  #e8f4ff;
  --txt2: #8bafc8;
  --txt3: #3d5570;
  --fd:   var(--font-rajdhani, 'Rajdhani', sans-serif);
  --fm:   var(--font-ibm-mono, 'IBM Plex Mono', monospace);
}

/* ── Auth shell ────────────────────────────────────────────────────────── */
.auth-shell {
  min-height: 100vh;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  position: relative;
}

.auth-bg-grid {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(0,212,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,.03) 1px, transparent 1px);
  background-size: 40px 40px;
}
.auth-bg-glow {
  position: fixed; top: -200px; left: 50%; transform: translateX(-50%);
  width: 900px; height: 600px; pointer-events: none; z-index: 0;
  background: radial-gradient(ellipse, rgba(0,80,180,.12) 0%, transparent 70%);
}

.auth-card {
  position: relative; z-index: 1;
  width: 100%; max-width: 420px;
  background: var(--sf);
  border: 1px solid var(--bd2);
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: 0 24px 64px rgba(0,0,0,.6), 0 0 0 1px rgba(0,212,255,.06);
}

.auth-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.auth-logo-icon {
  width: 40px; height: 40px;
  background: linear-gradient(135deg, var(--acc), #0078ff);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: #000;
  box-shadow: 0 4px 16px rgba(0,212,255,.35);
}
.auth-logo-name { font-family: var(--fd); font-size: 20px; font-weight: 700; letter-spacing: 3px; color: var(--acc); text-shadow: 0 0 14px rgba(0,212,255,.45); }
.auth-logo-sub { font-size: 10px; color: var(--txt2); letter-spacing: .8px; text-transform: uppercase; margin-top: 1px; }

.auth-title { font-size: 20px; font-weight: 600; color: var(--txt); margin-bottom: 4px; }
.auth-subtitle { font-size: 13px; color: var(--txt2); margin-bottom: 24px; line-height: 1.5; }

.auth-form { display: flex; flex-direction: column; gap: 18px; }
.auth-field { display: flex; flex-direction: column; gap: 6px; }
.auth-label { font-size: 12px; font-weight: 500; color: var(--txt2); letter-spacing: .3px; text-transform: uppercase; }
.auth-label-row { display: flex; justify-content: space-between; align-items: center; }

.auth-input {
  width: 100%;
  background: rgba(8,13,26,.8);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 11px 14px;
  color: var(--txt);
  font-size: 14px;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
.auth-input:focus { border-color: var(--acc); box-shadow: 0 0 0 3px rgba(0,212,255,.12); }
.auth-input::placeholder { color: var(--txt3); }
.auth-input-err { border-color: var(--red) !important; }
.auth-input-code { font-family: var(--fm); font-size: 22px; letter-spacing: 6px; text-align: center; }

.auth-input-wrap { position: relative; }
.auth-eye { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--txt3); cursor: pointer; transition: color .15s; display: flex; align-items: center; }
.auth-eye:hover { color: var(--txt); }

.auth-hint-err { font-size: 11px; color: var(--red); margin-top: 3px; }
.auth-error { display: flex; align-items: flex-start; gap: 8px; padding: 11px 14px; background: rgba(255,77,77,.07); border: 1px solid rgba(255,77,77,.3); border-radius: 8px; font-size: 13px; color: var(--red); }
.auth-link { font-size: 13px; color: var(--acc); text-decoration: none; transition: opacity .15s; }
.auth-link:hover { opacity: .8; text-decoration: underline; }

.auth-btn {
  width: 100%; padding: 13px;
  background: linear-gradient(135deg, var(--acc), #0078ff);
  border: none; border-radius: 9px;
  color: #000; font-family: var(--fd);
  font-size: 16px; font-weight: 700; letter-spacing: 1px;
  cursor: pointer; transition: all .2s;
  box-shadow: 0 4px 20px rgba(0,212,255,.3);
  display: flex; align-items: center; justify-content: center;
  margin-top: 4px;
}
.auth-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 6px 28px rgba(0,212,255,.5); }
.auth-btn:disabled { opacity: .4; cursor: not-allowed; background: #1e2a3a; box-shadow: none; color: var(--txt2); transform: none; }

.auth-spinner { display: inline-block; width: 18px; height: 18px; border-radius: 50%; border: 2px solid rgba(0,0,0,.25); border-top-color: #000; animation: terminal-spin .8s linear infinite; }
@keyframes terminal-spin { to { transform: rotate(360deg); } }

.auth-footer-text { text-align: center; font-size: 13px; color: var(--txt2); margin-top: 22px; }
.auth-footer { position: relative; z-index: 1; margin-top: 24px; font-size: 11px; color: var(--txt3); letter-spacing: .5px; text-align: center; }

/* ── Dashboard shell ───────────────────────────────────────────────────── */
.app { min-height: 100vh; position: relative; background: var(--bg); color: var(--txt); }
.bg-grid {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(0,212,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,.03) 1px, transparent 1px);
  background-size: 40px 40px;
}
.bg-glow { position: fixed; top: -200px; left: 50%; transform: translateX(-50%); width: 900px; height: 600px; pointer-events: none; z-index: 0; background: radial-gradient(ellipse, rgba(0,80,180,.1) 0%, transparent 70%); }

/* ── Dashboard header ──────────────────────────────────────────────────── */
.header { position: relative; z-index: 10; display: flex; align-items: center; justify-content: space-between; padding: 14px 32px; border-bottom: 1px solid var(--bd); background: rgba(5,8,16,.96); backdrop-filter: blur(10px); }
.logo { display: flex; align-items: center; gap: 14px; }
.logo-plane { font-size: 26px; transform: rotate(-45deg); display: inline-block; filter: drop-shadow(0 0 8px var(--acc)); }
.logo-name { font-family: var(--fd); font-size: 22px; font-weight: 700; letter-spacing: 3px; color: var(--acc); text-shadow: 0 0 18px rgba(0,212,255,.5); }
.logo-sub { font-size: 10px; color: var(--txt2); letter-spacing: 1px; text-transform: uppercase; margin-top: 2px; }
.header-badges { display: flex; gap: 8px; }
.badge { font-family: var(--fm); font-size: 10px; padding: 3px 9px; border-radius: 4px; letter-spacing: 1px; }
.badge.yellow { border: 1px solid rgba(255,190,0,.4); color: var(--amb); background: rgba(255,190,0,.05); }
.badge.blue   { border: 1px solid var(--bd2); color: var(--acc); background: rgba(0,212,255,.05); }
.badge.green  { border: 1px solid rgba(0,255,157,.4); color: var(--grn); background: rgba(0,255,157,.05); }

.header-right { display: flex; align-items: center; gap: 16px; }
.user-pill { display: flex; align-items: center; gap: 8px; font-family: var(--fm); font-size: 11px; color: var(--txt2); letter-spacing: .5px; }
.user-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--grn); box-shadow: 0 0 6px var(--grn); }
.signout-btn { background: none; border: 1px solid var(--bd2); color: var(--txt2); padding: 5px 12px; border-radius: 6px; font-size: 12px; cursor: pointer; transition: all .15s; }
.signout-btn:hover { border-color: var(--red); color: var(--red); }

/* ── Global API bar ────────────────────────────────────────────────────── */
.global-api-bar { position: relative; z-index: 9; padding: 10px 32px; background: rgba(8,13,26,.8); border-bottom: 1px solid var(--bd); }
.api-bar { display: flex; align-items: center; gap: 10px; max-width: 560px; }
.api-bar span { font-size: 16px; }
.api-bar input { flex: 1; background: var(--sf); border: 1px solid var(--bd); color: var(--txt); padding: 8px 12px; border-radius: 7px; font-family: var(--fm); font-size: 12px; outline: none; transition: border-color .2s; }
.api-bar input:focus { border-color: var(--acc); }
.api-bar input::placeholder { color: var(--txt3); }

/* ── Tab nav ───────────────────────────────────────────────────────────── */
.tab-nav { position: relative; z-index: 8; display: flex; border-bottom: 1px solid var(--bd); background: rgba(5,8,16,.9); }
.nav-tab { flex: 1; padding: 12px 16px; background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; transition: all .2s; display: flex; flex-direction: column; align-items: center; gap: 2px; }
.nt-label { font-family: var(--fd); font-size: 14px; font-weight: 600; color: var(--txt2); letter-spacing: .5px; }
.nt-desc  { font-size: 10px; color: var(--txt3); }
.nav-tab:hover .nt-label { color: var(--txt); }
.nav-tab.on { border-bottom-color: var(--acc); background: rgba(0,212,255,.04); }
.nav-tab.on .nt-label { color: var(--acc); }
.nav-tab.on .nt-desc  { color: var(--txt2); }

/* ── Main ──────────────────────────────────────────────────────────────── */
.main { position: relative; z-index: 1; padding: 28px 32px; max-width: 1500px; margin: 0 auto; }

/* ── Loader ────────────────────────────────────────────────────────────── */
.loader-box { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 60px; color: var(--txt2); }
.loader-ring { width: 48px; height: 48px; border-radius: 50%; border: 3px solid rgba(0,212,255,.2); border-top-color: var(--acc); animation: terminal-spin .8s linear infinite; }
.spin { display: inline-block; width: 16px; height: 16px; border-radius: 50%; border: 2px solid rgba(0,212,255,.3); border-top-color: var(--acc); animation: terminal-spin .8s linear infinite; vertical-align: middle; }

/* ── Error box ─────────────────────────────────────────────────────────── */
.err-box { display: flex; gap: 10px; align-items: flex-start; margin-top: 14px; padding: 14px 16px; background: rgba(255,77,77,.07); border: 1px solid rgba(255,77,77,.3); border-radius: 10px; font-size: 13px; color: var(--red); }

/* ── Dropzone ──────────────────────────────────────────────────────────── */
.dropzone { border: 2px dashed var(--bd2); border-radius: 12px; cursor: pointer; transition: all .2s; background: var(--sf); min-height: 220px; display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
.dropzone.small { min-height: 180px; }
.dropzone.active, .dropzone:hover { border-color: var(--acc); background: rgba(0,212,255,.04); }
.dropzone.filled { border-style: solid; }
.drop-msg { text-align: center; padding: 30px; }
.drop-icon { font-size: 44px; margin-bottom: 12px; }
.drop-msg p { font-family: var(--fd); font-size: 17px; font-weight: 600; margin-bottom: 4px; }
.drop-msg small { color: var(--txt2); font-size: 12px; }
.drop-preview { width: 100%; height: 100%; object-fit: contain; padding: 10px; max-height: 220px; }

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn-analyze { width: 100%; margin-top: 12px; padding: 13px; background: linear-gradient(135deg, var(--acc), #0078ff); border: none; border-radius: 9px; color: #000; font-family: var(--fd); font-size: 17px; font-weight: 700; letter-spacing: 1px; cursor: pointer; transition: all .2s; box-shadow: 0 4px 20px rgba(0,212,255,.3); display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-analyze:hover:not(.disabled) { transform: translateY(-1px); box-shadow: 0 6px 28px rgba(0,212,255,.5); }
.btn-analyze.disabled { opacity: .4; cursor: not-allowed; background: #1e2a3a; box-shadow: none; color: var(--txt2); }
.btn-search { padding: 0 18px; background: var(--acc); border: none; border-radius: 0 9px 9px 0; color: #000; font-size: 18px; cursor: pointer; transition: background .2s; }
.btn-search:hover:not(:disabled) { background: #00b8e0; }
.btn-search:disabled { opacity: .5; cursor: not-allowed; }
.btn-refresh { background: none; border: 1px solid var(--bd2); color: var(--acc); padding: 6px 14px; border-radius: 6px; font-size: 13px; cursor: pointer; transition: all .2s; }
.btn-refresh:hover { background: rgba(0,212,255,.07); }

/* ── Save toggle ───────────────────────────────────────────────────────── */
.save-toggle { display: flex; align-items: center; gap: 8px; margin-top: 10px; font-size: 13px; color: var(--txt2); cursor: pointer; }
.save-toggle input { accent-color: var(--acc); }

/* ── Analyze layout ────────────────────────────────────────────────────── */
.analyze-layout { display: grid; grid-template-columns: 380px 1fr; gap: 28px; }

/* ── Result card ───────────────────────────────────────────────────────── */
.result-card { background: var(--sf); border: 1px solid var(--bd); border-radius: 14px; overflow: hidden; }
.saved-banner { background: rgba(0,255,157,.08); border-bottom: 1px solid rgba(0,255,157,.2); color: var(--grn); padding: 8px 16px; font-family: var(--fm); font-size: 12px; }
.result-hero-row { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--bd); }
.rh-brand { font-family: var(--fd); font-size: 24px; font-weight: 700; }
.rh-model { font-size: 13px; color: var(--txt2); margin-top: 2px; }
.r-tabs { display: flex; border-bottom: 1px solid var(--bd); background: rgba(0,0,0,.2); }
.r-tab { flex: 1; padding: 10px; background: none; border: none; border-bottom: 2px solid transparent; color: var(--txt2); font-family: var(--fm); font-size: 10px; letter-spacing: 1px; cursor: pointer; transition: all .2s; }
.r-tab.on { color: var(--acc); border-bottom-color: var(--acc); background: rgba(0,212,255,.04); }
.r-body { padding: 18px 20px; }
.r-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.r-block { background: var(--bg3); border: 1px solid var(--bd); border-radius: 9px; padding: 14px; }
.rb-title { font-family: var(--fd); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--txt2); margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--bd); }
.ms-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.ms-label { color: var(--txt2); }
.ms-value { color: var(--txt); font-weight: 500; text-align: right; }

/* ── Color rows ────────────────────────────────────────────────────────── */
.color-row { display: flex; align-items: center; gap: 8px; padding: 3px 0; font-size: 13px; }
.color-dot { width: 14px; height: 14px; border-radius: 50%; border: 1px solid rgba(255,255,255,.1); flex-shrink: 0; }
.color-pct { color: var(--txt2); font-size: 11px; margin-left: auto; }

/* ── Dim row ───────────────────────────────────────────────────────────── */
.dim-row { display: flex; align-items: center; gap: 10px; justify-content: center; padding: 12px 0; }
.dim-box { text-align: center; }
.dim-v { font-family: var(--fd); font-size: 26px; font-weight: 700; color: var(--acc); display: block; }
.dim-u { font-size: 11px; color: var(--txt2); }

/* ── Wear dots ─────────────────────────────────────────────────────────── */
.wear-dots { display: flex; gap: 3px; margin: 6px 0; }
.wd { width: 18px; height: 18px; border-radius: 3px; background: rgba(255,255,255,.08); transition: background .3s; }
.wd.green { background: var(--grn); }
.wd.amber { background: var(--amb); }
.wd.red   { background: var(--red); }

/* ── Value big ─────────────────────────────────────────────────────────── */
.value-big { font-family: var(--fd); font-size: 26px; font-weight: 700; color: var(--grn); }

/* ── IATA hero ─────────────────────────────────────────────────────────── */
.iata-hero-big { text-align: center; font-family: var(--fm); font-size: 56px; font-weight: 700; letter-spacing: 10px; padding: 24px 0 10px; line-height: 1; }
.ihb-color { color: var(--grn); }
.ihb-dash  { color: var(--txt3); margin: 0 4px; }
.ihb-code  { color: var(--acc); }
.iata-pill { display: inline-block; font-family: var(--fm); font-size: 13px; font-weight: 600; background: rgba(0,212,255,.1); border: 1px solid var(--acc); color: var(--acc); padding: 2px 10px; border-radius: 5px; letter-spacing: 2px; }

/* ── Confidence bars ───────────────────────────────────────────────────── */
.conf-row { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.conf-label { font-size: 12px; min-width: 140px; color: var(--txt2); }
.conf-track { flex: 1; height: 7px; background: rgba(255,255,255,.06); border-radius: 4px; overflow: hidden; }
.conf-fill { height: 100%; border-radius: 4px; transition: width .5s ease; }
.conf-pct { font-family: var(--fm); font-size: 12px; font-weight: 600; min-width: 34px; text-align: right; }

/* ── Gallery ───────────────────────────────────────────────────────────── */
.gallery-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.gallery-count { font-family: var(--fm); font-size: 13px; color: var(--txt2); }
.bag-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.empty-state { text-align: center; padding: 80px 20px; color: var(--txt3); font-size: 15px; }
.hint-state { background: var(--sf); border: 1px solid var(--bd); border-radius: 12px; }

/* ── Bag card ──────────────────────────────────────────────────────────── */
.bag-card { background: var(--sf); border: 1px solid var(--bd); border-radius: 12px; overflow: hidden; cursor: pointer; transition: all .2s; }
.bag-card:hover { border-color: var(--acc); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(0,212,255,.12); }
.bc-img-wrap { position: relative; aspect-ratio: 1; background: var(--bg3); overflow: hidden; }
.bc-img { width: 100%; height: 100%; object-fit: contain; padding: 8px; }
.bc-score { position: absolute; top: 6px; right: 6px; background: rgba(0,0,0,.75); color: var(--grn); font-family: var(--fm); font-size: 11px; padding: 2px 7px; border-radius: 4px; border: 1px solid rgba(0,255,157,.3); }
.bc-info { padding: 10px 12px; }
.bc-brand { font-family: var(--fd); font-size: 15px; font-weight: 700; color: var(--txt); }
.bc-model { font-size: 12px; color: var(--txt2); margin-bottom: 6px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bc-row { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; flex-wrap: wrap; }
.bc-type { font-size: 11px; color: var(--txt2); }
.bc-color-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.bc-color { font-size: 11px; color: var(--txt2); text-transform: capitalize; }
.bc-val { font-size: 11px; color: var(--grn); margin-left: auto; }

/* ── Search box ────────────────────────────────────────────────────────── */
.search-box { display: flex; margin-bottom: 14px; }
.search-input { flex: 1; background: var(--sf); border: 1px solid var(--bd2); color: var(--txt); padding: 13px 16px; border-radius: 9px 0 0 9px; font-size: 14px; outline: none; transition: border-color .2s; }
.search-input:focus { border-color: var(--acc); }
.search-input::placeholder { color: var(--txt3); }
.example-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.chip { background: rgba(0,212,255,.07); border: 1px solid var(--bd2); color: var(--txt2); padding: 5px 12px; border-radius: 20px; font-size: 12px; cursor: pointer; transition: all .2s; }
.chip:hover { background: rgba(0,212,255,.15); color: var(--txt); border-color: var(--acc); }
.search-results { margin-top: 20px; }
.results-count { font-family: var(--fm); font-size: 12px; color: var(--txt2); margin-bottom: 14px; }

/* ── Search params box ─────────────────────────────────────────────────── */
.search-params-box { background: rgba(0,212,255,.04); border: 1px solid var(--bd2); border-radius: 10px; padding: 14px 16px; margin-bottom: 18px; }
.spb-title { font-family: var(--fd); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--acc); margin-bottom: 10px; }
.spb-row { display: flex; justify-content: space-between; font-size: 12px; padding: 3px 0; }
.spb-row span:first-child { color: var(--txt2); }
.spb-summary { font-size: 12px; color: var(--txt2); margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--bd); font-style: italic; }

/* ── Image search layout ───────────────────────────────────────────────── */
.img-search-layout { display: grid; grid-template-columns: 360px 1fr; gap: 28px; }
.img-search-hint { font-size: 13px; color: var(--txt2); margin-bottom: 12px; }

/* ── Modal ─────────────────────────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.75); z-index: 100; display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(4px); }
.modal { background: var(--bg2); border: 1px solid var(--bd2); border-radius: 16px; width: 100%; max-width: 700px; max-height: 90vh; overflow-y: auto; position: relative; animation: modalIn .25s ease; }
@keyframes modalIn { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: scale(1); } }
.modal-close { position: absolute; top: 14px; right: 16px; background: none; border: none; color: var(--txt2); font-size: 18px; cursor: pointer; transition: color .2s; z-index: 10; }
.modal-close:hover { color: var(--txt); }
.modal-hero { display: flex; gap: 20px; padding: 24px; border-bottom: 1px solid var(--bd); background: linear-gradient(135deg, var(--bg3), rgba(0,40,70,.4)); }
.modal-img { width: 120px; height: 120px; object-fit: contain; border-radius: 10px; border: 1px solid var(--bd2); background: rgba(0,0,0,.3); padding: 8px; flex-shrink: 0; }
.modal-brand { font-family: var(--fd); font-size: 26px; font-weight: 700; color: var(--txt); margin-bottom: 2px; }
.modal-model { font-size: 14px; color: var(--txt2); margin-bottom: 10px; }
.modal-sub { font-size: 12px; color: var(--txt2); margin-top: 6px; }
.modal-id { font-family: var(--fm); font-size: 11px; color: var(--txt3); margin-top: 8px; }
.modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--bd); }
.modal-section { background: var(--bg2); padding: 16px 20px; }
.ms-title { font-family: var(--fd); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--txt2); margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--bd); }
.modal-footer { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; border-top: 1px solid var(--bd); background: rgba(0,0,0,.2); }
.modal-date { font-family: var(--fm); font-size: 11px; color: var(--txt3); }
.del-btn { background: rgba(255,77,77,.1); border: 1px solid rgba(255,77,77,.3); color: var(--red); padding: 6px 14px; border-radius: 6px; font-size: 13px; cursor: pointer; transition: all .2s; }
.del-btn:hover { background: rgba(255,77,77,.2); }

/* ── Footer ────────────────────────────────────────────────────────────── */
.footer { position: relative; z-index: 1; text-align: center; padding: 18px; font-size: 11px; color: var(--txt3); letter-spacing: .5px; border-top: 1px solid var(--bd); margin-top: 40px; }

/* ── Auth two-column layout ─────────────────────────────────────────────── */
/* Show left branding panel on screens >= 900px */
@media (min-width: 900px) {
  .auth-left-panel   { display: flex !important; }
  .auth-mobile-logo  { display: none !important; }
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 960px) {
  .analyze-layout, .img-search-layout { grid-template-columns: 1fr; }
  .r-grid2 { grid-template-columns: 1fr; }
  .modal-hero { flex-direction: column; }
  .modal-grid { grid-template-columns: 1fr; }
  .main { padding: 16px; }
  .header { padding: 12px 16px; }
  .logo-name { font-size: 18px; }
  .iata-hero-big { font-size: 36px; }
}
