/* Travel module design layer - v4.6.5
   Dedicated travel styles. No forced declarations by design. */
:root{
  --travel-bg:#f3f8ff;
  --travel-surface:#ffffff;
  --travel-surface-2:#f8fbff;
  --travel-border:#dfeaf7;
  --travel-border-2:#cfe0f4;
  --travel-text:#0f172a;
  --travel-muted:#64748b;
  --travel-primary:#2563eb;
  --travel-primary-2:#06b6d4;
  --travel-deep:#0f2744;
  --travel-success:#16a34a;
  --travel-danger:#e11d48;
  --travel-radius-sm:14px;
  --travel-radius-md:20px;
  --travel-radius-lg:28px;
  --travel-shadow:0 14px 38px rgba(15,39,68,.08);
  --travel-shadow-soft:0 8px 22px rgba(15,39,68,.06);
}
.travel-public-body{
  margin:0;
  min-height:100vh;
  overflow-x:hidden;
  background:
    radial-gradient(circle at 85% -10%, rgba(14,165,233,.18), transparent 34%),
    radial-gradient(circle at 8% 12%, rgba(37,99,235,.10), transparent 28%),
    var(--travel-bg);
  color:var(--travel-text);
  -webkit-text-size-adjust:100%;
  touch-action:manipulation;
}
.travel-public-main{
  width:min(100%,1000px);
  margin:0 auto;
  padding:12px 14px 40px;
  overflow-x:hidden;
}
.travel-public-body .top,
.travel-public-body nav:not(.travel-topbar){display:none}
.travel-topbar{
  max-width:960px;
  margin:0 auto 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 2px;
}
.travel-topbar a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:40px;
  padding:0 15px;
  border:1px solid rgba(37,99,235,.14);
  border-radius:999px;
  background:rgba(255,255,255,.84);
  color:#1d4ed8;
  text-decoration:none;
  font-size:13px;
  font-weight:850;
  box-shadow:var(--travel-shadow-soft);
  backdrop-filter:blur(14px);
}
.travel-topbar span{font-size:12px;color:var(--travel-muted);font-weight:750}
.travel-hero,
.travel-hero-pro{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
  padding:24px;
  border-radius:var(--travel-radius-lg);
  color:#fff;
  background:linear-gradient(135deg,#0f2744 0%,#2563eb 58%,#06b6d4 100%);
  box-shadow:0 20px 54px rgba(37,99,235,.22);
  position:relative;
  overflow:hidden;
}
.travel-hero:before,
.travel-hero-pro:after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  left:-70px;
  bottom:-110px;
}
.travel-hero h1,
.travel-hero-pro h1{margin:0 0 6px;font-size:28px;line-height:1.25;color:#fff;position:relative;z-index:1}
.travel-hero p,
.travel-hero-pro p{margin:0;color:#dbeafe;position:relative;z-index:1}
.travel-hero-pro small{display:inline-flex;align-items:center;width:max-content;margin-bottom:10px;padding:6px 11px;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);color:#e0f2fe;font-size:12px;font-weight:850;position:relative;z-index:1}
.travel-hero-icon{font-size:54px;position:relative;z-index:1;filter:drop-shadow(0 8px 16px rgba(15,23,42,.22))}
.travel-search{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:10px;
  margin-bottom:18px;
  padding:12px;
  border:1px solid var(--travel-border);
  border-radius:24px;
  background:rgba(255,255,255,.88);
  box-shadow:var(--travel-shadow-soft);
  backdrop-filter:blur(12px);
}
.travel-search input,
.travel-admin-form textarea,
.contract-admin-form textarea{
  width:100%;
  min-height:48px;
  border:1px solid var(--travel-border);
  border-radius:16px;
  padding:0 14px;
  background:var(--travel-surface-2);
  color:var(--travel-text);
  font-family:inherit;
  font-size:14px;
  outline:none;
  box-sizing:border-box;
}
.travel-search input:focus,
.travel-admin-form textarea:focus,
.contract-admin-form textarea:focus{border-color:#93c5fd;background:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.08)}
.travel-search button,
.reserve-primary{
  min-height:48px;
  border:0;
  border-radius:16px;
  padding:0 22px;
  background:linear-gradient(135deg,#0f2744,#2563eb);
  color:#fff;
  font-family:inherit;
  font-size:14px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(37,99,235,.20);
}
.travel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.travel-card{
  display:block;
  overflow:hidden;
  text-decoration:none;
  color:var(--travel-text);
  background:#fff;
  border:1px solid var(--travel-border);
  border-radius:24px;
  box-shadow:var(--travel-shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease;
}
.travel-card:hover{transform:translateY(-3px);box-shadow:var(--travel-shadow)}
.travel-card-img{height:170px;position:relative;background:#dbeafe;overflow:hidden}
.travel-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.travel-card:hover .travel-card-img img{transform:scale(1.035)}
.travel-card-img span{position:absolute;right:10px;top:10px;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.94);border:1px solid rgba(37,99,235,.12);color:#1d4ed8;font-size:11px;font-weight:900}
.travel-fallback{height:100%;display:grid;place-items:center;font-size:46px;background:linear-gradient(135deg,#dbeafe,#e0f2fe)}
.travel-card-body{padding:14px}
.travel-card-body h3{margin:0 0 6px;font-size:16px;font-weight:950;color:var(--travel-text)}
.travel-card-body p{margin:0 0 10px;color:var(--travel-muted);font-size:12px;font-weight:650}
.travel-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.travel-meta b{color:#0284c7;font-size:15px;font-weight:950}
.travel-meta small{color:var(--travel-muted);font-size:11px;font-weight:700}
.travel-detail,
.travel-detail-pro,
.booking-panel,
.shantia-calendar,
.digital-contract-box,
.booking-contract-view,
.travel-ticket,
.booking-detail-card,
.admin-collapse,
.travel-admin-item,
.booking-row{
  background:#fff;
  border:1px solid var(--travel-border);
  border-radius:var(--travel-radius-lg);
  box-shadow:var(--travel-shadow-soft);
}
.travel-detail,
.travel-detail-pro{max-width:960px;margin:0 auto;padding:20px;overflow:hidden}
.property-head{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;margin-bottom:12px}
.property-head h1{margin:0 0 7px;font-size:28px;line-height:1.25;color:var(--travel-text)}
.property-location{margin:0;color:var(--travel-muted);font-size:13px;font-weight:800}
.property-price{min-width:170px;padding:15px;border:1px solid var(--travel-border-2);border-radius:22px;background:linear-gradient(135deg,#f8fbff,#e0f2fe);text-align:center}
.property-price small,.property-price span{display:block;color:var(--travel-muted);font-size:11px;font-weight:800}
.property-price b{display:block;margin:5px 0;color:#0284c7;font-size:18px;font-weight:950}
.travel-tags{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}
.travel-tags span{padding:7px 12px;border-radius:999px;background:#eff6ff;border:1px solid rgba(37,99,235,.14);color:#1d4ed8;font-size:12px;font-weight:800}
.property-desc{margin:12px 0 16px;padding:14px;border:1px solid var(--travel-border);border-radius:20px;background:var(--travel-surface-2);color:#334155;line-height:1.95;font-size:13px}
.shantia-gallery-pro{max-width:960px;margin:0 auto 16px;overflow:hidden;background:#0f2744;border:1px solid rgba(37,99,235,.16);border-radius:28px;box-shadow:0 16px 45px rgba(15,39,68,.16)}
.shantia-gallery-pro .gal-stage{position:relative;width:100%;height:410px;background:#0f2744;display:flex;align-items:center;justify-content:center;overflow:hidden}
.shantia-gallery-pro .gal-stage img{width:100%;height:100%;object-fit:cover;display:block}
.shantia-gallery-pro .gal-prev,.shantia-gallery-pro .gal-next{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border:0;border-radius:50%;background:rgba(255,255,255,.92);color:#0f2744;font-size:26px;font-weight:900;box-shadow:0 8px 24px rgba(0,0,0,.18);cursor:pointer}
.shantia-gallery-pro .gal-prev{right:12px}.shantia-gallery-pro .gal-next{left:12px}
.shantia-gallery-pro .gal-count{position:absolute;left:12px;bottom:12px;padding:6px 12px;border-radius:999px;background:rgba(15,39,68,.74);color:#dbeafe;font-size:12px;font-weight:900;backdrop-filter:blur(8px)}
.shantia-gallery-pro .gal-thumbs{display:flex;gap:8px;overflow-x:auto;padding:10px;background:#071a36;scrollbar-width:none}
.shantia-gallery-pro .gal-thumbs::-webkit-scrollbar{display:none}
.shantia-gallery-pro .gal-thumb{flex:0 0 80px;width:80px;height:62px;border:2px solid transparent;border-radius:14px;background:#112347;padding:0;overflow:hidden;opacity:.66;cursor:pointer}
.shantia-gallery-pro .gal-thumb.active{border-color:#38bdf8;opacity:1}
.shantia-gallery-pro .gal-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.shantia-calendar{max-width:580px;margin:14px auto 18px;padding:14px;overflow:hidden}
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 12px;direction:ltr}
.cal-head h3{direction:rtl;margin:0;color:var(--travel-text);font-size:17px;font-weight:950}
.cal-nav{width:38px;height:38px;border:1px solid rgba(37,99,235,.14);border-radius:12px;background:#eff6ff;color:#1d4ed8;font-size:20px;font-weight:900;cursor:pointer}
.cal-week,.cal-month.active{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:5px}
.cal-week{padding:8px 0 4px;color:var(--travel-muted);text-align:center;font-weight:900}
.cal-week span{font-size:11px}.cal-months{overflow:hidden}.cal-month{display:none;width:100%;box-sizing:border-box}.cal-month.active{display:grid}
.cal-day,.cal-blank{min-height:64px}
.cal-day{border:0;border-radius:16px;background:#fff;color:var(--travel-text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-family:inherit;cursor:pointer;position:relative;padding:0;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}
.cal-day b{font-size:16px;font-weight:950}.cal-day small{font-size:9.5px;color:var(--travel-muted)}
.cal-day.available{box-shadow:inset 0 0 0 1px rgba(37,99,235,.16);background:#f8fbff}.cal-day.available:hover{transform:scale(1.04);background:#eff6ff}
.cal-day.disabled{color:#94a3b8;background:#f8fafc;text-decoration:line-through;cursor:default;opacity:.75}
.cal-day.selected{background:linear-gradient(135deg,#0f2744,#2563eb);color:#fff;box-shadow:0 8px 20px rgba(37,99,235,.25)}
.cal-day.selected small{color:#dbeafe}.cal-day.in-range{background:#eff6ff;box-shadow:inset 0 0 0 1px rgba(37,99,235,.20)}
.cal-guide{display:flex;gap:14px;flex-wrap:wrap;padding-top:12px;color:var(--travel-muted);font-size:11px;font-weight:800}.cal-guide span{display:flex;align-items:center;gap:6px}.cal-guide i{width:10px;height:10px;border-radius:50%;background:#f8fbff;border:1px solid rgba(37,99,235,.22)}
.booking-panel{padding:18px;margin:18px 0;background:linear-gradient(180deg,#fff,#f8fbff)}
.booking-panel h2{margin:0 0 6px;font-size:21px;color:var(--travel-text)}.booking-panel .muted{margin:0 0 12px;color:var(--travel-muted);font-size:13px}
.shantia-book-pro{display:grid;grid-template-columns:1fr;gap:14px}.date-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px}.date-summary div,.booking-live-summary div{padding:12px;border:1px solid var(--travel-border);border-radius:18px;background:#fff;text-align:center}.date-summary small,.booking-live-summary small{display:block;margin-bottom:5px;color:var(--travel-muted);font-size:11px;font-weight:800}.date-summary b,.booking-live-summary b{display:block;color:var(--travel-text);font-size:16px;font-weight:950}
.booking-live-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:center;padding:14px;border:1px solid var(--travel-border);border-radius:22px;background:linear-gradient(135deg,#f8fbff,#eff6ff)}.booking-live-summary>span{grid-column:1/-1;text-align:center;color:var(--travel-muted);font-weight:800}.booking-live-summary em{grid-column:1/-1;padding:9px;border:1px solid rgba(225,29,72,.12);border-radius:14px;background:#fff1f2;color:#9f1239;font-style:normal;text-align:center;font-size:12px;font-weight:850}
.digital-contract-box{padding:16px}.dcb-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.dcb-head>span{width:40px;height:40px;display:grid;place-items:center;border-radius:14px;background:#eff6ff}.dcb-head b{display:block;color:var(--travel-text);font-size:15px}.dcb-head small{display:block;color:var(--travel-muted);font-size:11px;margin-top:2px}.dcb-text{max-height:170px;overflow:auto;padding:14px;border:1px dashed var(--travel-border-2);border-radius:18px;background:var(--travel-surface-2);color:#334155;line-height:1.9;font-size:13px}.dcb-check{display:flex;gap:8px;align-items:flex-start;margin:12px 0;color:#334155;font-size:13px;font-weight:800}.signature-pad-wrap{padding:12px;border:1px solid var(--travel-border);border-radius:20px;background:#fff}.sig-title{margin-bottom:8px;color:var(--travel-muted);font-size:12px;font-weight:900}.signature-pad-wrap canvas{width:100%;height:170px;border:1px dashed var(--travel-border-2);border-radius:16px;background:#fff;display:block;touch-action:none}.sig-clear{margin-top:8px;border:0;border-radius:12px;background:#f1f5f9;color:#475569;padding:9px 12px;font-family:inherit;font-weight:850;cursor:pointer}
.property-info-box{display:grid;gap:12px;margin-top:16px}.property-info-box h2{display:none}.amenities-block,.rules-block{padding:16px;border:1px solid var(--travel-border);border-radius:22px;background:#fff;box-shadow:var(--travel-shadow-soft)}.amenities-block-head,.rules-block-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.blk-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:#eff6ff}.amenities-tags{display:flex;flex-wrap:wrap;gap:8px}.amenities-tags span,.rules-list li{border:1px solid var(--travel-border);border-radius:999px;background:var(--travel-surface-2);padding:7px 12px;font-size:12px;color:#334155;font-weight:750}.rules-list{display:grid;gap:8px;margin:0;padding:0}.rules-list li{list-style:none;border-radius:14px;line-height:1.8}
.travel-admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0 18px}.travel-admin-stats.pro{grid-template-columns:repeat(6,1fr)}.travel-admin-stats>div{padding:16px;border:1px solid var(--travel-border);border-radius:20px;background:#fff;box-shadow:var(--travel-shadow-soft);text-align:center}.travel-admin-stats b{display:block;color:var(--travel-text);font-size:20px;font-weight:950}.travel-admin-stats span{display:block;margin-top:4px;color:var(--travel-muted);font-size:11px;font-weight:800}.shantia-quick{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.shantia-quick a{padding:13px;border:1px solid var(--travel-border);border-radius:18px;background:#fff;color:var(--travel-text);text-decoration:none;text-align:center;font-size:13px;font-weight:900;box-shadow:var(--travel-shadow-soft)}
.travel-admin-list,.travel-admin-bookings{display:grid;gap:12px}.travel-admin-item,.booking-row.pro{display:grid;grid-template-columns:88px 1fr auto;gap:12px;align-items:center;padding:13px}.tai-img,.booking-thumb{width:84px;height:84px;border-radius:20px;background:#dbeafe;overflow:hidden;display:grid;place-items:center;font-size:28px}.tai-img img,.booking-thumb img{width:100%;height:100%;object-fit:cover}.tai-main h3{margin:0 0 5px;font-size:17px}.tai-main p,.tai-main small,.booking-row span,.booking-row small{color:var(--travel-muted);font-size:12px}.tai-mini{display:flex;gap:7px;flex-wrap:wrap}.tai-mini span{padding:5px 9px;border:1px solid var(--travel-border);border-radius:999px;background:var(--travel-surface-2);color:#1d4ed8;font-size:11px;font-weight:750}.tai-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.travel-ticket{max-width:540px;margin:auto;padding:24px;text-align:center}.ticket-code,.pro-code{font-size:25px;font-weight:950;letter-spacing:2px;background:#eff6ff;border:1px dashed rgba(37,99,235,.28);border-radius:18px;padding:14px;margin:14px 0;color:#0f2744}.booking-detail-card{max-width:780px;margin:0 auto;overflow:hidden}.booking-detail-body{padding:20px}.booking-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:14px 0}.booking-detail-grid div{background:var(--travel-surface-2);border:1px solid var(--travel-border);border-radius:18px;padding:12px}.booking-total-box{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#0f2744,#2563eb);color:#fff;border-radius:22px;padding:16px;margin:14px 0}.booking-actions{display:flex;gap:10px;margin-top:16px}.booking-actions .btn{flex:1;text-align:center}
@media(max-width:760px){
  .travel-public-main{width:100%;max-width:100%;padding:10px 12px 28px;box-sizing:border-box}
  .travel-topbar{padding:8px 2px;margin-bottom:10px}.travel-topbar a{min-height:36px;padding:0 12px;font-size:12px}.travel-topbar span{display:none}
  .travel-hero,.travel-hero-pro{margin:0 0 12px;padding:20px;border-radius:24px}.travel-hero h1,.travel-hero-pro h1{font-size:23px}.travel-hero p,.travel-hero-pro p{font-size:13px}.travel-hero-icon{font-size:42px}
  .travel-search{grid-template-columns:1fr;gap:8px;padding:10px;border-radius:20px}.travel-search input,.travel-search button{min-height:46px}
  .travel-grid{grid-template-columns:1fr;gap:12px}.travel-card{border-radius:22px}.travel-card-img{height:150px}.travel-card-body{padding:13px}
  .shantia-gallery-pro{margin:0 0 12px;border-radius:0 0 24px 24px}.shantia-gallery-pro .gal-stage{height:255px}.shantia-gallery-pro .gal-stage img{object-fit:cover}.shantia-gallery-pro .gal-prev,.shantia-gallery-pro .gal-next{width:38px;height:38px;font-size:22px}.shantia-gallery-pro .gal-thumb{flex-basis:70px;width:70px;height:54px}
  .travel-detail,.travel-detail-pro{padding:14px;border-radius:24px}.property-head{grid-template-columns:1fr;gap:10px}.property-head h1{font-size:22px}.property-price{min-width:0}.travel-tags span{font-size:11px;padding:6px 10px}
  .booking-panel,.shantia-calendar,.digital-contract-box{border-radius:22px;padding:12px}.cal-day,.cal-blank{min-height:51px}.cal-day b{font-size:14px}.cal-day small{font-size:8.5px}.cal-week{gap:3px}.cal-month.active{gap:3px}.date-summary,.booking-live-summary{grid-template-columns:1fr}.signature-pad-wrap canvas{height:150px}.reserve-primary{width:100%;position:sticky;bottom:10px;z-index:50;box-shadow:0 12px 28px rgba(15,39,68,.20)}
  .travel-admin-stats,.travel-admin-stats.pro,.shantia-quick{grid-template-columns:repeat(2,minmax(0,1fr))}.travel-admin-item,.travel-admin-item.pro,.booking-row.pro{grid-template-columns:64px 1fr}.tai-img,.booking-thumb{width:64px;height:64px;border-radius:16px}.tai-actions,.booking-row.pro form{grid-column:1/-1;justify-content:stretch}.tai-actions .btn,.booking-row.pro form button,.booking-row.pro form select{flex:1}
  .booking-detail-grid{grid-template-columns:1fr}.booking-actions{flex-direction:column}
}


/* Stage 2: public travel list aligned with customer app */
.travel-app-head{
  max-width:960px;
  margin:0 auto 12px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
  padding:8px 2px;
}
.travel-brand-mini{
  justify-self:center;
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--travel-text);
}
.travel-brand-mini>span{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:linear-gradient(135deg,#e0f2fe,#f8fbff);
  border:1px solid rgba(37,99,235,.12);
  box-shadow:var(--travel-shadow-soft);
}
.travel-brand-mini b{display:block;font-size:15px;font-weight:950;line-height:1.3}
.travel-brand-mini small{display:block;color:var(--travel-muted);font-size:10.5px;font-weight:800}
.travel-back,
.travel-account{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 13px;
  border-radius:999px;
  background:rgba(255,255,255,.84);
  border:1px solid rgba(37,99,235,.13);
  color:#1d4ed8;
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  box-shadow:var(--travel-shadow-soft);
  backdrop-filter:blur(14px);
}
.travel-account{color:#475569;background:rgba(255,255,255,.72)}
.travel-hero-app{
  padding:22px;
  margin-bottom:12px;
  border-radius:30px;
  background:
    radial-gradient(circle at 16% 0,rgba(255,255,255,.22),transparent 34%),
    linear-gradient(135deg,#0f2744 0%,#2563eb 55%,#06b6d4 100%);
}
.travel-hero-app h1{font-size:26px;margin-bottom:8px}
.travel-hero-app p{max-width:560px;line-height:1.8;font-size:13px}
.travel-hero-pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
  position:relative;
  z-index:1;
}
.travel-hero-pills span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.18);
  color:#e0f2fe;
  font-size:11px;
  font-weight:850;
}
.travel-hero-card{
  min-width:150px;
  padding:16px;
  border-radius:24px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16);
  text-align:center;
  backdrop-filter:blur(12px);
  position:relative;
  z-index:1;
}
.travel-hero-card b{display:block;color:#fff;font-size:32px;font-weight:950;line-height:1}
.travel-hero-card span{display:block;margin-top:7px;color:#e0f2fe;font-size:12px;font-weight:900}
.travel-hero-card small{display:block;margin-top:5px;color:#bfdbfe;font-size:10.5px;font-weight:750}
.travel-search-app{
  grid-template-columns:1fr 1fr auto;
  align-items:end;
  margin-bottom:10px;
}
.travel-search-app label{display:grid;gap:6px;margin:0}
.travel-search-app label span{padding-inline:4px;color:var(--travel-muted);font-size:11px;font-weight:850}
.travel-filter-row{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:2px 1px 12px;
  scrollbar-width:none;
}
.travel-filter-row::-webkit-scrollbar{display:none}
.travel-filter-pill{
  flex:0 0 auto;
  min-height:38px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--travel-border);
  color:#475569;
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  box-shadow:var(--travel-shadow-soft);
}
.travel-filter-pill.active{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#1d4ed8;
}
.travel-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin:4px 0 12px;
  padding:0 2px;
}
.travel-section-head h2{margin:0;color:var(--travel-text);font-size:18px;font-weight:950}
.travel-section-head p{margin:4px 0 0;color:var(--travel-muted);font-size:11.5px;font-weight:750}
.travel-section-head>span{
  flex:0 0 auto;
  min-height:30px;
  display:inline-flex;
  align-items:center;
  padding:0 10px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--travel-border);
  color:#1d4ed8;
  font-size:11px;
  font-weight:900;
}
.travel-grid-premium{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.travel-card-premium{
  border-radius:26px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
}
.travel-card-premium .travel-card-img{height:172px;background:#e0f2fe}
.travel-card-badges{
  position:absolute;
  inset:10px 10px auto 10px;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.travel-card-badges span{
  position:static;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.56);
  color:#0f2744;
  font-size:10px;
  font-weight:950;
  box-shadow:0 6px 16px rgba(15,39,68,.10);
}
.travel-card-title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
}
.travel-card-title-row h3{margin-bottom:4px}
.travel-card-title-row em{
  flex:0 0 auto;
  font-style:normal;
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:#eff6ff;
  color:#1d4ed8;
  font-size:10.5px;
  font-weight:950;
}
.travel-card-location{line-height:1.7}
.travel-card-facts{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin:10px 0;
}
.travel-card-facts span{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:6px 8px;
  border-radius:999px;
  background:var(--travel-surface-2);
  border:1px solid var(--travel-border);
  color:#334155;
  font-size:10.5px;
  font-weight:850;
}
.travel-card-address{
  margin:8px 0 10px;
  padding:9px 10px;
  border-radius:16px;
  background:#f8fafc;
  color:#64748b;
  font-size:11px;
  font-weight:750;
  line-height:1.8;
}
.travel-card-seller{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:6px;
  align-items:center;
  margin:8px 0 10px;
  padding:8px 10px;
  border:1px dashed #cfe0f4;
  border-radius:16px;
  background:#fff;
}
.travel-card-seller span{color:#94a3b8;font-size:10px;font-weight:900}
.travel-card-seller b{color:#334155;font-size:11.5px;font-weight:950;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.travel-card-seller small{direction:ltr;color:#64748b;font-size:10.5px;font-weight:850}
.travel-card-premium .travel-meta{
  justify-content:space-between;
  padding-top:10px;
  border-top:1px solid #eef2f7;
}
.travel-card-premium .travel-meta div{display:grid;gap:3px}
.travel-card-premium .travel-meta strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:linear-gradient(135deg,#0f2744,#2563eb);
  color:#fff;
  font-size:12px;
  font-weight:950;
  box-shadow:0 9px 18px rgba(37,99,235,.18);
}
.travel-empty-state{
  margin:12px 0;
  padding:28px 18px;
  border:1px solid var(--travel-border);
  border-radius:28px;
  background:rgba(255,255,255,.9);
  box-shadow:var(--travel-shadow-soft);
  text-align:center;
}
.travel-empty-state div{font-size:34px;margin-bottom:8px}
.travel-empty-state b{display:block;color:var(--travel-text);font-size:17px;font-weight:950}
.travel-empty-state p{max-width:420px;margin:8px auto 14px;color:var(--travel-muted);font-size:12px;line-height:1.9}
.travel-empty-state a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1d4ed8;
  text-decoration:none;
  font-size:12px;
  font-weight:900;
}
@media(max-width:760px){
  .travel-app-head{grid-template-columns:auto 1fr auto;margin-bottom:8px;padding:7px 0}.travel-back,.travel-account{min-height:36px;padding:0 11px;font-size:11px}.travel-brand-mini{gap:8px}.travel-brand-mini>span{width:38px;height:38px;border-radius:14px}.travel-brand-mini small{display:none}
  .travel-hero-app{display:grid;grid-template-columns:1fr;gap:14px;padding:18px;border-radius:26px}.travel-hero-app h1{font-size:22px}.travel-hero-app p{font-size:12.5px}.travel-hero-pills{gap:6px}.travel-hero-pills span{min-height:28px;font-size:10.5px}.travel-hero-card{display:flex;align-items:center;justify-content:space-between;text-align:right;min-width:0;padding:12px 14px}.travel-hero-card b{font-size:24px}.travel-hero-card span,.travel-hero-card small{margin:0}
  .travel-search-app{grid-template-columns:1fr;padding:11px}.travel-filter-row{margin-inline:-2px}.travel-section-head h2{font-size:16px}.travel-section-head p{font-size:10.5px}
  .travel-grid-premium{grid-template-columns:1fr;gap:12px}.travel-card-premium{border-radius:24px}.travel-card-premium .travel-card-img{height:158px}.travel-card-body{padding:12px}.travel-card-title-row h3{font-size:15px}.travel-card-facts{gap:5px}.travel-card-facts span{font-size:10px;padding:5px 7px}.travel-card-seller{grid-template-columns:auto 1fr}.travel-card-seller small{grid-column:2/3}.travel-card-premium .travel-meta strong{min-height:32px;padding:0 12px}
  .travel-detail-head{position:sticky;top:0;z-index:60;background:linear-gradient(180deg,rgba(243,248,255,.96),rgba(243,248,255,.78));backdrop-filter:blur(14px);border-radius:0 0 18px 18px}
}

/* Travel stage 3: premium detail and booking flow */
.travel-detail-shell{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr);
  gap:16px;
  align-items:start;
}
.travel-detail-main{display:grid;gap:14px;min-width:0}
.travel-booking-column{min-width:0}
.travel-booking-sticky{position:sticky;top:14px}
.travel-detail-gallery,
.travel-property-card,
.travel-info-card,
.travel-book-modern .travel-step{
  background:rgba(255,255,255,.92);
  border:1px solid var(--travel-border);
  border-radius:28px;
  box-shadow:var(--travel-shadow-soft);
  overflow:hidden;
}
.tdg-stage{
  position:relative;
  height:350px;
  background:linear-gradient(135deg,#e0f2fe,#f8fafc);
  overflow:hidden;
}
.tdg-stage img{width:100%;height:100%;object-fit:cover;display:block}
.tdg-stage::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:38%;
  background:linear-gradient(180deg,transparent,rgba(15,39,68,.26));
  pointer-events:none;
}
.tdg-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  color:#0f2744;
  font-size:25px;
  font-weight:900;
  box-shadow:0 10px 24px rgba(15,39,68,.16);
  cursor:pointer;
}
.tdg-prev{right:12px}.tdg-next{left:12px}
.tdg-count{
  position:absolute;
  left:12px;
  bottom:12px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  background:rgba(15,39,68,.64);
  backdrop-filter:blur(12px);
  color:#fff;
  font-size:11px;
  font-weight:900;
}
.tdg-thumbs{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:10px;
  background:#fff;
  scrollbar-width:none;
}
.tdg-thumbs::-webkit-scrollbar{display:none}
.tdg-thumb{
  flex:0 0 68px;
  width:68px;
  height:54px;
  border:2px solid transparent;
  border-radius:16px;
  overflow:hidden;
  padding:0;
  background:#f1f5f9;
  opacity:.74;
  cursor:pointer;
}
.tdg-thumb.active{border-color:#2563eb;opacity:1}
.tdg-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.travel-property-card{padding:18px}
.property-head-modern{align-items:flex-start;margin-bottom:10px}
.property-eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 10px;
  margin-bottom:8px;
  border-radius:999px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1d4ed8;
  font-size:11px;
  font-weight:950;
}
.property-head-modern h1{font-size:25px;line-height:1.45;margin:0;color:var(--travel-text);font-weight:950;letter-spacing:-.03em}
.property-price-modern{
  min-width:150px;
  padding:12px;
  border-radius:22px;
  background:#f8fafc;
  border:1px solid #eef2f7;
  text-align:left;
}
.property-price-modern small{display:block;color:#64748b;font-size:10.5px;font-weight:850;margin-bottom:4px}
.property-price-modern b{font-size:17px;color:#0f2744;font-weight:950}
.travel-detail-facts{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:14px 0 0;
}
.travel-detail-facts span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 11px;
  border-radius:999px;
  background:var(--travel-surface-2);
  border:1px solid var(--travel-border);
  color:#334155;
  font-size:11px;
  font-weight:900;
}
.property-desc-modern{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid #eef2f7;
  color:#475569;
  font-size:13px;
  line-height:2.05;
}
.travel-info-card{padding:15px 16px}
.tic-head{display:flex;align-items:center;gap:9px;margin-bottom:12px;color:var(--travel-text)}
.tic-head span{
  width:34px;height:34px;border-radius:14px;
  display:grid;place-items:center;
  background:#eff6ff;border:1px solid #dbeafe;
}
.tic-head b{font-size:14px;font-weight:950}
.host-line{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}
.host-line strong{color:#0f2744;font-size:13px;font-weight:950}
.host-line small{direction:ltr;color:#64748b;font-size:11px;font-weight:850}
.travel-host-card p{margin:0;color:#64748b;font-size:12px;line-height:1.9}
.travel-chip-list{display:flex;flex-wrap:wrap;gap:7px}
.travel-chip-list span{
  display:inline-flex;
  min-height:30px;
  align-items:center;
  padding:0 10px;
  border-radius:999px;
  background:#f8fafc;
  border:1px solid #eef2f7;
  color:#475569;
  font-size:11px;
  font-weight:850;
}
.travel-rules-list{margin:0;padding:0 18px 0 0;color:#475569;font-size:12px;line-height:2}
.travel-book-modern{display:grid;gap:12px;margin:0}
.travel-book-modern .travel-step{padding:14px}
.travel-step-head,
.travel-contract-step summary{
  display:flex;
  align-items:center;
  gap:10px;
  list-style:none;
  cursor:default;
}
.travel-contract-step summary{cursor:pointer}
.travel-contract-step summary::-webkit-details-marker{display:none}
.travel-step-head>span,
.travel-contract-step summary>span{
  flex:0 0 34px;
  width:34px;
  height:34px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1d4ed8;
  font-size:12px;
  font-weight:950;
}
.travel-step-head b,
.travel-contract-step summary b{display:block;color:var(--travel-text);font-size:14px;font-weight:950}
.travel-step-head small,
.travel-contract-step summary small{display:block;color:var(--travel-muted);font-size:10.5px;font-weight:800;margin-top:1px}
.travel-book-modern .shantia-calendar{
  margin-top:12px;
  border:0;
  box-shadow:none;
  background:#f8fafc;
  border-radius:22px;
  padding:10px;
}
.travel-book-modern .cal-head{margin-bottom:8px}
.travel-book-modern .cal-head h3{font-size:13px}
.travel-book-modern .cal-week span{font-size:10px}
.travel-book-modern .cal-month{gap:5px}
.travel-book-modern .cal-day{
  min-height:48px;
  border-radius:14px;
  box-shadow:none;
}
.travel-book-modern .cal-day b{font-size:12px}
.travel-book-modern .cal-day small{font-size:8.5px}
.travel-book-modern .cal-guide{margin-top:8px}
.date-summary-modern{grid-template-columns:1fr 1fr;margin-top:12px;gap:8px}
.date-summary-modern div{
  padding:11px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #eef2f7;
}
.date-summary-modern small{font-size:10px;color:#64748b;font-weight:850}
.date-summary-modern b{font-size:12px;color:#0f2744;font-weight:950}
.booking-live-modern{
  margin-top:9px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #eef2f7;
  color:#475569;
}
.booking-live-modern div{min-width:0}
.booking-live-modern small{color:#64748b;font-weight:850}
.booking-live-modern b{color:#0f2744;font-weight:950}
.booking-live-modern em{display:block;grid-column:1/-1;color:#e11d48;font-style:normal;font-size:10.5px;font-weight:900}
.travel-contract-step[open]{padding-bottom:14px}
.travel-contract-step summary{padding:14px}
.digital-contract-modern{margin:12px 14px 0;padding:0;border:0;background:transparent;box-shadow:none}
.digital-contract-modern .dcb-text{
  max-height:160px;
  overflow:auto;
  padding:12px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #eef2f7;
  color:#475569;
  font-size:11.5px;
  line-height:2;
}
.digital-contract-modern .dcb-check{
  margin:10px 0;
  padding:10px 12px;
  border-radius:16px;
  background:#fff;
  border:1px solid #eef2f7;
  color:#334155;
  font-size:11px;
  font-weight:850;
}
.signature-pad-modern{margin-top:10px;padding:10px;border-radius:18px;background:#fff;border:1px solid #eef2f7}
.signature-pad-modern canvas{width:100%;height:118px;border-radius:14px;background:#f8fafc;border:1px dashed #cbd5e1}
.signature-pad-modern .sig-title{font-size:11px;color:#334155;font-weight:950;margin-bottom:8px}
.signature-pad-modern .sig-clear{min-height:30px;padding:0 10px;border-radius:999px;font-size:10.5px}
.reserve-primary-modern{
  width:100%;
  min-height:48px;
  border:0;
  border-radius:18px;
  background:linear-gradient(135deg,#0f2744,#2563eb);
  color:#fff;
  font-size:13px;
  font-weight:950;
  box-shadow:0 12px 24px rgba(37,99,235,.22);
  cursor:pointer;
}
.reserve-primary-modern:disabled{
  background:#e2e8f0;
  color:#94a3b8;
  box-shadow:none;
  cursor:not-allowed;
}
.travel-book-modern.booking-ready .travel-summary-step{border-color:#bfdbfe;box-shadow:0 14px 34px rgba(37,99,235,.10)}
@media(max-width:900px){
  .travel-detail-shell{grid-template-columns:1fr;gap:12px}
  .travel-booking-sticky{position:static}
  .tdg-stage{height:260px}
  .travel-property-card,.travel-info-card,.travel-book-modern .travel-step{border-radius:24px}
}
@media(max-width:600px){
  .travel-detail-shell{margin-inline:-2px}
  .tdg-stage{height:220px}
  .tdg-nav{width:34px;height:34px;font-size:22px}.tdg-thumb{flex-basis:58px;width:58px;height:46px;border-radius:13px}
  .travel-property-card{padding:14px}.property-head-modern{display:grid;gap:10px}.property-head-modern h1{font-size:20px}.property-price-modern{min-width:0;text-align:right}.travel-detail-facts{gap:6px}.travel-detail-facts span{font-size:10px;min-height:29px;padding:0 9px}
  .property-desc-modern{font-size:12px;line-height:1.95}.travel-info-card{padding:13px}.host-line{display:grid;justify-content:stretch}.host-line small{text-align:right}
  .travel-book-modern .travel-step{padding:11px}.travel-step-head>span,.travel-contract-step summary>span{width:30px;height:30px;flex-basis:30px;border-radius:12px}.travel-book-modern .shantia-calendar{padding:8px;border-radius:18px}.travel-book-modern .cal-day{min-height:43px;border-radius:12px}.travel-book-modern .cal-day small{display:none}.date-summary-modern div{padding:9px}.booking-live-modern{display:grid;gap:8px}.digital-contract-modern{margin-inline:11px}.signature-pad-modern canvas{height:100px}.reserve-primary-modern{position:sticky;bottom:10px;z-index:20}
}

/* Stage 4: travel admin, owner panel and mobile polish */
.admin-main .travel-admin-shell{
  width:min(100%,1120px);
  margin:0 auto;
  padding-bottom:28px;
}
.shantia-admin-hero,
.owner-hero-modern{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:22px;
  margin:0 0 14px;
  border-radius:28px;
  background:
    radial-gradient(circle at 0 100%,rgba(6,182,212,.20),transparent 32%),
    linear-gradient(135deg,#0f2744,#2563eb 72%,#06b6d4);
  color:#fff;
  box-shadow:0 18px 45px rgba(37,99,235,.20);
  overflow:hidden;
  position:relative;
}
.shantia-admin-hero:after,
.owner-hero-modern:after{
  content:"";
  position:absolute;
  left:-70px;
  bottom:-90px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:rgba(255,255,255,.13);
}
.shantia-admin-hero h1,
.owner-hero-modern h1{margin:4px 0 5px;color:#fff;font-size:25px;line-height:1.3;font-weight:950}
.shantia-admin-hero p,
.owner-hero-modern p{margin:0;color:#dbeafe;font-size:13px;font-weight:750;line-height:1.9}
.shantia-admin-hero small,
.owner-hero-modern small{display:inline-flex;width:max-content;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);color:#e0f2fe;font-size:11px;font-weight:900}
.shantia-admin-logo{width:58px;height:58px;border-radius:22px;display:grid;place-items:center;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);font-size:29px;position:relative;z-index:1}
.owner-hero-badge{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:12px;font-weight:900;position:relative;z-index:1;white-space:nowrap}
.travel-admin-shell>.card,
.travel-public-main>.card{
  border:1px solid var(--travel-border);
  border-radius:26px;
  box-shadow:var(--travel-shadow-soft);
  background:rgba(255,255,255,.92);
  overflow:hidden;
}
.travel-admin-shell>.card h2,
.travel-public-main>.card h2{
  margin:0 0 12px;
  color:#0f2744;
  font-size:16px;
  font-weight:950;
}
.travel-admin-stats.pro,
.owner-stat-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin:12px 0 16px;
}
.travel-admin-stats.pro{grid-template-columns:repeat(6,minmax(0,1fr))}
.travel-admin-stats.pro>div,
.owner-stat-grid>div{
  min-height:82px;
  padding:14px 10px;
  border-radius:22px;
  border:1px solid var(--travel-border);
  background:linear-gradient(180deg,#fff,#f8fbff);
  box-shadow:var(--travel-shadow-soft);
  text-align:center;
}
.travel-admin-stats.pro b,
.owner-stat-grid b{display:block;color:#0f2744;font-size:17px;font-weight:950;line-height:1.35}
.travel-admin-stats.pro span,
.owner-stat-grid span{display:block;margin-top:4px;color:#64748b;font-size:10.5px;font-weight:850;line-height:1.6}
.shantia-quick{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:9px;
  margin:10px 0 14px;
}
.shantia-quick a{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:0 10px;
  border-radius:18px;
  border:1px solid var(--travel-border);
  background:#fff;
  color:#0f2744;
  text-decoration:none;
  box-shadow:var(--travel-shadow-soft);
  font-size:12px;
  font-weight:900;
}
.travel-net-note{
  margin:8px 0 10px;
  padding:10px 13px;
  border-radius:18px;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  color:#1d4ed8;
  font-size:11.5px;
  font-weight:850;
  line-height:1.9;
}
.travel-admin-list.pro,
.travel-admin-bookings.pro{display:grid;gap:10px}
.travel-admin-item.pro,
.booking-row.pro{
  grid-template-columns:72px minmax(0,1fr) auto;
  gap:12px;
  padding:11px;
  border-radius:22px;
}
.booking-row.pro{grid-template-columns:60px minmax(0,1fr) auto auto}
.tai-img,.booking-thumb{width:72px;height:72px;border-radius:18px}
.booking-thumb{width:60px;height:60px;border-radius:16px}
.tai-main h3,.booking-row.pro strong{margin:0 0 4px;color:#0f2744;font-size:14px;font-weight:950;line-height:1.55}
.tai-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tai-main p,.tai-main small,.booking-row.pro span,.booking-row.pro small{display:block;color:#64748b;font-size:11px;font-weight:750;line-height:1.8}
.tai-mini span{font-size:10.5px;padding:4px 8px;background:#f8fbff}
.tai-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.tai-actions .btn,.booking-row.pro .btn,.booking-row.pro button.small{
  min-height:34px;
  border-radius:999px;
  padding:0 11px;
  font-size:11px;
  font-weight:900;
}
.booking-row.pro form{display:flex;gap:6px;align-items:center;justify-content:flex-end}
.booking-row.pro select,
.travel-admin-form select,
.travel-admin-form input,
.travel-admin-form textarea,
.travel-owner-login-form input{
  border:1px solid var(--travel-border);
  border-radius:16px;
  background:#fff;
  color:#0f2744;
  font-family:inherit;
  font-weight:800;
  outline:none;
}
.booking-row.pro select{min-height:34px;padding:0 10px;font-size:11px}
.travel-admin-form{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.travel-admin-form label{display:flex;flex-direction:column;gap:6px;color:#334155;font-size:11.5px;font-weight:900}
.travel-admin-form input,.travel-admin-form select{min-height:44px;padding:0 12px}
.travel-admin-form textarea{padding:11px 12px;line-height:1.9;resize:vertical}
.travel-admin-form button{min-height:44px;border:0;border-radius:16px;background:linear-gradient(135deg,#0f2744,#2563eb);color:#fff;font-family:inherit;font-weight:950;cursor:pointer}
.admin-collapse{padding:12px;border-radius:24px}
.admin-collapse summary{cursor:pointer;font-weight:950;color:#0f2744;list-style:none;padding:4px 2px 12px}
.admin-collapse summary::-webkit-details-marker{display:none}
.pill-ok,.pill-off{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:10px;font-weight:950;font-style:normal}
.pill-ok{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}
.pill-off{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}
.owner-app-head{margin-bottom:12px}
.travel-owner-login-shell{
  min-height:calc(100vh - 24px);
  display:grid;
  place-items:center;
  padding:18px 0;
}
.travel-login-back{
  position:fixed;
  top:18px;
  right:18px;
  min-height:38px;
  display:inline-flex;
  align-items:center;
  padding:0 14px;
  border-radius:999px;
  border:1px solid var(--travel-border);
  background:rgba(255,255,255,.82);
  color:#1d4ed8;
  text-decoration:none;
  box-shadow:var(--travel-shadow-soft);
  font-size:12px;
  font-weight:900;
  backdrop-filter:blur(12px);
}
.travel-owner-login-card{
  width:min(100%,390px);
  padding:24px;
  border-radius:30px;
  border:1px solid var(--travel-border);
  background:rgba(255,255,255,.92);
  box-shadow:0 24px 60px rgba(15,39,68,.12);
  text-align:center;
}
.travel-login-mark{
  width:58px;
  height:58px;
  margin:0 auto 12px;
  display:grid;
  place-items:center;
  border-radius:22px;
  background:linear-gradient(135deg,#eff6ff,#e0f2fe);
  border:1px solid #bfdbfe;
  font-size:27px;
}
.travel-owner-login-card h1{margin:0 0 7px;color:#0f2744;font-size:22px;font-weight:950;line-height:1.35}
.travel-owner-login-card p{margin:0 0 16px;color:#64748b;font-size:12.5px;font-weight:750;line-height:1.9}
.travel-owner-login-form{display:grid;gap:10px;text-align:right}
.travel-owner-login-form label{display:grid;gap:6px;color:#334155;font-size:11.5px;font-weight:900}
.travel-owner-login-form input{min-height:48px;padding:0 14px}
.travel-owner-login-form button{
  min-height:48px;
  border:0;
  border-radius:18px;
  background:linear-gradient(135deg,#0f2744,#2563eb);
  color:#fff;
  font-family:inherit;
  font-size:13px;
  font-weight:950;
  cursor:pointer;
  box-shadow:0 12px 24px rgba(37,99,235,.20);
}
.travel-login-error{margin:0 0 12px;padding:10px 12px;border-radius:16px;border:1px solid #fecdd3;background:#fff1f2;color:#be123c;font-size:12px;font-weight:900;line-height:1.8;text-align:right}
.travel-login-note{display:block;margin-top:12px;color:#94a3b8;font-size:10.5px;font-weight:800}
.admin-calendar-pro{max-width:820px;background:#fff}
.admin-calendar-pro .cal-day.has-booking{background:#fff7ed;box-shadow:inset 0 0 0 1px #fed7aa;color:#9a3412;text-decoration:none}
.admin-calendar-pro .cal-day.has-booking:after{content:"";position:absolute;top:7px;left:7px;width:7px;height:7px;border-radius:50%;background:#f97316}
@media(max-width:900px){
  .travel-admin-stats.pro{grid-template-columns:repeat(3,minmax(0,1fr))}
  .owner-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .shantia-quick{grid-template-columns:repeat(3,minmax(0,1fr))}
  .travel-admin-form{grid-template-columns:repeat(2,minmax(0,1fr))}
  .booking-row.pro{grid-template-columns:54px minmax(0,1fr)}
  .booking-row.pro>div:nth-child(3),.booking-row.pro form{grid-column:1/-1}
}
@media(max-width:640px){
  .admin-main .travel-admin-shell{padding:0 0 22px}
  .shantia-admin-hero,.owner-hero-modern{padding:18px;border-radius:24px;align-items:flex-start}
  .shantia-admin-hero h1,.owner-hero-modern h1{font-size:20px}
  .shantia-admin-hero p,.owner-hero-modern p{font-size:12px}
  .shantia-admin-logo,.owner-hero-badge{display:none}
  .travel-admin-stats.pro,.owner-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .travel-admin-stats.pro>div,.owner-stat-grid>div{min-height:70px;padding:11px 8px;border-radius:18px}
  .travel-admin-stats.pro b,.owner-stat-grid b{font-size:14px}
  .travel-admin-stats.pro span,.owner-stat-grid span{font-size:9.5px}
  .shantia-quick{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:3px}
  .shantia-quick a{flex:0 0 auto;min-width:132px;scroll-snap-align:start}
  .travel-admin-item.pro,.booking-row.pro{grid-template-columns:54px minmax(0,1fr);padding:10px;border-radius:20px}
  .tai-img,.booking-thumb{width:54px;height:54px;border-radius:15px}
  .tai-actions{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  .tai-actions .btn{justify-content:center;text-align:center;padding:0 6px}
  .booking-row.pro form{display:grid;grid-template-columns:1fr auto;gap:6px}
  .travel-admin-form{grid-template-columns:1fr}
  .travel-owner-login-shell{min-height:calc(100vh - 20px);align-items:start;padding-top:70px}
  .travel-login-back{top:12px;right:12px}
  .travel-owner-login-card{padding:20px;border-radius:26px}
}

.travel-cancel-note{margin:12px 0;padding:12px 14px;border-radius:18px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:12px;line-height:1.8;font-weight:700}
.booking-actions button.btn{border:0;font-family:inherit;cursor:pointer}
.travel-empty-soft{padding:18px;border:1px dashed #cbd5e1;border-radius:22px;background:#f8fafc;color:#64748b;text-align:center;font-weight:800}

/* v4.6.12 - compact villa booking calendar prices */
.travel-book-modern .cal-day small,
.shantia-calendar .cal-day small{
  display:block;
  font-size:7.5px;
  line-height:1;
  letter-spacing:-.03em;
  color:#64748b;
  font-weight:850;
  font-variant-numeric:tabular-nums;
  opacity:.82;
}
.travel-book-modern .cal-day.selected small,
.shantia-calendar .cal-day.selected small{color:#dbeafe;opacity:1}
@media (max-width:640px){
  .travel-book-modern .cal-day small{display:block;font-size:7px;margin-top:-1px}
  .travel-book-modern .cal-day{gap:2px}
}

/* v4.6.13 - cancelled booking status states */
.booking-status-pill.cancelled{background:#fee2e2;color:#dc2626;border-color:#fecaca}
.booking-status-pill.info{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}
.travel-status-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:900;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;font-style:normal;white-space:nowrap}
.travel-status-pill.status-cancelled{background:#fee2e2;color:#dc2626;border-color:#fecaca}
.travel-status-pill.status-info{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}
.travel-status-pill.status-ok{background:#dcfce7;color:#166534;border-color:#bbf7d0}
