:root{
  --booking-bg:#eef6fc;
  --booking-paper:#ffffff;
  --booking-ink:#111111;
  --booking-muted:#5f6f80;
  --booking-line:rgba(83,115,148,.18);
  --booking-accent:#cfe7fb;
  --booking-ocean:#1e5b93;
  --booking-shadow:0 20px 48px rgba(32,76,121,.10);
}
*{box-sizing:border-box}
body.booking-body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at top left,rgba(182,221,248,.68),transparent 26%),
    linear-gradient(180deg,#fafdff 0%,var(--booking-bg) 100%);
  color:var(--booking-ink);
  font-family:'DM Sans',sans-serif;
}
.admin-auth-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:32px 16px;
}
.auth-panel{
  width:min(560px,100%);
}
.booking-shell-page{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:42px 0 64px}
.admin-gateway-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.admin-gateway-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-gateway-card{padding:28px}
.booking-hero{
  padding:34px;
  border-radius:32px;
  background:linear-gradient(135deg,#edf7ff,#d9edfd 58%,#c9e5fb);
  color:var(--booking-ink);
  box-shadow:var(--booking-shadow);
}
.booking-hero h1,.booking-hero h2{margin:0;font-family:'Playfair Display',serif;font-size:clamp(34px,5vw,58px);line-height:1}
.booking-hero p{max-width:760px;font-size:15px;line-height:1.8;color:var(--booking-muted)}
.booking-hero-kickers{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.booking-summary{margin-top:14px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--booking-ocean)}
.booking-success-stage{display:grid;place-items:center;min-height:calc(100vh - 260px);padding:42px 0}
.booking-success-card{
  position:relative;
  width:min(540px,100%);
  overflow:hidden;
  padding:40px 28px 34px;
  border:1px solid rgba(30,91,147,.14);
  border-radius:34px;
  background:radial-gradient(circle at 50% -10%,rgba(244,186,24,.24),transparent 34%),linear-gradient(180deg,#ffffff 0%,#fbf7ed 100%);
  box-shadow:0 28px 80px rgba(32,76,121,.16),0 1px 0 rgba(255,255,255,.9) inset;
  text-align:center;
}
.booking-success-card::before{content:'';position:absolute;inset:auto -18% 0;height:92px;background:linear-gradient(90deg,transparent,rgba(30,91,147,.08),transparent);transform:skewY(-5deg);pointer-events:none}
.success-brand{position:relative;z-index:1;display:grid;place-items:center;width:112px;min-height:74px;margin:0 auto 16px;border:1px solid rgba(30,91,147,.14);border-radius:28px;background:linear-gradient(135deg,rgba(244,186,24,.12),rgba(30,91,147,.06));box-shadow:0 14px 34px rgba(30,91,147,.1)}
.success-brand img{display:block;width:76px;height:auto;object-fit:contain}
.success-wave{position:relative;z-index:1;display:grid;place-items:center;width:54px;height:54px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,#ffe38b,#f4ba18);color:#0e3a52;font-size:26px;font-weight:900;box-shadow:0 16px 36px rgba(244,186,24,.34)}
.booking-success-card h1{position:relative;z-index:1;margin:0 0 12px;font-family:'Playfair Display',serif;font-size:clamp(34px,5vw,52px);line-height:.98;color:#0e3a52}
.booking-success-card p{position:relative;z-index:1;margin:0;color:var(--booking-muted);font-size:15px;line-height:1.7}
.success-reference{display:grid;gap:8px;margin-top:18px;color:#0e3a52;font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:800}
.success-reference strong{display:inline-flex;align-items:center;justify-content:center;width:max-content;max-width:100%;margin:0 auto;padding:10px 18px;border-radius:999px;background:#0e3a52;color:#fff;font-size:18px;letter-spacing:.08em;box-shadow:0 14px 34px rgba(14,58,82,.2)}
.success-consultant{margin-top:16px;color:#173f55;font-weight:700}
.booking-receipt-button{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;min-height:48px;margin-top:24px;padding:0 24px;border:none;border-radius:999px;background:linear-gradient(135deg,#ffd447,#f4ba18);color:#0e3a52;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;cursor:pointer;box-shadow:0 18px 44px rgba(244,186,24,.34);transition:transform .25s,box-shadow .25s,opacity .25s}
.booking-receipt-button:hover{transform:translateY(-2px);box-shadow:0 22px 54px rgba(244,186,24,.42)}
.booking-receipt-button:disabled{cursor:not-allowed;opacity:.58;transform:none;box-shadow:none}
.booking-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:28px}
.booking-catalog{display:grid;gap:22px;margin-top:28px}
.booking-catalog .booking-grid{margin-top:0}
.booking-catalog-section{display:grid;gap:18px}
.booking-section-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:end;
  padding:24px 26px;
  border-radius:28px;
  background:rgba(255,255,255,.8);
  border:1px solid rgba(83,115,148,.14);
  box-shadow:0 18px 42px rgba(32,76,121,.08);
}
.booking-section-head h2{
  margin:14px 0 0;
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,4vw,42px);
  line-height:.96;
  color:var(--booking-ink);
}
.booking-section-head p{
  margin:12px 0 0;
  max-width:720px;
  font-size:14px;
  line-height:1.75;
  color:var(--booking-muted);
}
.booking-section-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 16px;
  border-radius:999px;
  background:#eff7fe;
  border:1px solid rgba(94,153,207,.2);
  color:var(--booking-ocean);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
  white-space:nowrap;
}
.booking-section-count.is-combo{
  background:rgba(244,186,24,.14);
  border-color:rgba(244,186,24,.26);
  color:#7e5417;
}
.booking-card,.booking-panel,.result-card,.metric-card,.template-card{
  background:var(--booking-paper);
  border:1px solid var(--booking-line);
  border-radius:28px;
  box-shadow:var(--booking-shadow);
}
.booking-card{position:relative;overflow:hidden}
.booking-card-media{height:210px;background:linear-gradient(145deg,#c7e3f8,#96c6ed,#5e99cf);background-size:cover;background-position:center}
.booking-card-body{padding:22px}
.booking-card-topline{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.booking-chip{display:inline-flex;padding:8px 12px;border-radius:999px;background:#e7f3fd;color:var(--booking-ocean);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border:1px solid rgba(94,153,207,.16)}
.booking-type-pill{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
}
.booking-type-pill.is-standard{
  background:rgba(30,91,147,.1);
  border:1px solid rgba(30,91,147,.18);
  color:var(--booking-ocean);
}
.booking-type-pill.is-combo{
  background:rgba(244,186,24,.16);
  border:1px solid rgba(244,186,24,.28);
  color:#805515;
}
.booking-card.is-combo{
  border-color:rgba(244,186,24,.22);
  box-shadow:0 22px 52px rgba(159,114,34,.12);
}
.booking-card.is-combo .booking-card-body{
  background:
    radial-gradient(circle at top right,rgba(244,186,24,.12),transparent 26%),
    linear-gradient(180deg,rgba(255,253,248,.96),rgba(252,246,236,.98));
}
.booking-card h3,.booking-panel h3{margin:14px 0 8px;font-family:'Playfair Display',serif;font-size:28px}
.booking-card p,.booking-panel p,.muted-copy{font-size:14px;line-height:1.75;color:var(--booking-muted)}
.booking-meta-row,.booking-action-row{display:flex;justify-content:space-between;gap:16px;align-items:center}
.booking-meta-row{margin:14px 0 18px;font-size:13px;color:var(--booking-muted)}
.booking-highlight-list{margin:0 0 22px;padding-left:18px;color:var(--booking-muted);display:grid;gap:8px}
.booking-button{
  display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:999px;border:none;background:var(--booking-ocean);color:#fff;text-decoration:none;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;cursor:pointer;
}
.booking-button.ghost{background:#f5f9fd;color:var(--booking-ocean);border:1px solid var(--booking-line)}
.booking-two-col{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:22px;margin-top:28px}
.booking-panel{padding:26px}
.booking-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.booking-field,.booking-field-full{display:grid;gap:8px}
.booking-field-full{grid-column:1 / -1}
.booking-field label,.booking-field-full label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--booking-ocean)}
.booking-field input,.booking-field select,.booking-field textarea,.booking-field-full input,.booking-field-full select,.booking-field-full textarea{
  width:100%;min-height:50px;padding:14px 16px;border-radius:18px;border:1px solid var(--booking-line);background:#fbfdff;color:var(--booking-ink);font:inherit;
}
.booking-field textarea,.booking-field-full textarea{min-height:120px;resize:vertical}
.booking-inline-note{margin:0;font-size:13px;line-height:1.6;color:var(--booking-muted)}
.booking-service-meta{
  display:grid;
  gap:8px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(30,91,147,.12);
  background:linear-gradient(135deg,rgba(232,244,255,.92),rgba(245,250,255,.98));
  color:var(--booking-ocean);
  font-size:13px;
  line-height:1.7;
}
.booking-service-meta strong{color:var(--booking-ink)}
.booking-service-meta small{font-size:12px;color:var(--booking-muted)}
.check-card,.inline-check{
  display:flex;gap:12px;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:18px;border:1px solid var(--booking-line);background:#f4f8fc;margin-top:10px;
}
.inline-check{align-items:flex-start}
.booking-stat-stack{display:grid;gap:12px}
.booking-stat,.detail-grid div,.metric-card{
  padding:16px;border-radius:18px;background:#f4f8fc;border:1px solid var(--booking-line);
}
.booking-stat span,.detail-grid span,.metric-card span{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--booking-muted)}
.booking-stat strong,.detail-grid strong,.metric-card strong{display:block;margin-top:8px;font-size:20px}
.booking-stat strong{font-family:'Playfair Display',serif;font-size:26px}
.status-banner{
  margin-top:18px;padding:14px 16px;border-radius:18px;border:1px solid rgba(83,115,148,.18);background:#f4f8fc;color:var(--booking-muted);line-height:1.7;
}
.status-banner.is-error{border-color:rgba(173,52,52,.18);background:rgba(173,52,52,.08);color:#8b2e2e}
.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.admin-grid{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}
.admin-sidebar-booking{
  padding:26px 20px;
  background:linear-gradient(180deg,#ffffff 0%,#eef5fb 100%);
  color:var(--booking-ink);
  border-right:1px solid var(--booking-line);
}
.admin-sidebar-booking h1{margin:0;font-family:'Playfair Display',serif;font-size:36px}
.admin-sidebar-booking p{color:var(--booking-muted);line-height:1.7}
.admin-nav-group{display:grid;gap:10px;margin-top:18px}
.admin-nav-group span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--booking-ocean)}
.admin-session{
  margin:18px 0 10px;
  display:grid;
  gap:10px;
}
.admin-tab{
  width:100%;margin-top:10px;min-height:46px;border-radius:16px;border:1px solid var(--booking-line);background:#ffffff;color:var(--booking-ink);font:inherit;text-align:left;padding:0 16px;cursor:pointer;
}
.admin-tab-link{display:flex;align-items:center;text-decoration:none}
.admin-tab.is-active{background:var(--booking-ocean);color:#fff;border-color:var(--booking-ocean)}
.admin-content{padding:24px}
.admin-toolbar{
  display:flex;justify-content:space-between;gap:14px;align-items:center;padding:22px 24px;border-radius:26px;background:var(--booking-paper);border:1px solid var(--booking-line);box-shadow:var(--booking-shadow);
}
.admin-toolbar h2{margin:0;font-family:'Playfair Display',serif;font-size:34px}
.admin-view{display:none;margin-top:18px}
.admin-view.is-active{display:block}
.admin-panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.admin-panel-grid-single{grid-template-columns:repeat(3,minmax(0,1fr))}
.admin-spacer{margin-top:18px}
.panel-header-inline{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.table-wrap{margin-top:16px;overflow:auto;border-radius:24px;background:var(--booking-paper);border:1px solid var(--booking-line);box-shadow:var(--booking-shadow)}
table{width:100%;border-collapse:collapse}
th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--booking-line);font-size:14px}
th{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--booking-muted)}
tr{cursor:pointer}
.detail-actions,.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.detail-actions button,.toolbar-actions button{
  min-height:42px;padding:0 16px;border-radius:999px;border:none;background:var(--booking-ocean);color:#fff;cursor:pointer;font-weight:700;
}
.template-card{padding:20px}
.template-card pre{margin:10px 0 0;white-space:pre-wrap;font-family:'DM Sans',sans-serif;color:var(--booking-muted)}

.auth-panel .auth-card,
.auth-panel .booking-panel,
.admin-toolbar,
.table-wrap,
.booking-card,
.booking-panel,
.result-card,
.metric-card,
.template-card{
  background:var(--booking-paper);
}

.admin-content .booking-chip,
.admin-toolbar .booking-chip{
  background:#e8f4ff;
  color:var(--booking-ocean);
}
@media (max-width:980px){
  .booking-grid,.booking-two-col,.admin-panel-grid,.admin-panel-grid-single,.admin-grid,.detail-grid,.booking-form-grid,.admin-gateway-grid{grid-template-columns:1fr}
  .booking-action-row,.booking-meta-row,.admin-toolbar,.panel-header-inline{flex-direction:column;align-items:flex-start}
  .booking-section-head{grid-template-columns:1fr}
}

/* New True Travel brand assets */
:root{
  --tt-flamingos:url("https://zegfirgyhdjyehvhlrnh.supabase.co/storage/v1/object/public/True%20Travel/BG%20Flamingos.png");
}
body.booking-body{
  background:
    linear-gradient(180deg,rgba(250,253,255,.93) 0%,rgba(238,246,252,.97) 100%),
    radial-gradient(circle at top left,rgba(182,221,248,.68),transparent 26%),
    var(--tt-flamingos) center bottom / cover fixed no-repeat;
}
.booking-site-header{
  width:min(1180px,calc(100% - 32px));
  margin:24px auto 0;
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:10px 14px 10px 20px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(83,115,148,.16);
  box-shadow:0 18px 44px rgba(32,76,121,.1);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
}
.booking-brand-link{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--booking-ink);
  text-decoration:none;
  font-family:'Playfair Display',serif;
  font-size:26px;
  font-weight:700;
  line-height:1;
}
.booking-brand-link img{
  width:78px;
  height:56px;
  object-fit:contain;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
  filter:drop-shadow(0 8px 14px rgba(32,76,121,.14));
}
.booking-site-nav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.booking-site-nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 14px;
  border-radius:999px;
  color:var(--booking-ocean);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  border:1px solid transparent;
  transition:background .25s,border-color .25s,transform .25s;
}
.booking-site-nav a:hover{
  transform:translateY(-1px);
  background:#f1f8fe;
  border-color:var(--booking-line);
}
.booking-hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.booking-hero::before{
  content:'';
  position:absolute;
  right:-60px;
  bottom:-120px;
  width:420px;
  height:260px;
  z-index:-1;
  background:var(--tt-flamingos) center / cover no-repeat;
  opacity:.16;
  border-radius:48%;
  transform:rotate(-4deg);
}
.booking-empty-state{
  grid-column:1 / -1;
  padding:32px;
  border-radius:28px;
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(241,248,254,.92));
  border:1px solid rgba(83,115,148,.16);
  box-shadow:0 22px 48px rgba(32,76,121,.08);
}
.booking-empty-state h3,
.booking-empty-state h4{
  margin:14px 0 10px;
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,4vw,38px);
  color:var(--booking-ink);
}
.booking-empty-state p{
  margin:0;
  max-width:720px;
  font-size:15px;
  line-height:1.8;
  color:var(--booking-muted);
}
.booking-empty-inline{
  padding:22px;
  margin-top:10px;
}
.booking-empty-inline h4{
  font-size:24px;
}
.booking-empty-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}

@media (max-width:760px){
  .booking-site-header{
    border-radius:28px;
    align-items:flex-start;
    flex-direction:column;
    padding:14px;
  }
  .booking-brand-link img{
    width:96px;
    height:48px;
  }
  .booking-site-nav{
    width:100%;
    justify-content:stretch;
  }
  .booking-site-nav a{
    flex:1 1 120px;
  }
  .booking-empty-state{
    padding:22px;
  }
  .booking-empty-actions{
    flex-direction:column;
  }
  .booking-empty-actions .booking-button{
    width:100%;
  }
}

@media (max-width:460px){
  .booking-site-header{
    width:min(1180px,calc(100% - 20px));
    margin-top:12px;
  }
  .booking-brand-link{
    font-size:22px;
  }
  .booking-site-nav a{
    min-height:40px;
    font-size:9px;
    letter-spacing:.12em;
  }
}
