:root{
  /* Color system: 4 variables used throughout */
  --c-bg: #0b1020;
  --c-surface: #111a33;
  --c-primary: #7c5cff;
  --c-accent: #25d0ab;

  --c-text: #ecf0ff;
  --c-muted: rgba(236,240,255,.72);
  --c-border: rgba(236,240,255,.12);

  --radius-lg: 18px;
  --radius-md: 14px;
  --shadow: 0 12px 34px rgba(0,0,0,.28);

  --container: 1100px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 420px at 20% -10%, rgba(124,92,255,.30), transparent 60%),
              radial-gradient(900px 340px at 85% 0%, rgba(37,208,171,.24), transparent 55%),
              var(--c-bg);
  color:var(--c-text);
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{
  width:min(var(--container), calc(100% - 32px));
  margin:0 auto;
}

.muted{color:var(--c-muted)}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--c-border);
  border-radius:999px;
  background: rgba(255,255,255,.06);
  color: var(--c-text);
  font-size:13px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 12px 16px;
  font-weight: 650;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
}
.btn:active{transform: translateY(1px)}
.btn-primary{
  background: linear-gradient(135deg, var(--c-primary), rgba(124,92,255,.65));
  color: var(--c-text);
}
.btn-primary:hover{filter: brightness(1.03)}
.btn-ghost{
  background: rgba(255,255,255,.06);
  border-color: var(--c-border);
}
.btn-ghost:hover{background: rgba(255,255,255,.10)}
.btn-small{padding:10px 14px; font-size:14px}

.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid var(--c-border);
  backdrop-filter: blur(12px);
  background: rgba(11,16,32,.72);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 800;
  letter-spacing: .2px;
}
.brand-mark{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius: 12px;
  background: rgba(124,92,255,.16);
  border: 1px solid rgba(124,92,255,.38);
  color: var(--c-text);
}
.brand-name{font-size:16px}

.site-nav{
  display:flex;
  align-items:center;
  gap:18px;
}
.site-nav a{color:var(--c-muted); font-weight:650}
.site-nav a:hover{color:var(--c-text)}
.nav-toggle{
  display:none;
  width:42px;
  height:40px;
  border-radius: 12px;
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.06);
}
.nav-toggle span{
  display:block;
  height:2px;
  width:18px;
  background: var(--c-text);
  margin:4px auto;
  opacity:.9;
}

.section{
  padding: 56px 0;
}
.section-title{
  font-size: 28px;
  line-height: 1.15;
  margin: 0 0 8px 0;
}
.section-lead{
  margin: 0 0 22px 0;
  color: var(--c-muted);
  max-width: 720px;
}

/* Hero */
.hero{
  padding: 24px 0 10px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  align-items: stretch;
}
.hero-slider{
  border-radius: var(--radius-lg);
  overflow:hidden;
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,.04);
}
.hero-slide{
  position:relative;
  min-height: 440px;
}
.hero-slide::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(11,16,32,.78), rgba(11,16,32,.35) 55%, rgba(11,16,32,.78));
  z-index: 1;
}
.hero-slide img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-copy{
  position:absolute;
  z-index: 2;
  inset: 0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding: 26px;
  gap: 12px;
}
.hero-copy h1{
  margin:0;
  font-size: 40px;
  line-height: 1.05;
  letter-spacing:-.3px;
}
.hero-copy p{margin:0; color:var(--c-muted); max-width: 560px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top: 6px}

.hero-card{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow);
  padding: 20px;
  display:flex;
  flex-direction:column;
  gap: 14px;
}
.hero-card h2{
  margin:0;
  font-size: 18px;
}
.search-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.field{
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.label{
  font-size: 13px;
  color: var(--c-muted);
  font-weight: 650;
}
.input, select{
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--c-border);
  background: rgba(11,16,32,.45);
  color: var(--c-text);
  padding: 10px 12px;
  outline: none;
}
.input:focus, select:focus{
  border-color: rgba(124,92,255,.75);
  box-shadow: 0 0 0 4px rgba(124,92,255,.18);
}
.form-actions{
  grid-column: 1 / -1;
  display:flex;
  gap: 10px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.note{
  color: var(--c-muted);
  font-size: 13px;
}

/* Cards */
.card-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.card{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  overflow:hidden;
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
}
.card-media{
  position:relative;
  aspect-ratio: 16/10;
  overflow:hidden;
}
.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.02);
}
.card-body{
  padding: 14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.card-title{
  font-size: 16px;
  font-weight: 800;
  line-height:1.2;
  margin:0;
}
.card-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  flex-wrap:wrap;
  color: var(--c-muted);
  font-size: 13px;
}
.price{
  font-weight: 900;
  color: var(--c-text);
}
.kpi{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}
.kpi .badge{border-color: rgba(37,208,171,.25); background: rgba(37,208,171,.10)}
.kpi .star{color: var(--c-accent); font-weight: 900}

/* Offers carousel */
.carousel{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.offer-card{
  height: 100%;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  overflow:hidden;
}
.offer-card .card-body{padding: 14px}
.offer-card .tag{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid rgba(124,92,255,.35);
  background: rgba(124,92,255,.12);
  color: var(--c-text);
}

/* How it works */
.steps{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.step{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  padding: 16px;
}
.step .num{
  width:36px;height:36px;border-radius: 12px;
  display:grid;place-items:center;
  background: rgba(37,208,171,.12);
  border: 1px solid rgba(37,208,171,.30);
  font-weight: 900;
  margin-bottom: 10px;
}

/* Footer */
.site-footer{
  margin-top: 24px;
  border-top: 1px solid var(--c-border);
  background: rgba(11,16,32,.68);
}
.footer-grid{
  padding: 36px 0 18px;
  display:grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 18px;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 12px;
}
.footer-title{font-weight: 900}
.footer-subtitle{color: var(--c-muted); font-size: 13px}
.footer-meta{color: var(--c-muted); font-size: 14px; display:flex; flex-direction:column; gap: 6px}
.footer-col-title{font-weight: 900; margin-bottom: 10px}
.site-footer a{display:block; color: var(--c-muted); padding: 6px 0}
.site-footer a:hover{color: var(--c-text)}
.footer-bottom{
  padding: 14px 0 22px;
  border-top: 1px solid var(--c-border);
  display:flex;
  justify-content:space-between;
  gap: 10px;
  flex-wrap:wrap;
  color: var(--c-muted);
  font-size: 13px;
}

/* Swiper tweaks */
.swiper-pagination-bullet{background: rgba(236,240,255,.55)}
.swiper-pagination-bullet-active{background: var(--c-primary)}
.swiper-button-next, .swiper-button-prev{
  color: var(--c-text);
  text-shadow: 0 8px 16px rgba(0,0,0,.45);
}

/* ---------------------------------
   Search page
---------------------------------- */
.crumbs{
  display:flex;
  gap:10px;
  align-items:center;
  color: var(--c-muted);
  font-size: 13px;
  margin-bottom: 12px;
}
.crumbs a:hover{color: var(--c-text)}

.page-title{
  font-size: 30px;
  line-height: 1.1;
  margin: 0;
}

.search-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  flex-wrap:wrap;
  margin-bottom: 14px;
}
.search-actions{
  display:flex;
  align-items:flex-end;
  gap: 12px;
  flex-wrap:wrap;
}
.js-filters-toggle{display:none}
.sort{
  display:flex;
  align-items:center;
  gap: 10px;
}
.sort select{min-width: 220px}

.search-shell{
  display:grid;
  grid-template-columns: 330px 1fr;
  gap: 16px;
  align-items:start;
}

.search-filters{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow);
  padding: 14px;
}

.filters-head{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 12px;
}

.filters-form{
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.filter-block{
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius-md);
  padding: 12px;
}
.filter-title{
  font-weight: 900;
  margin-bottom: 10px;
}

.filter-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.filter-grid > div:nth-child(3){grid-column: 1 / -1;}

.check-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.check, .radio{
  display:flex;
  align-items:center;
  gap: 10px;
  color: var(--c-text);
  font-weight: 650;
  font-size: 13px;
}
.check input, .radio input{accent-color: var(--c-primary)}

.radio-grid{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.filter-actions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}

.results-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap:wrap;
  margin-bottom: 12px;
}

.empty{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  padding: 18px;
}

.pagination{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap:wrap;
}
.is-disabled{opacity:.55; pointer-events:none}

.overlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.55);
  z-index: 90;
}

.crumb-sep{opacity:.6}
.crumb.current{color: var(--c-text)}

.alert{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 120, 120, .35);
  background: rgba(255, 120, 120, .10);
  padding: 14px;
  color: var(--c-text);
}

.notice{
  border-radius: var(--radius-md);
  border: 1px solid rgba(37,208,171,.35);
  background: rgba(37,208,171,.10);
  padding: 12px;
  color: var(--c-text);
}

/* ---------------------------------
   Checkout page
---------------------------------- */
.checkout-shell{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items:start;
}
.checkout-aside{position: sticky; top: 92px;}
.checkout-property{
  display:grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items:center;
}
.checkout-thumb{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
  aspect-ratio: 4/3;
}
.checkout-thumb img{width:100%; height:100%; object-fit:cover;}

.form-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.pay-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.pay-card{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 12px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
  cursor:pointer;
}
.pay-card input{margin-top: 4px; accent-color: var(--c-primary);}
.pay-title{font-weight: 950; margin-bottom: 4px;}

.sum-grid{display:flex; flex-direction:column; gap: 10px; margin-top: 10px;}
.sum-row{display:flex; align-items:flex-start; justify-content:space-between; gap: 12px; font-size: 14px;}
.sum-row.total{padding-top: 10px; border-top: 1px solid var(--c-border); font-weight: 950; font-size: 15px;}

/* ---------------------------------
   Manage booking
---------------------------------- */
.manage-shell{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items:start;
}
.info-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.info-item{
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
}

/* ---------------------------------
   Property page
---------------------------------- */
.property-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 16px;
  flex-wrap:wrap;
}
.property-price{ text-align:right; min-width: 240px; }
.price-big{
  font-size: 28px;
  font-weight: 950;
  letter-spacing: -.2px;
}

.property-grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap: 16px;
  align-items:start;
}

.property-gallery{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.js-gallery-main{
  aspect-ratio: 16/10;
  background: rgba(255,255,255,.04);
}
.js-gallery-main img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.js-gallery-thumbs{
  padding: 10px;
  border-top: 1px solid var(--c-border);
  background: rgba(255,255,255,.03);
}
.js-gallery-thumbs .swiper-slide{opacity: .72; cursor:pointer; border-radius: 12px; overflow:hidden; border: 1px solid transparent;}
.js-gallery-thumbs .swiper-slide-thumb-active{opacity: 1; border-color: rgba(124,92,255,.55);}
.js-gallery-thumbs img{width:100%; height: 70px; object-fit:cover;}

.property-panels{display:flex; flex-direction:column; gap: 14px; margin-top: 14px;}
.panel{
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  padding: 16px;
}
.panel-title{margin:0 0 10px; font-size: 18px; font-weight: 950; letter-spacing: -.1px;}
.panel-text{color: var(--c-muted); font-size: 14px; line-height: 1.65;}

.highlights{display:flex; flex-direction:column; gap: 12px;}
.highlight{display:flex; gap: 12px; align-items:flex-start;}
.dot{width: 10px; height: 10px; border-radius: 999px; background: rgba(37,208,171,.9); margin-top: 5px; box-shadow: 0 0 0 4px rgba(37,208,171,.14);} 
.highlight-title{font-weight: 900; margin-bottom: 4px;}

.offer-mini-grid{display:grid; grid-template-columns: 1fr; gap: 10px;}
.offer-mini{display:grid; grid-template-columns: 96px 1fr; gap: 12px; align-items:center; padding: 10px; border-radius: var(--radius-md); border: 1px solid var(--c-border); background: rgba(255,255,255,.04);} 
.offer-mini-media{border-radius: 14px; overflow:hidden; border: 1px solid var(--c-border);}
.offer-mini-media img{width:100%; height: 70px; object-fit:cover;}

.property-aside{position: sticky; top: 92px;}
.booking-box{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(124,92,255,.28);
  background: linear-gradient(180deg, rgba(124,92,255,.10), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  padding: 16px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}
.booking-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.aside-actions{display:flex; flex-direction:column; gap: 10px; margin-top: 4px;}
.aside-note{padding-top: 10px; border-top: 1px solid var(--c-border);}

/* Confirmation */
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}
.confirm-hero{
  display:grid;
  grid-template-columns: 420px 1fr;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  overflow:hidden;
  background: var(--c-card);
  box-shadow: var(--shadow);
}
.confirm-hero-media{min-height: 240px;}
.confirm-hero-media img{width:100%; height:100%; object-fit:cover; display:block;}
.confirm-hero-body{padding: 18px; display:flex; flex-direction:column; justify-content:center;}
.confirm-title{margin: 8px 0 6px; font-size: 26px; letter-spacing: -0.3px;}
.pill-row{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.06);
  font-weight: 800;
  font-size: 12px;
}
.pill-success{border-color: rgba(14,227,184,.35); background: rgba(14,227,184,.12);}
.pill-danger{border-color: rgba(255,79,142,.35); background: rgba(255,79,142,.12);}
.pill-warn{border-color: rgba(255,188,52,.35); background: rgba(255,188,52,.12);}
.pill-neutral{border-color: rgba(124,92,255,.30); background: rgba(124,92,255,.10);}
.confirm-shell{display:grid; grid-template-columns: 1.3fr .7fr; gap: 16px; align-items:start;}
.kv-grid{display:grid; grid-template-columns: repeat(2, 1fr); gap: 10px;}
.kv{padding: 12px; border-radius: 14px; border: 1px solid var(--c-border); background: rgba(255,255,255,.05);}
.kv .k{font-size: 12px; text-transform: uppercase; letter-spacing:.06em; color: var(--c-muted);}
.kv .v{margin-top: 6px; font-weight: 900;}
.bank-box{margin-top: 10px; padding: 12px; border-radius: 14px; border: 1px dashed rgba(124,92,255,.45); background: rgba(124,92,255,.10);}

/* Online payment (demo gateway) */
.pay-box{
  padding: 14px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
}
.pay-row{display:flex; align-items:flex-end; justify-content:space-between; gap: 12px;}
.pay-amt{font-size: 28px; font-weight: 1000; letter-spacing: -0.4px;}

/* =========================
   Simple content pages (About / FAQ / Contact)
   ========================= */
.page-hero{
  padding: 34px 0 18px;
}
.page-hero-inner{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 16px;
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
}
.breadcrumb{
  font-size: 13px;
  color: var(--c-muted);
}
.breadcrumb a{color: inherit; text-decoration: underline; text-underline-offset: 3px;}
.breadcrumb .sep{opacity: .6; padding: 0 6px;}
.page-lead{margin: 10px 0 0; color: var(--c-muted); max-width: 62ch}
.page-hero-badges{display:flex; gap: 10px; flex-wrap:wrap; justify-content:flex-end}

.page-grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap: 16px;
}
.content-card,
.sidebar-card{
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow);
}
.content-card h2{margin: 0 0 10px; letter-spacing: -0.2px;}
.content-card p{line-height: 1.6}

.feature-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 14px;
}
.feature-item{
  padding: 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
}
.feature-title{font-weight: 900; margin-bottom: 6px}

.callout{
  margin-top: 16px;
  padding: 14px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(37,208,171,.35);
  background: linear-gradient(180deg, rgba(37,208,171,.14), rgba(255,255,255,.04));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.callout-title{font-weight: 900; margin-bottom: 4px}

.sidebar-card h3{margin: 0 0 12px}
.bullets{margin: 0; padding-left: 18px; color: var(--c-muted)}
.bullets li{margin: 8px 0}
.sidebar-divider{height: 1px; background: var(--c-border); margin: 14px 0}
.sidebar-links{display:flex; flex-direction:column; gap: 10px}

.faq-layout{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap: 16px;
}
.faq-list{display:flex; flex-direction:column; gap: 10px}
.faq-item{
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.04);
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding: 14px;
  font-weight: 850;
  list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-answer{padding: 0 14px 14px; line-height: 1.6}

.contact-grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap: 16px;
}
.form{margin-top: 12px}
.form-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.contact-cards{display:grid; gap: 10px}
.contact-card{
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,.04);
}
.contact-k{font-size: 12px; color: var(--c-muted)}
.contact-v{font-weight: 900; margin-top: 4px}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr; }
  .hero-slide{min-height: 380px}
  .card-grid{grid-template-columns: repeat(2, 1fr)}
  .property-grid{grid-template-columns: 1fr}
  .property-aside{position: static}
  .confirm-hero{grid-template-columns: 1fr;}
  .confirm-shell{grid-template-columns: 1fr;}
  .steps{grid-template-columns: 1fr; }
  .footer-grid{grid-template-columns: 1fr}
  .site-nav{
    position: fixed;
    top: 64px;
    right: 16px;
    left: 16px;
    border: 1px solid var(--c-border);
    background: rgba(11,16,32,.92);
    border-radius: var(--radius-lg);
    padding: 14px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap: 10px;
    box-shadow: var(--shadow);
  }
  .site-nav a{padding: 10px 12px; border-radius: 12px; background: rgba(255,255,255,.04)}
  .site-nav a.btn{background: rgba(124,92,255,.14)}
  .nav-toggle{display:block}
  .site-nav.is-open{display:flex}

  .js-filters-toggle{display:inline-flex}

  .search-shell{grid-template-columns: 1fr;}
  .filters-head{display:flex}
  .search-filters{
    position: fixed;
    z-index: 100;
    left: 16px;
    right: 16px;
    top: 86px;
    bottom: 16px;
    overflow:auto;
    display:none;
  }
  .search-filters.is-open{display:block}

  .checkout-shell{grid-template-columns: 1fr;}
  .checkout-aside{position: static;}

  .manage-shell{grid-template-columns: 1fr;}
  .info-grid{grid-template-columns: repeat(2, 1fr);}

  .page-hero-inner{flex-direction:column; align-items:flex-start}
  .page-hero-badges{justify-content:flex-start}
  .page-grid{grid-template-columns: 1fr}
  .faq-layout{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
}
@media (max-width: 560px){
  .hero-copy h1{font-size: 32px}
  .search-form{grid-template-columns: 1fr}
  .card-grid{grid-template-columns: 1fr}

  .property-price{ text-align:left; }
  .booking-form{grid-template-columns: 1fr}

  .filter-grid{grid-template-columns: 1fr}
  .filter-grid > div:nth-child(3){grid-column: auto;}
  .check-grid{grid-template-columns: 1fr}
  .sort select{min-width: 200px}

  .form-grid{grid-template-columns: 1fr}
  .pay-grid{grid-template-columns: 1fr}

  .info-grid{grid-template-columns: 1fr;}

  .feature-grid{grid-template-columns: 1fr}
  .form-row{grid-template-columns: 1fr}
}


/* Admin styles */

.admin-body { background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,1)); color: #0b1020; --text: #0b1020; --muted: rgba(11,16,32,.62); }
.admin-body .muted{ color: var(--muted); }
.admin-topbar { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border-bottom: 1px solid rgba(0,0,0,.06); }
.admin-topbar-inner { display:flex; align-items:center; justify-content:space-between; padding: 14px 0; gap: 12px; }
.admin-nav { display:flex; align-items:center; gap: 10px; flex-wrap:wrap; justify-content:flex-end; }
.admin-link { color: var(--text); text-decoration:none; font-weight:700; font-size:14px; padding: 8px 10px; border-radius: 10px; }
.admin-link:hover { background: rgba(0,0,0,.04); }
.admin-link.disabled { opacity: .45; pointer-events:none; }
.admin-user { color: var(--muted); font-size: 13px; margin-left: 6px; margin-right: 2px; }

.admin-main { padding: 18px 0 44px; }
.admin-shell .admin-head { margin: 10px 0 16px; }
.admin-kpis { display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 16px; }
.kpi-card { background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 16px; padding: 14px; box-shadow: 0 10px 28px rgba(0,0,0,.05); }
.kpi-label { color: var(--muted); font-size: 13px; }
.kpi-value { font-size: 28px; font-weight: 900; margin-top: 6px; letter-spacing: -0.02em; }

.admin-card { background:#fff; border: 1px solid rgba(0,0,0,.06); border-radius: 18px; padding: 14px; box-shadow: 0 14px 36px rgba(0,0,0,.06); }
.admin-card-head { display:flex; align-items:flex-end; justify-content:space-between; gap: 12px; padding-bottom: 10px; border-bottom: 1px solid rgba(0,0,0,.06); margin-bottom: 10px; }
.admin-alert{border-radius: 14px; border: 1px solid rgba(0,0,0,.08); background: rgba(0,0,0,.03); padding: 12px 14px; margin: 12px 0; font-weight: 800;}
.admin-alert.success{border-color: rgba(37,208,171,.35); background: rgba(37,208,171,.10);}
.admin-alert.info{border-color: rgba(124,92,255,.28); background: rgba(124,92,255,.08);}
.admin-alert.error{border-color: rgba(255,79,142,.25); background: rgba(255,79,142,.08);}

.admin-grid-2{display:grid; grid-template-columns: 1.15fr .85fr; gap: 14px; align-items:start;}
@media (max-width: 900px){.admin-grid-2{grid-template-columns: 1fr;}}


.admin-body .info-item{background:#fff; border: 1px solid rgba(0,0,0,.06);}
.admin-body .info-label{color: var(--muted); font-size:12px; font-weight: 850;}
.admin-body .info-value{font-weight: 900;}

.table-wrap { width:100%; overflow:auto; border-radius: 14px; border: 1px solid rgba(0,0,0,.06); }
.table { width: 100%; border-collapse: collapse; min-width: 860px; background: #fff; }
.table th, .table td { padding: 12px 12px; text-align:left; vertical-align: top; border-bottom: 1px solid rgba(0,0,0,.06); }
.table th { font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); background: rgba(0,0,0,.02); }
.table tr:hover td { background: rgba(0,0,0,.015); }

.pill { display:inline-flex; align-items:center; padding: 6px 10px; border-radius: 999px; font-weight: 800; font-size: 12px; background: rgba(0,0,0,.06); color: var(--text); }
.pill-soft { background: rgba(0, 117, 255, .10); color: #0a3d91; }

.admin-auth { padding: 36px 0 54px; }
.auth-card { max-width: 520px; margin: 0 auto; background:#fff; border: 1px solid rgba(0,0,0,.06); border-radius: 18px; padding: 18px; box-shadow: 0 18px 44px rgba(0,0,0,.08); }
.auth-head h1 { margin: 0 0 8px; }
.btn-sm { padding: 8px 10px; font-size: 13px; border-radius: 12px; }
.btn-block { width: 100%; justify-content: center; }
.admin-footer { border-top: 1px solid rgba(0,0,0,.06); padding: 16px 0; background: rgba(255,255,255,.92); }

@media (max-width: 900px) {
  .admin-kpis { grid-template-columns: 1fr; }
  .admin-topbar-inner { align-items:flex-start; }
}


/* Admin — properties module */

.admin-link.active { background: rgba(0, 117, 255, .10); color: #0a3d91; }

.admin-head-row { display:flex; align-items:flex-end; justify-content:space-between; gap: 12px; flex-wrap:wrap; }
.admin-actions { display:flex; gap: 10px; flex-wrap:wrap; justify-content:flex-end; }

.admin-filters { display:grid; grid-template-columns: 1.6fr .7fr auto; gap: 12px; align-items:end; }
.admin-filters-4 { grid-template-columns: 1.6fr 1fr .9fr auto; }

.prop-cell { display:flex; align-items:center; gap: 12px; }
.prop-thumb { width: 48px; height: 48px; border-radius: 14px; background-size: cover; background-position: center; border: 1px solid rgba(0,0,0,.06); box-shadow: 0 10px 24px rgba(0,0,0,.06); }

.row-actions { display:flex; gap: 8px; align-items:center; flex-wrap:wrap; }

.admin-form { width: 100%; }
.admin-form-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.admin-form-grid .span-2 { grid-column: span 2; }
.checkbox-field label { display:flex; align-items:center; gap: 10px; font-weight: 800; }
.checkbox-field input { width: 18px; height: 18px; }
.hint { color: var(--muted); font-size: 12px; margin-top: 6px; }
.admin-form-actions { display:flex; gap: 10px; flex-wrap:wrap; margin-top: 14px; }

@media (max-width: 900px) {
  .admin-filters { grid-template-columns: 1fr; }
  .admin-actions { width: 100%; justify-content:flex-start; }
  .admin-form-grid { grid-template-columns: 1fr; }
  .admin-form-grid .span-2 { grid-column: auto; }
}


/* Admin — availability calendar */

.admin-filters-3 { grid-template-columns: 1.1fr 1fr 220px; }

.cal-month { font-weight: 950; letter-spacing: -0.01em; }

.cal-weekdays {
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10px;
  margin-bottom: 10px;
}

.cal-weekdays > div {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  padding: 8px 10px;
}

.cal-pad { min-height: 1px; }

.cal-pill { font-size: 11px; font-weight: 900; padding: 4px 8px; border-radius: 999px; border: 1px solid rgba(0,0,0,.08); background: rgba(0,0,0,.03); }
.cal-pill.ok { background: rgba(37,208,171,.12); border-color: rgba(37,208,171,.22); }
.cal-pill.danger { background: rgba(255,79,142,.10); border-color: rgba(255,79,142,.22); }
.cal-pill.soft { background: rgba(124,92,255,.10); border-color: rgba(124,92,255,.20); }

.field-row { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.inline-opts { display:flex; gap: 10px; flex-wrap:wrap; margin: 10px 0; }
.radio { display:flex; align-items:center; gap: 8px; padding: 6px 10px; border-radius: 12px; border: 1px solid rgba(0,0,0,.06); background: rgba(0,0,0,.02); font-weight: 900; font-size: 13px; }
.radio input { width: 16px; height: 16px; }
.help { margin-top: 6px; font-size: 12px; color: var(--muted); }

.cal-nav { display:flex; align-items:center; gap: 10px; }
.cal-nav .cal-title { font-weight: 950; letter-spacing: -0.01em; }

.cal-wrap { display:grid; grid-template-columns: 1.1fr .9fr; gap: 14px; align-items:start; }

.cal-grid {
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10px;
}

.cal-dow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  padding: 8px 10px;
}

.cal-day {
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  border-radius: 16px;
  padding: 10px;
  min-height: 92px;
  box-shadow: 0 12px 28px rgba(0,0,0,.05);
  text-align: left;
  cursor: pointer;
  transition: transform .08s ease, box-shadow .08s ease;
}

.cal-day:hover { transform: translateY(-1px); box-shadow: 0 16px 34px rgba(0,0,0,.07); }
.cal-day:active { transform: translateY(0); }

.cal-day.is-muted { opacity: .35; cursor: default; box-shadow: none; }
.cal-day.is-muted:hover { transform:none; box-shadow:none; }

.cal-top { display:flex; align-items:flex-start; justify-content:space-between; gap: 10px; }
.cal-num { font-weight: 950; font-size: 14px; }

.cal-badges { display:flex; gap: 6px; align-items:center; flex-wrap:wrap; justify-content:flex-end; }
.cal-tag { font-size: 11px; font-weight: 900; padding: 4px 8px; border-radius: 999px; border: 1px solid rgba(0,0,0,.08); background: rgba(0,0,0,.03); }
.cal-tag.open { background: rgba(37,208,171,.12); border-color: rgba(37,208,171,.22); }
.cal-tag.closed { background: rgba(255,79,142,.10); border-color: rgba(255,79,142,.22); }
.cal-tag.override { background: rgba(124,92,255,.10); border-color: rgba(124,92,255,.20); }

.cal-meta { margin-top: 10px; display:flex; flex-direction:column; gap: 6px; }
.cal-line { display:flex; align-items:center; justify-content:space-between; gap: 10px; font-size: 12px; }
.cal-line .k { color: var(--muted); font-weight: 850; }
.cal-line .v { font-weight: 950; }

.cal-selected {
  border: 2px solid rgba(0, 117, 255, .45);
  box-shadow: 0 18px 42px rgba(0,0,0,.10);
}

.range-hint { font-size: 12px; color: var(--muted); margin-top: 6px; }

.admin-form .seg { display:flex; gap: 10px; flex-wrap:wrap; }
.admin-form .seg label { display:flex; align-items:center; gap: 8px; font-weight: 900; font-size: 13px; }

.admin-kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  padding: 2px 6px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 8px;
  background: rgba(0,0,0,.03);
}

@media (max-width: 980px) {
  .cal-wrap { grid-template-columns: 1fr; }
  .admin-filters-3 { grid-template-columns: 1fr; }
  .cal-grid { gap: 8px; }
  .cal-day { min-height: 88px; }
  .field-row { grid-template-columns: 1fr; }
}