/* Airbooky — Responsive-first, minimalist design system */

/* === TOKENS === */
:root {
  --c-primary: #FF385C;
  --c-primary-hover: #E31C5F;
  --c-text: #1A1A1A;
  --c-text-secondary: #6B6B6B;
  --c-text-tertiary: #999;
  --c-bg: #FFF;
  --c-bg-alt: #F7F7F7;
  --c-border: #E0E0E0;
  --c-border-light: #EBEBEB;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,.12);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --transition: .15s ease;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-size:15px;line-height:1.6;color:var(--c-text);background:var(--c-bg)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* === UTILITIES === */
.container{width:100%;max-width:1120px;margin:0 auto;padding:0 20px}

/* === HEADER === */
.header{position:sticky;top:0;z-index:100;background:var(--c-bg);border-bottom:1px solid var(--c-border-light)}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:1120px;margin:0 auto;padding:0 20px}
.logo{font-size:22px;font-weight:700;color:var(--c-primary);letter-spacing:-.3px}
.nav{display:none;align-items:center;gap:8px}
.nav-link{padding:8px 14px;font-size:14px;font-weight:500;color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition)}
.nav-link:hover{color:var(--c-text);background:var(--c-bg-alt)}

/* Mobile menu btn */
.mobile-menu-btn{display:flex;flex-direction:column;gap:5px;padding:8px}
.mobile-menu-btn span{display:block;width:20px;height:2px;background:var(--c-text);border-radius:2px;transition:var(--transition)}
.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;background:var(--c-bg);border-bottom:1px solid var(--c-border);padding:8px 20px 16px;z-index:99;box-shadow:var(--shadow-md)}
.mobile-nav.active{display:block}
.mobile-nav a{display:block;padding:14px 0;font-size:15px;font-weight:500;color:var(--c-text);border-bottom:1px solid var(--c-border-light)}
.mobile-nav a:last-child{border:none}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition);white-space:nowrap;line-height:1}
.btn-primary{padding:10px 20px;background:var(--c-primary);color:#fff;font-size:14px;font-weight:600;border-radius:var(--radius-sm);transition:background var(--transition)}
.btn-primary:hover{background:var(--c-primary-hover)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:600;color:var(--c-text);border:1.5px solid var(--c-border);border-radius:var(--radius-sm);transition:all var(--transition)}
.btn-secondary:hover{border-color:var(--c-text)}
.btn-ghost{padding:10px 20px;font-size:14px;font-weight:500;color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition)}
.btn-ghost:hover{color:var(--c-text);background:var(--c-bg-alt)}

/* === HERO === */
.hero{padding:40px 0 48px}
.hero-content{margin-bottom:32px}
.hero-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--c-bg-alt);border:1px solid var(--c-border-light);border-radius:20px;font-size:13px;font-weight:500;color:var(--c-text-secondary);margin-bottom:20px}
.hero h1{font-size:32px;font-weight:700;line-height:1.15;letter-spacing:-.5px;margin-bottom:12px}
.hero h1 em{font-style:normal;color:var(--c-primary)}
.hero-subtitle{font-size:16px;color:var(--c-text-secondary);line-height:1.6;margin-bottom:28px}
.hero-visual{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/10}
.hero-visual img{width:100%;height:100%;object-fit:cover}

/* Search box */
.search-box{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.search-grid{display:grid;gap:12px}
.search-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--c-text-secondary);margin-bottom:6px}
.search-field input,.search-field select{width:100%;padding:12px 14px;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;color:var(--c-text);background:var(--c-bg);transition:border-color var(--transition)}
.search-field input:focus,.search-field select:focus{outline:none;border-color:var(--c-primary)}
.search-field input::placeholder{color:var(--c-text-tertiary)}
.search-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;background:var(--c-primary);color:#fff;font-size:15px;font-weight:600;border-radius:var(--radius-sm);transition:background var(--transition)}
.search-btn:hover{background:var(--c-primary-hover)}
.search-btn i{font-size:18px}
.trust-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:4px}
.trust-row span{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--c-text-secondary)}
.trust-row i{color:var(--c-primary);font-size:16px}

/* === SECTIONS === */
.section{padding:56px 0}
.section-alt{background:var(--c-bg-alt)}
.section-title{font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}
.section-desc{font-size:14px;color:var(--c-text-secondary);margin-bottom:28px}

/* === PROPERTY CARDS === */
.prop-grid{display:grid;grid-template-columns:1fr;gap:20px}
.prop-card{display:block;background:var(--c-bg);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--c-border-light);transition:box-shadow var(--transition),transform var(--transition)}
.prop-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.prop-card-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.prop-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.prop-card:hover .prop-card-img img{transform:scale(1.03)}
.prop-card-badge{position:absolute;top:10px;left:10px;padding:4px 10px;background:var(--c-bg);border-radius:6px;font-size:12px;font-weight:600;color:var(--c-text)}
.prop-card-body{padding:14px 16px}
.prop-card-loc{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.prop-card-loc span:first-child{font-size:12px;color:var(--c-text-secondary)}
.prop-card-loc .rating{font-size:12px;font-weight:600;display:flex;align-items:center;gap:3px}
.prop-card-loc .rating i{color:#222;font-size:14px}
.prop-card h3{font-size:15px;font-weight:600;line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.prop-card .meta{font-size:13px;color:var(--c-text-secondary);margin-bottom:10px}
.prop-card .price{font-size:14px}.prop-card .price strong{font-size:17px;font-weight:700}

/* === CITIES === */
.cities-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.city-card{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:3/2}
.city-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.city-card:hover img{transform:scale(1.05)}
.city-card-info{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(transparent,rgba(0,0,0,.6));color:#fff}
.city-card-info h4{font-size:15px;font-weight:600;margin-bottom:1px}
.city-card-info p{font-size:12px;opacity:.85}

/* === NEWSLETTER === */
.nl-box{padding:40px 24px;background:var(--c-bg-alt);border-radius:var(--radius-lg);text-align:center}
.nl-box h2{font-size:20px;font-weight:700;margin-bottom:6px}
.nl-box>p{font-size:14px;color:var(--c-text-secondary);margin-bottom:20px}
.nl-form{display:flex;flex-direction:column;gap:10px;max-width:420px;margin:0 auto 12px}
.nl-form input{padding:12px 16px;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px}
.nl-form input:focus{outline:none;border-color:var(--c-primary)}
.nl-form button{padding:12px;background:var(--c-primary);color:#fff;font-size:14px;font-weight:600;border-radius:var(--radius-sm)}
.nl-box small{font-size:12px;color:var(--c-text-tertiary)}
.nl-box small a{color:var(--c-primary)}

/* === DASHBOARD === */
.dash{padding:32px 0 56px}
.dash-header{margin-bottom:28px}
.dash-header h1{font-size:24px;font-weight:700;margin-bottom:4px}
.dash-header p{font-size:14px;color:var(--c-text-secondary)}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}
.stat-card{background:var(--c-bg);border:1px solid var(--c-border-light);border-radius:var(--radius-md);padding:20px}
.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:20px}
.stat-icon.pink{background:rgba(255,56,92,.08);color:var(--c-primary)}
.stat-icon.green{background:rgba(0,138,5,.08);color:#008a05}
.stat-icon.blue{background:rgba(66,133,244,.08);color:#4285F4}
.stat-icon.amber{background:rgba(245,158,11,.08);color:#F59E0B}
.stat-val{font-size:26px;font-weight:700;letter-spacing:-.5px;margin-bottom:2px}
.stat-label{font-size:13px;color:var(--c-text-secondary)}
.dash-grid{display:grid;gap:20px}
.card{background:var(--c-bg);border:1px solid var(--c-border-light);border-radius:var(--radius-md);padding:20px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.card-head h3{font-size:16px;font-weight:600}
.card-head a{font-size:13px;color:var(--c-primary);font-weight:500}
.list-item{display:flex;align-items:center;gap:14px;padding:10px;border-radius:var(--radius-sm);transition:background var(--transition)}
.list-item:hover{background:var(--c-bg-alt)}
.list-icon{width:38px;height:38px;background:var(--c-bg-alt);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--c-text-secondary);font-size:18px;flex-shrink:0}
.list-body{flex:1;min-width:0}
.list-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-sub{font-size:12px;color:var(--c-text-secondary)}
.list-thumb{width:56px;height:42px;object-fit:cover;border-radius:6px;flex-shrink:0}
.empty-state{text-align:center;padding:32px 16px;color:var(--c-text-secondary);font-size:14px}

/* === SEARCH PAGE === */
.search-page{padding:24px 0 56px}
.search-bar{background:var(--c-bg);border:1px solid var(--c-border-light);border-radius:var(--radius-md);padding:16px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.search-bar form{display:grid;gap:10px}
.search-bar .form-input{width:100%;padding:11px 14px;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;transition:border-color var(--transition)}
.search-bar .form-input:focus{outline:none;border-color:var(--c-primary)}
.results-head{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.results-head h1{font-size:22px;font-weight:700}
.results-head p{font-size:14px;color:var(--c-text-secondary)}
.sort-bar{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-text-secondary)}
.sort-bar select{padding:6px 10px;border:1px solid var(--c-border);border-radius:6px;font-size:13px;background:var(--c-bg)}
.results-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:32px}
.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px 0}
.pagination span{font-size:14px;color:var(--c-text-secondary)}

/* === FOOTER === */
.footer{background:var(--c-bg-alt);border-top:1px solid var(--c-border-light);padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:32px}
.footer-col h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--c-text);margin-bottom:14px}
.footer-col a{display:block;font-size:14px;color:var(--c-text-secondary);margin-bottom:8px;transition:color var(--transition)}
.footer-col a:hover{color:var(--c-primary)}
.footer-bottom{display:flex;flex-direction:column;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--c-border-light);text-align:center}
.footer-bottom p{font-size:13px;color:var(--c-text-secondary)}
.footer-social{display:flex;gap:16px}
.footer-social a{color:var(--c-text-secondary);font-size:20px;transition:color var(--transition)}
.footer-social a:hover{color:var(--c-primary)}

/* === ALERTS === */
.alert{position:fixed;top:80px;left:50%;transform:translateX(-50%);padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;z-index:1001;animation:slideIn .3s ease;white-space:nowrap}
@keyframes slideIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.alert-success{background:#D1FAE5;color:#065F46}
.alert-error{background:#FEE2E2;color:#991B1B}

/* === FORMS (shared) === */
.form-input{width:100%;padding:11px 14px;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;transition:border-color var(--transition)}
.form-input:focus{outline:none;border-color:var(--c-primary)}

/* ============================================
   RESPONSIVE BREAKPOINTS (mobile-first → up)
   ============================================ */

/* Tablet (≥640px) */
@media(min-width:640px){
  .hero-content{margin-bottom:40px}
  .hero h1{font-size:38px}
  .search-grid{grid-template-columns:1fr 1fr;gap:12px}
  .search-btn{grid-column:1/-1}
  .prop-grid{grid-template-columns:1fr 1fr}
  .cities-grid{grid-template-columns:repeat(3,1fr)}
  .nl-form{flex-direction:row}
  .nl-form input{flex:1}
  .nl-form button{white-space:nowrap;padding:12px 24px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .search-bar form{grid-template-columns:1fr 1fr 1fr;align-items:end}
  .results-grid{grid-template-columns:1fr 1fr}
  .results-head{flex-direction:row;justify-content:space-between;align-items:center}
  .footer-grid{grid-template-columns:repeat(4,1fr)}
}

/* Desktop (≥1024px) */
@media(min-width:1024px){
  .container{padding:0 32px}
  .header-inner{padding:0 32px}
  .nav{display:flex}
  .mobile-menu-btn{display:none}
  .hero{padding:64px 0 72px}
  .hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .hero-content{margin-bottom:0}
  .hero h1{font-size:44px}
  .search-grid{grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}
  .search-btn{grid-column:auto;width:auto}
  .prop-grid{grid-template-columns:repeat(3,1fr)}
  .cities-grid{grid-template-columns:repeat(3,1fr);gap:16px}
  .city-card{aspect-ratio:4/3}
  .section{padding:72px 0}
  .section-title{font-size:26px}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .dash-grid{grid-template-columns:1fr 1fr}
  .search-bar form{grid-template-columns:2fr 1fr 1fr 1fr auto;align-items:end}
  .results-grid{grid-template-columns:repeat(3,1fr)}
  .footer-bottom{flex-direction:row;justify-content:space-between}
}
/* ========================================
   Airbooky - CSS Principal
   Design moderne inspiré d'Airbnb
   ======================================== */

/* Variables CSS */
:root {
    --primary: #FF385C;
    --primary-dark: #E31C5F;
    --secondary: #222222;
    --text: #222222;
    --text-light: #717171;
    --text-lighter: #ABABAB;
    --bg: #FFFFFF;
    --bg-gray: #F7F7F7;
    --border: #DDDDDD;
    --shadow: rgba(0,0,0,0.08);
    --shadow-lg: rgba(0,0,0,0.15);
    --radius: 12px;
    --radius-lg: 16px;
    --transition: 0.2s ease;
}

/* Reset */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text);
    background: var(--bg);
    min-height: 100vh;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
}

input, select, textarea {
    font-family: inherit;
    font-size: inherit;
}

/* Container */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ========================================
   Header
   ======================================== */
.header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.logo {
    font-size: 24px;
    font-weight: 700;
    color: var(--primary);
}

.nav {
    display: flex;
    align-items: center;
    gap: 24px;
}

.nav-link {
    font-size: 14px;
    font-weight: 500;
    color: var(--text);
    transition: color var(--transition);
}

.nav-link:hover {
    color: var(--primary);
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--primary);
    color: white;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    transition: background var(--transition);
}

.btn-primary:hover {
    background: var(--primary-dark);
}

/* Mobile Menu */
.mobile-menu-btn {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: none;
}

.mobile-menu-btn span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text);
}

.mobile-nav {
    display: none;
    position: fixed;
    top: 70px;
    left: 0;
    right: 0;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    z-index: 99;
}

.mobile-nav.active {
    display: block;
}

.mobile-nav a {
    display: block;
    padding: 12px 0;
    font-size: 16px;
    font-weight: 500;
    border-bottom: 1px solid var(--border);
}

/* ========================================
   Hero Section
   ======================================== */
.hero {
    padding: 60px 0 80px;
    background: linear-gradient(135deg, #FFF5F7 0%, #FFF 50%);
}

.hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.hero-content {
    max-width: 560px;
}

.hero-badge {
    display: inline-block;
    padding: 8px 16px;
    background: rgba(255, 56, 92, 0.1);
    color: var(--primary);
    font-size: 14px;
    font-weight: 600;
    border-radius: 20px;
    margin-bottom: 24px;
}

.hero-content h1 {
    font-size: 42px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 16px;
    color: var(--text);
}

.hero-content h1 span {
    color: var(--primary);
}

.hero-subtitle {
    font-size: 18px;
    color: var(--text-light);
    margin-bottom: 32px;
}

/* Search Box */
.search-box {
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 24px var(--shadow-lg);
    padding: 24px;
    margin-bottom: 24px;
}

.search-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.search-row {
    display: flex;
    gap: 12px;
    align-items: flex-end;
}

.search-field {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.search-field-large {
    flex: 2;
}

.search-field label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.search-field input,
.search-field select {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid var(--border);
    border-radius: 10px;
    font-size: 15px;
    color: var(--text);
    background: var(--bg);
    transition: border-color var(--transition);
}

.search-field input:focus,
.search-field select:focus {
    outline: none;
    border-color: var(--primary);
}

.search-field input::placeholder {
    color: var(--text-lighter);
}

.search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 32px;
    background: var(--primary);
    color: white;
    font-size: 15px;
    font-weight: 600;
    border-radius: 10px;
    transition: background var(--transition), transform var(--transition);
    white-space: nowrap;
    height: 52px;
}

.search-btn:hover {
    background: var(--primary-dark);
    transform: translateY(-1px);
}

.search-btn svg {
    flex-shrink: 0;
}

/* Trust Badges */
.trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.trust-badges span {
    font-size: 14px;
    color: var(--text-light);
}

/* Hero Visual */
.hero-visual img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 60px var(--shadow-lg);
}

/* ========================================
   Sections
   ======================================== */
.section {
    padding: 80px 0;
}

.section-gray {
    background: var(--bg-gray);
}

.section-header {
    margin-bottom: 40px;
}

.section-header.centered {
    text-align: center;
}

.section-header h2 {
    font-size: 32px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}

.section-header p {
    font-size: 16px;
    color: var(--text-light);
}

.section-footer {
    text-align: center;
    margin-top: 40px;
}

/* ========================================
   Property Cards
   ======================================== */
.properties-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.property-card {
    display: block;
    background: var(--bg);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: 0 2px 8px var(--shadow);
    transition: transform var(--transition), box-shadow var(--transition);
}

.property-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px var(--shadow-lg);
}

.property-image {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
}

.property-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.property-card:hover .property-image img {
    transform: scale(1.05);
}

.property-image .badge {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 6px 12px;
    background: var(--bg);
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    border-radius: 6px;
}

.property-info {
    padding: 16px;
}

.property-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.property-top .location {
    font-size: 13px;
    color: var(--text-light);
}

.property-top .rating {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
}

.property-info h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 6px;
    line-height: 1.4;
}

.property-info .details {
    font-size: 14px;
    color: var(--text-light);
    margin-bottom: 12px;
}

.property-info .price {
    font-size: 15px;
    color: var(--text);
}

.property-info .price strong {
    font-size: 18px;
    font-weight: 700;
}

/* ========================================
   Steps Section
   ======================================== */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.step-card {
    text-align: center;
    padding: 32px 24px;
    background: var(--bg);
    border-radius: var(--radius);
    box-shadow: 0 4px 20px var(--shadow);
}

.step-icon {
    font-size: 48px;
    margin-bottom: 20px;
}

.step-card h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}

.step-card p {
    font-size: 14px;
    color: var(--text-light);
}

/* ========================================
   Destinations
   ======================================== */
.destinations-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}

.destination-card {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 1;
}

.destination-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.destination-card:hover img {
    transform: scale(1.1);
}

.destination-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 16px;
    background: linear-gradient(transparent, rgba(0,0,0,0.7));
    color: white;
}

.destination-overlay h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 2px;
}

.destination-overlay p {
    font-size: 12px;
    opacity: 0.9;
}

/* ========================================
   Newsletter
   ======================================== */
.newsletter-box {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
    padding: 48px;
    background: var(--bg-gray);
    border-radius: var(--radius-lg);
}

.newsletter-box h2 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}

.newsletter-box > p {
    color: var(--text-light);
    margin-bottom: 24px;
}

.newsletter-form {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}

.newsletter-form input {
    flex: 1;
    padding: 14px 18px;
    border: 2px solid var(--border);
    border-radius: 8px;
    font-size: 15px;
}

.newsletter-form input:focus {
    outline: none;
    border-color: var(--primary);
}

.newsletter-form button {
    padding: 14px 28px;
    background: var(--primary);
    color: white;
    font-size: 15px;
    font-weight: 600;
    border-radius: 8px;
}

.newsletter-box small {
    font-size: 13px;
    color: var(--text-lighter);
}

.newsletter-box small a {
    color: var(--primary);
}

/* ========================================
   Buttons
   ======================================== */
.btn-secondary {
    display: inline-block;
    padding: 14px 32px;
    background: transparent;
    color: var(--text);
    font-size: 15px;
    font-weight: 600;
    border: 2px solid var(--border);
    border-radius: 8px;
    transition: border-color var(--transition), color var(--transition);
}

.btn-secondary:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: transparent;
    color: var(--text);
    font-size: 14px;
    font-weight: 500;
    border: 1px solid var(--border);
    border-radius: 8px;
    transition: all var(--transition);
}

.btn-outline:hover {
    border-color: var(--text);
    background: var(--bg-gray);
}

/* ========================================
   Footer
   ======================================== */
.footer {
    background: var(--bg-gray);
    padding: 60px 0 30px;
    border-top: 1px solid var(--border);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    margin-bottom: 40px;
}

.footer-col h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.footer-col a {
    display: block;
    font-size: 14px;
    color: var(--text-light);
    margin-bottom: 10px;
    transition: color var(--transition);
}

.footer-col a:hover {
    color: var(--primary);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

.footer-bottom p {
    font-size: 14px;
    color: var(--text-light);
}

.footer-social {
    display: flex;
    gap: 16px;
}

.footer-social a {
    color: var(--text-light);
    transition: color var(--transition);
}

.footer-social a:hover {
    color: var(--primary);
}

/* ========================================
   Dashboard Page
   ======================================== */
.dashboard {
    padding: 40px 0;
}

.dashboard-header {
    margin-bottom: 32px;
}

.dashboard-header h1 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
}

.dashboard-header p {
    color: var(--text-light);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 40px;
}

.stat-card {
    background: var(--bg);
    border-radius: var(--radius);
    padding: 24px;
    box-shadow: 0 2px 8px var(--shadow);
}

.stat-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.stat-card-icon.pink {
    background: rgba(255, 56, 92, 0.1);
    color: var(--primary);
}

.stat-card-icon.green {
    background: rgba(0, 138, 5, 0.1);
    color: #008a05;
}

.stat-card-icon.blue {
    background: rgba(66, 133, 244, 0.1);
    color: #4285F4;
}

.stat-card-icon.yellow {
    background: rgba(251, 188, 5, 0.1);
    color: #FBBC05;
}

.stat-card-value {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 4px;
}

.stat-card-label {
    font-size: 14px;
    color: var(--text-light);
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.card {
    background: var(--bg);
    border-radius: var(--radius);
    padding: 24px;
    box-shadow: 0 2px 8px var(--shadow);
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.card-header h3 {
    font-size: 18px;
    font-weight: 600;
}

.card-header a {
    font-size: 14px;
    color: var(--primary);
}

.list-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px;
    border-radius: 8px;
    transition: background var(--transition);
}

.list-item:hover {
    background: var(--bg-gray);
}

.list-item-icon {
    width: 40px;
    height: 40px;
    background: var(--bg-gray);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-light);
}

.list-item-content {
    flex: 1;
}

.list-item-title {
    font-weight: 500;
    margin-bottom: 2px;
}

.list-item-subtitle {
    font-size: 13px;
    color: var(--text-light);
}

.empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-light);
}

/* ========================================
   Search Results Page
   ======================================== */
.search-page {
    padding: 24px 0;
}

.search-filters {
    background: var(--bg);
    border-radius: var(--radius);
    padding: 20px;
    box-shadow: 0 2px 8px var(--shadow);
    margin-bottom: 24px;
    position: sticky;
    top: 86px;
    z-index: 50;
}

.search-filters form {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.search-filters .form-input {
    padding: 12px 16px;
    border: 2px solid var(--border);
    border-radius: 8px;
    font-size: 14px;
    background: var(--bg);
    transition: border-color var(--transition);
}

.search-filters .form-input:focus {
    outline: none;
    border-color: var(--primary);
}

.search-filters .form-input-wide {
    flex: 1;
    min-width: 200px;
}

.results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.results-header h1 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 4px;
}

.results-header p {
    font-size: 14px;
    color: var(--text-light);
}

.sort-select {
    display: flex;
    align-items: center;
    gap: 8px;
}

.sort-select span {
    font-size: 14px;
    color: var(--text-light);
}

.sort-select select {
    padding: 8px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    font-size: 14px;
    background: var(--bg);
}

.results-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 40px;
}

.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    padding: 20px 0;
}

.pagination span {
    color: var(--text-light);
}

/* ========================================
   Forms
   ======================================== */
.form-input {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--border);
    border-radius: 8px;
    font-size: 15px;
    transition: border-color var(--transition);
}

.form-input:focus {
    outline: none;
    border-color: var(--primary);
}

/* ========================================
   Alerts
   ======================================== */
.alert {
    position: fixed;
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
    padding: 14px 24px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    z-index: 1001;
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.alert-success {
    background: #D4EDDA;
    color: #155724;
}

.alert-error {
    background: #F8D7DA;
    color: #721C24;
}

/* ========================================
   Responsive
   ======================================== */
@media (max-width: 1024px) {
    .hero-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .hero-content {
        max-width: 100%;
        text-align: center;
    }

    .hero-content h1 {
        font-size: 32px;
    }

    .trust-badges {
        justify-content: center;
    }

    .hero-visual {
        max-width: 500px;
        margin: 0 auto;
    }

    .hero-visual img {
        height: 300px;
    }

    .properties-grid,
    .results-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .destinations-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nav {
        display: none;
    }

    .mobile-menu-btn {
        display: flex;
    }

    .hero {
        padding: 40px 0 60px;
    }

    .hero-content h1 {
        font-size: 28px;
    }

    .search-row {
        flex-direction: column;
    }

    .search-btn {
        width: 100%;
    }

    .section {
        padding: 50px 0;
    }

    .section-header h2 {
        font-size: 24px;
    }

    .properties-grid,
    .results-grid {
        grid-template-columns: 1fr;
    }

    .steps-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .destinations-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .dashboard-grid {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: 1fr;
    }

    .search-filters form {
        flex-direction: column;
    }

    .search-filters .form-input,
    .search-filters .btn-primary {
        width: 100%;
    }

    .results-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .newsletter-form {
        flex-direction: column;
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 16px;
    }

    .destinations-grid {
        grid-template-columns: 1fr 1fr;
    }

    .footer-grid {
        grid-template-columns: 1fr;
    }
}
/* ========================================
   Airbooky - CSS Principal
   Design moderne inspiré d'Airbnb
   ======================================== */

/* Variables CSS */
:root {
    --primary: #FF385C;
    --primary-dark: #E31C5F;
    --secondary: #222222;
    --text: #222222;
    --text-light: #717171;
    --text-lighter: #ABABAB;
    --bg: #FFFFFF;
    --bg-gray: #F7F7F7;
    --border: #DDDDDD;
    --shadow: rgba(0,0,0,0.08);
    --shadow-lg: rgba(0,0,0,0.15);
    --radius: 12px;
    --radius-lg: 16px;
    --transition: 0.2s ease;
}

/* Reset */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text);
    background: var(--bg);
    min-height: 100vh;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
}

input, select, textarea {
    font-family: inherit;
    font-size: inherit;
}

/* Container */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ========================================
   Header
   ======================================== */
.header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.logo {
    font-size: 24px;
    font-weight: 700;
    color: var(--primary);
}

.nav {
    display: flex;
    align-items: center;
    gap: 24px;
}

.nav-link {
    font-size: 14px;
    font-weight: 500;
    color: var(--text);
    transition: color var(--transition);
}

.nav-link:hover {
    color: var(--primary);
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--primary);
    color: white;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    transition: background var(--transition);
}

.btn-primary:hover {
    background: var(--primary-dark);
}

/* Mobile Menu Button */
.mobile-menu-btn {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: none;
}

.mobile-menu-btn span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text);
    transition: var(--transition);
}

/* Mobile Nav */
.mobile-nav {
    display: none;
    position: fixed;
    top: 70px;
    left: 0;
    right: 0;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    z-index: 99;
}

.mobile-nav.active {
    display: block;
}

.mobile-nav a {
    display: block;
    padding: 12px 0;
    font-size: 16px;
    font-weight: 500;
    border-bottom: 1px solid var(--border);
}

.mobile-nav a:last-child {
    border-bottom: none;
}

/* ========================================
   Hero Section
   ======================================== */
.hero {
    padding: 60px 0 80px;
    background: linear-gradient(135deg, #FFF5F7 0%, #FFF 50%);
}

.hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.hero-content {
    max-width: 540px;
}

.hero-badge {
    display: inline-block;
    padding: 8px 16px;
    background: rgba(255, 56, 92, 0.1);
    color: var(--primary);
    font-size: 14px;
    font-weight: 600;
    border-radius: 20px;
    margin-bottom: 24px;
}

.hero-content h1 {
    font-size: 48px;
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 20px;
    color: var(--text);
}

.hero-content h1 span {
    color: var(--primary);
}

.hero-subtitle {
    font-size: 18px;
    color: var(--text-light);
    margin-bottom: 32px;
    line-height: 1.6;
}

/* Search Form */
.search-form {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 20px;
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 20px var(--shadow);
    margin-bottom: 24px;
}

.search-field {
    flex: 1;
    min-width: 140px;
}

.search-field label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.search-field input,
.search-field select {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--text);
    background: var(--bg);
    transition: border-color var(--transition);
}

.search-field input:focus,
.search-field select:focus {
    outline: none;
    border-color: var(--primary);
}

.search-field input::placeholder {
    color: var(--text-lighter);
}

.search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    background: var(--primary);
    color: white;
    font-size: 15px;
    font-weight: 600;
    border-radius: 8px;
    transition: background var(--transition);
    align-self: flex-end;
}

.search-btn:hover {
    background: var(--primary-dark);
}

.search-btn svg {
    flex-shrink: 0;
}

/* Trust Badges */
.trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.trust-badges span {
    font-size: 14px;
    color: var(--text-light);
}

/* Hero Visual */
.hero-visual {
    position: relative;
}

.hero-visual img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 60px var(--shadow-lg);
}

/* ========================================
   Sections
   ======================================== */
.section {
    padding: 80px 0;
}

.section-gray {
    background: var(--bg-gray);
}

.section-header {
    margin-bottom: 40px;
}

.section-header.centered {
    text-align: center;
}

.section-header h2 {
    font-size: 32px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}

.section-header p {
    font-size: 16px;
    color: var(--text-light);
}

.section-footer {
    text-align: center;
    margin-top: 40px;
}

/* ========================================
   Property Cards
   ======================================== */
.properties-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
}

.property-card {
    display: block;
    background: var(--bg);
    border-radius: var(--radius);
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}

.property-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px var(--shadow);
}

.property-image {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
}

.property-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.property-card:hover .property-image img {
    transform: scale(1.05);
}

.property-image .badge {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 6px 12px;
    background: var(--bg);
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    border-radius: 6px;
}

.property-info {
    padding: 16px;
}

.property-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.property-top .location {
    font-size: 13px;
    color: var(--text-light);
}

.property-top .rating {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
}

.property-info h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 6px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.property-info .details {
    font-size: 14px;
    color: var(--text-light);
    margin-bottom: 12px;
}

.property-info .price {
    font-size: 15px;
    color: var(--text);
}

.property-info .price strong {
    font-size: 18px;
    font-weight: 700;
}

/* ========================================
   Steps Section
   ======================================== */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.step-card {
    text-align: center;
    padding: 32px 24px;
    background: var(--bg);
    border-radius: var(--radius);
    box-shadow: 0 4px 20px var(--shadow);
}

.step-icon {
    font-size: 48px;
    margin-bottom: 20px;
    line-height: 1;
}

.step-card h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}

.step-card p {
    font-size: 14px;
    color: var(--text-light);
    line-height: 1.6;
}

/* ========================================
   Destinations
   ======================================== */
.destinations-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.destination-card {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 1;
}

.destination-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.destination-card:hover img {
    transform: scale(1.1);
}

.destination-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px;
    background: linear-gradient(transparent, rgba(0,0,0,0.7));
    color: white;
}

.destination-overlay h4 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 4px;
}

.destination-overlay p {
    font-size: 13px;
    opacity: 0.9;
}

/* ========================================
   CTA Section
   ======================================== */
.section-cta {
    padding: 60px 0;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
}

.cta-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
}

.cta-text {
    color: white;
}

.cta-text h2 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
}

.cta-text p {
    font-size: 16px;
    opacity: 0.9;
}

.btn-white {
    display: inline-block;
    padding: 14px 32px;
    background: white;
    color: var(--primary);
    font-size: 15px;
    font-weight: 600;
    border-radius: 8px;
    white-space: nowrap;
    transition: transform var(--transition);
}

.btn-white:hover {
    transform: translateY(-2px);
}

.btn-secondary {
    display: inline-block;
    padding: 14px 32px;
    background: transparent;
    color: var(--text);
    font-size: 15px;
    font-weight: 600;
    border: 2px solid var(--border);
    border-radius: 8px;
    transition: border-color var(--transition), color var(--transition);
}

.btn-secondary:hover {
    border-color: var(--primary);
    color: var(--primary);
}

/* ========================================
   Newsletter
   ======================================== */
.newsletter-box {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
    padding: 48px;
    background: var(--bg-gray);
    border-radius: var(--radius-lg);
}

.newsletter-box h2 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}

.newsletter-box > p {
    color: var(--text-light);
    margin-bottom: 24px;
}

.newsletter-form {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}

.newsletter-form input {
    flex: 1;
    padding: 14px 18px;
    border: 1px solid var(--border);
    border-radius: 8px;
    font-size: 15px;
}

.newsletter-form input:focus {
    outline: none;
    border-color: var(--primary);
}

.newsletter-form button {
    padding: 14px 28px;
    background: var(--primary);
    color: white;
    font-size: 15px;
    font-weight: 600;
    border-radius: 8px;
    transition: background var(--transition);
}

.newsletter-form button:hover {
    background: var(--primary-dark);
}

.newsletter-box small {
    font-size: 13px;
    color: var(--text-lighter);
}

.newsletter-box small a {
    color: var(--primary);
}

/* ========================================
   Footer
   ======================================== */
.footer {
    background: var(--bg-gray);
    padding: 60px 0 30px;
    border-top: 1px solid var(--border);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    margin-bottom: 40px;
}

.footer-col h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.footer-col a {
    display: block;
    font-size: 14px;
    color: var(--text-light);
    margin-bottom: 10px;
    transition: color var(--transition);
}

.footer-col a:hover {
    color: var(--primary);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

.footer-bottom p {
    font-size: 14px;
    color: var(--text-light);
}

.footer-social {
    display: flex;
    gap: 16px;
}

.footer-social a {
    color: var(--text-light);
    transition: color var(--transition);
}

.footer-social a:hover {
    color: var(--primary);
}

/* ========================================
   Alerts
   ======================================== */
.alert {
    position: fixed;
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
    padding: 14px 24px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    z-index: 1001;
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.alert-success {
    background: #D4EDDA;
    color: #155724;
}

.alert-error {
    background: #F8D7DA;
    color: #721C24;
}

/* ========================================
   No Properties
   ======================================== */
.no-properties {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 20px;
    color: var(--text-light);
}

/* ========================================
   Responsive
   ======================================== */
@media (max-width: 1024px) {
    .hero-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .hero-content {
        max-width: 100%;
        text-align: center;
    }

    .hero-content h1 {
        font-size: 36px;
    }

    .search-form {
        justify-content: center;
    }

    .trust-badges {
        justify-content: center;
    }

    .hero-visual {
        max-width: 500px;
        margin: 0 auto;
    }

    .hero-visual img {
        height: 300px;
    }

    .steps-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }

    .destinations-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nav {
        display: none;
    }

    .mobile-menu-btn {
        display: flex;
    }

    .hero {
        padding: 40px 0 60px;
    }

    .hero-content h1 {
        font-size: 28px;
    }

    .hero-subtitle {
        font-size: 16px;
    }

    .search-form {
        flex-direction: column;
        padding: 16px;
    }

    .search-field {
        min-width: 100%;
    }

    .search-btn {
        width: 100%;
    }

    .section {
        padding: 50px 0;
    }

    .section-header h2 {
        font-size: 24px;
    }

    .steps-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .step-card {
        padding: 24px 20px;
    }

    .step-icon {
        font-size: 36px;
    }

    .destinations-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .cta-box {
        flex-direction: column;
        text-align: center;
    }

    .cta-text h2 {
        font-size: 22px;
    }

    .newsletter-box {
        padding: 32px 20px;
    }

    .newsletter-form {
        flex-direction: column;
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 16px;
    }

    .header-inner {
        padding: 0 16px;
    }

    .hero-content h1 {
        font-size: 24px;
    }

    .properties-grid {
        grid-template-columns: 1fr;
    }

    .destinations-grid {
        grid-template-columns: 1fr;
    }

    .footer-grid {
        grid-template-columns: 1fr;
    }
}
/**
 * Airbooky - Modern CSS Styles
 * Airbnb-inspired design with premium look and feel
 */

/* ==========================================
   CSS Variables / Design Tokens
   ========================================== */
:root {
    /* Primary Colors */
    --primary: #ff385c;
    --primary-dark: #e31c5f;
    --primary-light: #ff5a5f;
    --primary-gradient: linear-gradient(135deg, #ff385c 0%, #bd1e59 100%);
    
    /* Neutral Colors */
    --black: #222222;
    --gray-900: #333333;
    --gray-800: #484848;
    --gray-700: #717171;
    --gray-600: #767676;
    --gray-500: #9a9a9a;
    --gray-400: #b0b0b0;
    --gray-300: #dddddd;
    --gray-200: #ebebeb;
    --gray-100: #f7f7f7;
    --white: #ffffff;
    
    /* Semantic Colors */
    --success: #00a699;
    --warning: #ff9500;
    --error: #c13515;
    --info: #428bff;
    
    /* Typography */
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 1.875rem;
    --font-size-4xl: 2.25rem;
    --font-size-5xl: 3rem;
    
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;
    
    /* Spacing */
    --spacing-1: 0.25rem;
    --spacing-2: 0.5rem;
    --spacing-3: 0.75rem;
    --spacing-4: 1rem;
    --spacing-5: 1.25rem;
    --spacing-6: 1.5rem;
    --spacing-8: 2rem;
    --spacing-10: 2.5rem;
    --spacing-12: 3rem;
    --spacing-16: 4rem;
    --spacing-20: 5rem;
    
    /* Border Radius */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-2xl: 32px;
    --radius-full: 9999px;
    
    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    --shadow-card: 0 6px 16px rgba(0, 0, 0, 0.12);
    --shadow-card-hover: 0 6px 20px rgba(0, 0, 0, 0.2);
    
    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-normal: 250ms ease;
    --transition-slow: 350ms ease;
    
    /* Layout */
    --container-max: 1280px;
    --header-height: 80px;
}

/* ==========================================
   CSS Reset & Base
   ========================================== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    color: var(--gray-800);
    background: var(--white);
    min-height: 100vh;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    text-decoration: none;
    color: inherit;
    transition: color var(--transition-fast);
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

input, textarea, select {
    font-family: inherit;
    font-size: inherit;
}

ul, ol {
    list-style: none;
}

/* ==========================================
   Typography
   ========================================== */
h1, h2, h3, h4, h5, h6 {
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-tight);
    color: var(--black);
}

h1 { font-size: var(--font-size-5xl); }
h2 { font-size: var(--font-size-4xl); }
h3 { font-size: var(--font-size-3xl); }
h4 { font-size: var(--font-size-2xl); }
h5 { font-size: var(--font-size-xl); }
h6 { font-size: var(--font-size-lg); }

p { margin-bottom: var(--spacing-4); }

.text-primary { color: var(--primary); }
.text-muted { color: var(--gray-600); }
.text-small { font-size: var(--font-size-sm); }
.text-center { text-align: center; }

/* ==========================================
   Layout Utilities
   ========================================== */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--spacing-6);
}

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1; }
.gap-2 { gap: var(--spacing-2); }
.gap-3 { gap: var(--spacing-3); }
.gap-4 { gap: var(--spacing-4); }
.gap-6 { gap: var(--spacing-6); }
.gap-8 { gap: var(--spacing-8); }

.grid { display: grid; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.mt-2 { margin-top: var(--spacing-2); }
.mt-4 { margin-top: var(--spacing-4); }
.mt-6 { margin-top: var(--spacing-6); }
.mt-8 { margin-top: var(--spacing-8); }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-6 { margin-bottom: var(--spacing-6); }
.mb-8 { margin-bottom: var(--spacing-8); }

.hidden { display: none !important; }

/* ==========================================
   Header / Navigation - NOUVEAU DESIGN
   ========================================== */
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    background: var(--white);
    z-index: 1000;
    transition: all var(--transition-normal);
}

.header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gray-200), transparent);
}

.header.scrolled {
    box-shadow: var(--shadow-md);
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--spacing-6);
}

/* Logo - Sans image, juste le texte stylisé */
.logo {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.logo-text {
    font-size: 1.75rem;
    font-weight: 800;
    background: var(--primary-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: -0.5px;
}

/* Navigation */
.nav {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.nav-link {
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-full);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    transition: all var(--transition-fast);
    position: relative;
}

.nav-link:hover {
    background: var(--gray-100);
    color: var(--black);
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 50%;
    transform: translateX(-50%) scaleX(0);
    width: 20px;
    height: 2px;
    background: var(--primary);
    border-radius: 2px;
    transition: transform var(--transition-fast);
}

.nav-link:hover::after {
    transform: translateX(-50%) scaleX(1);
}

.nav-divider {
    width: 1px;
    height: 24px;
    background: var(--gray-300);
    margin: 0 var(--spacing-2);
}

/* Mobile menu button */
.mobile-menu-btn {
    display: none;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    color: var(--gray-800);
    transition: background var(--transition-fast);
}

.mobile-menu-btn:hover {
    background: var(--gray-100);
}

/* Mobile Navigation */
.mobile-nav {
    display: none;
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--white);
    padding: var(--spacing-6);
    flex-direction: column;
    gap: var(--spacing-2);
    z-index: 999;
    animation: slideDown 0.3s ease;
}

.mobile-nav.active {
    display: flex;
}

.mobile-nav-link {
    padding: var(--spacing-4);
    border-radius: var(--radius-md);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    color: var(--gray-800);
    transition: background var(--transition-fast);
}

.mobile-nav-link:hover {
    background: var(--gray-100);
}

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ==========================================
   Buttons
   ========================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-6);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    line-height: 1;
    transition: all var(--transition-fast);
    cursor: pointer;
    white-space: nowrap;
}

.btn-primary {
    background: var(--primary-gradient);
    color: var(--white);
    box-shadow: 0 4px 14px rgba(255, 56, 92, 0.4);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 56, 92, 0.5);
}

.btn-secondary {
    background: var(--white);
    color: var(--black);
    border: 2px solid var(--black);
}

.btn-secondary:hover {
    background: var(--black);
    color: var(--white);
}

.btn-outline {
    background: transparent;
    color: var(--black);
    border: 1px solid var(--gray-300);
}

.btn-outline:hover {
    border-color: var(--black);
    background: var(--gray-100);
}

.btn-ghost {
    background: transparent;
    color: var(--gray-800);
}

.btn-ghost:hover {
    background: var(--gray-100);
}

.btn-lg {
    padding: var(--spacing-4) var(--spacing-8);
    font-size: var(--font-size-lg);
    border-radius: var(--radius-md);
}

.btn-sm {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
}

.btn-icon {
    padding: var(--spacing-3);
    border-radius: var(--radius-full);
}

.btn-rounded {
    border-radius: var(--radius-full);
}

/* ==========================================
   Hero Section - NOUVEAU DESIGN
   ========================================== */
.hero {
    min-height: 100vh;
    padding-top: var(--header-height);
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, #fef7f8 0%, #fff 50%, #f8f4ff 100%);
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 80%;
    height: 150%;
    background: radial-gradient(circle, rgba(255, 56, 92, 0.05) 0%, transparent 70%);
    pointer-events: none;
}

.hero-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-12);
    align-items: center;
    min-height: calc(100vh - var(--header-height) - var(--spacing-16));
    padding: var(--spacing-8) 0;
}

.hero-content {
    max-width: 560px;
    position: relative;
    z-index: 2;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2) var(--spacing-4);
    background: rgba(255, 56, 92, 0.1);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--primary);
    margin-bottom: var(--spacing-6);
}

.hero-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: var(--spacing-6);
    color: var(--black);
}

.hero-title span {
    background: var(--primary-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero-subtitle {
    font-size: var(--font-size-xl);
    color: var(--gray-600);
    margin-bottom: var(--spacing-8);
    line-height: var(--line-height-relaxed);
}

/* Hero Image - CORRIGÉ pour ne pas déformer */
.hero-image {
    position: relative;
    height: 550px;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-2xl);
}

.hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.hero-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.3) 100%);
    z-index: 1;
    pointer-events: none;
}

/* Trust indicators */
.trust-indicators {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-6);
    margin-top: var(--spacing-8);
}

.trust-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.trust-icon {
    width: 20px;
    height: 20px;
    color: var(--success);
}

.trust-text {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

/* ==========================================
   Search Box - AMÉLIORÉ
   ========================================== */
.search-box {
    background: var(--white);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--gray-200);
    display: flex;
    align-items: stretch;
    max-width: 100%;
    position: relative;
    transition: all var(--transition-normal);
}

.search-box:hover,
.search-box:focus-within {
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    border-color: var(--gray-300);
}

.search-box-field {
    flex: 1;
    padding: var(--spacing-4) var(--spacing-5);
    position: relative;
    cursor: pointer;
    border-radius: var(--radius-xl);
    transition: background var(--transition-fast);
    min-width: 0;
}

.search-box-field:hover {
    background: var(--gray-100);
}

.search-box-field:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 28px;
    background: var(--gray-300);
}

.search-box-label {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    color: var(--black);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-1);
}

.search-box-input {
    width: 100%;
    border: none;
    background: transparent;
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    outline: none;
}

.search-box-input::placeholder {
    color: var(--gray-500);
}

.search-box-btn {
    position: absolute;
    right: var(--spacing-2);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-4) var(--spacing-5);
    background: var(--primary-gradient);
    color: var(--white);
    border-radius: var(--radius-xl);
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-fast);
    box-shadow: 0 4px 14px rgba(255, 56, 92, 0.4);
}

.search-box-btn:hover {
    transform: translateY(-50%) scale(1.05);
    box-shadow: 0 6px 20px rgba(255, 56, 92, 0.5);
}

.search-box-btn svg {
    width: 18px;
    height: 18px;
}

/* ==========================================
   Property Cards
   ========================================== */
.property-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-6);
}

.property-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--white);
    transition: transform var(--transition-normal);
}

.property-card:hover {
    transform: translateY(-8px);
}

.property-card-image {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.property-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.property-card:hover .property-card-image img {
    transform: scale(1.08);
}

.property-card-badge {
    position: absolute;
    top: var(--spacing-3);
    left: var(--spacing-3);
    padding: var(--spacing-1) var(--spacing-3);
    background: var(--white);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    box-shadow: var(--shadow-md);
}

.property-card-save {
    position: absolute;
    top: var(--spacing-3);
    right: var(--spacing-3);
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gray-800);
    opacity: 0;
    transition: all var(--transition-fast);
    backdrop-filter: blur(4px);
}

.property-card:hover .property-card-save {
    opacity: 1;
}

.property-card-save:hover {
    color: var(--primary);
    transform: scale(1.1);
}

.property-card-save.saved {
    opacity: 1;
    color: var(--primary);
}

.property-card-content {
    padding: var(--spacing-4) 0;
}

.property-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-1);
}

.property-card-location {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

.property-card-rating {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    font-size: var(--font-size-sm);
}

.property-card-rating svg {
    width: 14px;
    height: 14px;
    fill: var(--black);
}

.property-card-title {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.property-card-details {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-2);
}

.property-card-price {
    font-size: var(--font-size-base);
}

.property-card-price strong {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

/* ==========================================
   Section Styles
   ========================================== */
.section {
    padding: var(--spacing-16) 0;
}

.section-header {
    margin-bottom: var(--spacing-8);
}

.section-title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-2);
}

.section-subtitle {
    color: var(--gray-600);
    font-size: var(--font-size-lg);
}

/* ==========================================
   Cards
   ========================================== */
.card {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    transition: all var(--transition-normal);
}

.card-shadow {
    border: none;
    box-shadow: var(--shadow-card);
}

.card-hover:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-card-hover);
}

/* ==========================================
   Destination Cards
   ========================================== */
.destination-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-4);
}

.destination-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    padding: var(--spacing-4);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
}

.destination-card:hover {
    background: var(--gray-100);
    transform: translateX(4px);
}

.destination-card-image {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
}

.destination-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.destination-card-name {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

.destination-card-count {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

/* ==========================================
   Forms
   ========================================== */
.form-group {
    margin-bottom: var(--spacing-6);
}

.form-label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--black);
    margin-bottom: var(--spacing-2);
}

.form-input {
    width: 100%;
    padding: var(--spacing-4);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
    transition: all var(--transition-fast);
}

.form-input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(255, 56, 92, 0.1);
}

.form-input.error {
    border-color: var(--error);
}

.form-error {
    font-size: var(--font-size-sm);
    color: var(--error);
    margin-top: var(--spacing-1);
}

.form-hint {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-top: var(--spacing-1);
}

textarea.form-input {
    min-height: 120px;
    resize: vertical;
}

select.form-input {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23717171' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 48px;
}

/* Checkbox & Radio */
.form-check {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    cursor: pointer;
}

.form-check-input {
    width: 20px;
    height: 20px;
    border: 2px solid var(--gray-400);
    border-radius: 4px;
    cursor: pointer;
    appearance: none;
    transition: all var(--transition-fast);
}

.form-check-input:checked {
    background: var(--primary);
    border-color: var(--primary);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}

/* ==========================================
   Alerts
   ========================================== */
.alert {
    padding: var(--spacing-4) var(--spacing-5);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.alert-success { background: #d1fae5; color: #065f46; }
.alert-error { background: #fee2e2; color: #991b1b; }
.alert-warning { background: #fef3c7; color: #92400e; }
.alert-info { background: #dbeafe; color: #1e40af; }

/* ==========================================
   Modal
   ========================================== */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-6);
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-normal);
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal {
    background: var(--white);
    border-radius: var(--radius-xl);
    max-width: 568px;
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    transform: translateY(20px);
    transition: transform var(--transition-normal);
}

.modal-overlay.active .modal {
    transform: translateY(0);
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-5) var(--spacing-6);
    border-bottom: 1px solid var(--gray-200);
}

.modal-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
}

.modal-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition-fast);
}

.modal-close:hover {
    background: var(--gray-100);
}

.modal-body {
    padding: var(--spacing-6);
    overflow-y: auto;
    max-height: calc(90vh - 140px);
}

.modal-footer {
    padding: var(--spacing-5) var(--spacing-6);
    border-top: 1px solid var(--gray-200);
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-3);
}

/* ==========================================
   Footer
   ========================================== */
.footer {
    background: var(--gray-100);
    border-top: 1px solid var(--gray-200);
    padding: var(--spacing-16) 0 var(--spacing-8);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-8);
    margin-bottom: var(--spacing-12);
}

.footer-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-4);
    color: var(--black);
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.footer-link {
    font-size: var(--font-size-sm);
    color: var(--gray-700);
    transition: color var(--transition-fast);
}

.footer-link:hover {
    color: var(--primary);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--spacing-8);
    border-top: 1px solid var(--gray-300);
}

.footer-copyright {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.footer-social {
    display: flex;
    gap: var(--spacing-4);
}

.footer-social a {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gray-600);
    border-radius: var(--radius-full);
    transition: all var(--transition-fast);
}

.footer-social a:hover {
    background: var(--gray-200);
    color: var(--primary);
}

/* ==========================================
   Auth Pages
   ========================================== */
.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-6);
    background: linear-gradient(135deg, #fef7f8 0%, #fff 100%);
}

.auth-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: var(--spacing-10);
    width: 100%;
    max-width: 480px;
}

.auth-logo {
    text-align: center;
    margin-bottom: var(--spacing-6);
}

.auth-logo .logo-text {
    font-size: 2rem;
}

.auth-title {
    font-size: var(--font-size-2xl);
    text-align: center;
    margin-bottom: var(--spacing-2);
}

.auth-subtitle {
    text-align: center;
    color: var(--gray-600);
    margin-bottom: var(--spacing-8);
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    margin: var(--spacing-6) 0;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--gray-300);
}

.auth-divider span {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

.auth-footer {
    text-align: center;
    margin-top: var(--spacing-6);
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.auth-footer a {
    color: var(--primary);
    font-weight: var(--font-weight-semibold);
}

/* ==========================================
   Dashboard
   ========================================== */
.dashboard-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    min-height: 100vh;
    padding-top: var(--header-height);
}

.dashboard-sidebar {
    background: var(--white);
    border-right: 1px solid var(--gray-200);
    padding: var(--spacing-6);
    position: sticky;
    top: var(--header-height);
    height: calc(100vh - var(--header-height));
    overflow-y: auto;
}

.dashboard-nav {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.dashboard-nav-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-sm);
    font-weight: var(--font-weight-medium);
    color: var(--gray-700);
    transition: all var(--transition-fast);
}

.dashboard-nav-item:hover,
.dashboard-nav-item.active {
    background: var(--gray-100);
    color: var(--black);
}

.dashboard-nav-item.active {
    background: rgba(255, 56, 92, 0.1);
    color: var(--primary);
}

.dashboard-content {
    padding: var(--spacing-8);
    background: var(--gray-100);
}

.dashboard-header {
    margin-bottom: var(--spacing-8);
}

.dashboard-title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-2);
}

.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-6);
}

.stat-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow-sm);
}

.stat-label {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-2);
}

.stat-value {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--black);
}

.stat-change {
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-1);
}

.stat-change.positive { color: var(--success); }
.stat-change.negative { color: var(--error); }

/* ==========================================
   Price Comparison
   ========================================== */
.price-comparison {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow-card);
}

.price-comparison-header {
    margin-bottom: var(--spacing-6);
}

.price-comparison-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-4);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-3);
    transition: all var(--transition-fast);
}

.price-comparison-item:hover {
    border-color: var(--primary);
    background: rgba(255, 56, 92, 0.02);
}

.price-comparison-item.best {
    border-color: var(--success);
    background: rgba(0, 166, 153, 0.05);
}

.price-source {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.price-source-logo {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    object-fit: contain;
}

.price-source-name {
    font-weight: var(--font-weight-semibold);
}

.price-amount {
    text-align: right;
}

.price-total {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--black);
}

.price-nightly {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.price-badge {
    padding: var(--spacing-1) var(--spacing-2);
    background: var(--success);
    color: var(--white);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    border-radius: var(--radius-sm);
    margin-left: var(--spacing-2);
}

/* ==========================================
   RESPONSIVE DESIGN
   ========================================== */

/* Tablet */
@media (max-width: 1024px) {
    .hero-split {
        grid-template-columns: 1fr;
        gap: var(--spacing-8);
        text-align: center;
    }
    
    .hero-content {
        max-width: 100%;
        order: 1;
    }
    
    .hero-image {
        height: 400px;
        order: 0;
    }
    
    .trust-indicators {
        justify-content: center;
    }
    
    .search-box {
        flex-direction: column;
        border-radius: var(--radius-xl);
        padding: var(--spacing-4);
    }
    
    .search-box-field::after {
        display: none;
    }
    
    .search-box-field {
        border-radius: var(--radius-md);
    }
    
    .search-box-btn {
        position: relative;
        right: auto;
        top: auto;
        transform: none;
        width: 100%;
        margin-top: var(--spacing-4);
        justify-content: center;
        padding: var(--spacing-4);
    }
    
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .destination-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .dashboard-layout {
        grid-template-columns: 1fr;
    }
    
    .dashboard-sidebar {
        display: none;
    }
}

/* Mobile */
@media (max-width: 768px) {
    :root {
        --header-height: 64px;
    }
    
    .nav {
        display: none;
    }
    
    .mobile-menu-btn {
        display: flex;
    }
    
    .hero {
        min-height: auto;
        padding: calc(var(--header-height) + var(--spacing-6)) 0 var(--spacing-10);
    }
    
    .hero-split {
        padding: 0;
    }
    
    .hero-title {
        font-size: var(--font-size-3xl);
    }
    
    .hero-subtitle {
        font-size: var(--font-size-base);
    }
    
    .hero-image {
        height: 280px;
        border-radius: var(--radius-lg);
    }
    
    .hero-badge {
        font-size: var(--font-size-xs);
    }
    
    .trust-indicators {
        flex-direction: column;
        gap: var(--spacing-3);
        align-items: center;
    }
    
    .section {
        padding: var(--spacing-10) 0;
    }
    
    .section-title {
        font-size: var(--font-size-xl);
    }
    
    .property-grid {
        grid-template-columns: 1fr;
    }
    
    .grid-3 {
        grid-template-columns: 1fr;
    }
    
    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }
    
    .footer-bottom {
        flex-direction: column;
        gap: var(--spacing-4);
        text-align: center;
    }
    
    .destination-grid {
        grid-template-columns: 1fr;
    }
    
    .auth-card {
        padding: var(--spacing-6);
    }
    
    .stat-grid {
        grid-template-columns: 1fr;
    }
    
    .container {
        padding: 0 var(--spacing-4);
    }
}

/* Small Mobile */
@media (max-width: 480px) {
    .logo-text {
        font-size: 1.5rem;
    }
    
    .hero-title {
        font-size: var(--font-size-2xl);
    }
    
    .btn-lg {
        padding: var(--spacing-3) var(--spacing-6);
        font-size: var(--font-size-base);
    }
}

/* ==========================================
   Animations
   ========================================== */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { 
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in {
    animation: fadeIn 0.6s ease;
}

.animate-slide-up {
    animation: slideUp 0.6s ease;
}

/* ==========================================
   Skeleton Loading
   ========================================== */
.skeleton {
    background: linear-gradient(90deg, var(--gray-200) 25%, var(--gray-100) 50%, var(--gray-200) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
    border-radius: var(--radius-sm);
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ==========================================
   Scroll Snap for Mobile Property Cards
   ========================================== */
@media (max-width: 768px) {
    .property-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: var(--spacing-4);
        padding-bottom: var(--spacing-4);
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    
    .property-grid::-webkit-scrollbar {
        display: none;
    }
    
    .property-card {
        flex: 0 0 85%;
        scroll-snap-align: start;
    }
}

/* ==========================================
   Utility classes
   ========================================== */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
/**
 * RentCompare - Modern CSS Styles
 * Airbnb-inspired design with premium look and feel
 */

/* ==========================================
   CSS Variables / Design Tokens
   ========================================== */
:root {
    /* Primary Colors */
    --primary: #ff385c;
    --primary-dark: #e31c5f;
    --primary-light: #ff5a5f;
    
    /* Neutral Colors */
    --black: #222222;
    --gray-900: #333333;
    --gray-800: #484848;
    --gray-700: #717171;
    --gray-600: #767676;
    --gray-500: #9a9a9a;
    --gray-400: #b0b0b0;
    --gray-300: #dddddd;
    --gray-200: #ebebeb;
    --gray-100: #f7f7f7;
    --white: #ffffff;
    
    /* Semantic Colors */
    --success: #008a05;
    --warning: #c13515;
    --info: #428bff;
    
    /* Typography */
    --font-family: 'Circular', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 1.875rem;
    --font-size-4xl: 2.25rem;
    --font-size-5xl: 3rem;
    --font-size-6xl: 3.75rem;
    
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;
    
    /* Spacing */
    --spacing-1: 0.25rem;
    --spacing-2: 0.5rem;
    --spacing-3: 0.75rem;
    --spacing-4: 1rem;
    --spacing-5: 1.25rem;
    --spacing-6: 1.5rem;
    --spacing-8: 2rem;
    --spacing-10: 2.5rem;
    --spacing-12: 3rem;
    --spacing-16: 4rem;
    --spacing-20: 5rem;
    --spacing-24: 6rem;
    
    /* Border Radius */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-2xl: 24px;
    --radius-full: 9999px;
    
    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.08);
    --shadow-lg: 0 10px 20px rgba(0, 0, 0, 0.04), 0 2px 6px rgba(0, 0, 0, 0.04), 0 0 1px rgba(0, 0, 0, 0.04);
    --shadow-xl: 0 15px 30px rgba(0, 0, 0, 0.08), 0 5px 15px rgba(0, 0, 0, 0.04);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    --shadow-card: 0 6px 16px rgba(0, 0, 0, 0.12);
    --shadow-card-hover: 0 6px 20px rgba(0, 0, 0, 0.2);
    
    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-normal: 250ms ease;
    --transition-slow: 350ms ease;
    
    /* Layout */
    --container-max: 1280px;
    --container-narrow: 1024px;
    --header-height: 80px;
}

/* ==========================================
   CSS Reset & Base
   ========================================== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height-normal);
    color: var(--gray-800);
    background-color: var(--white);
    min-height: 100vh;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    text-decoration: none;
    color: inherit;
    transition: color var(--transition-fast);
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

input, textarea, select {
    font-family: inherit;
    font-size: inherit;
}

ul, ol {
    list-style: none;
}

/* ==========================================
   Typography
   ========================================== */
h1, h2, h3, h4, h5, h6 {
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-tight);
    color: var(--black);
}

h1 { font-size: var(--font-size-5xl); }
h2 { font-size: var(--font-size-4xl); }
h3 { font-size: var(--font-size-3xl); }
h4 { font-size: var(--font-size-2xl); }
h5 { font-size: var(--font-size-xl); }
h6 { font-size: var(--font-size-lg); }

p {
    margin-bottom: var(--spacing-4);
}

.text-primary { color: var(--primary); }
.text-muted { color: var(--gray-600); }
.text-small { font-size: var(--font-size-sm); }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* ==========================================
   Layout Utilities
   ========================================== */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--spacing-6);
}

.container-narrow {
    max-width: var(--container-narrow);
}

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end { justify-content: flex-end; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1; }
.gap-1 { gap: var(--spacing-1); }
.gap-2 { gap: var(--spacing-2); }
.gap-3 { gap: var(--spacing-3); }
.gap-4 { gap: var(--spacing-4); }
.gap-6 { gap: var(--spacing-6); }
.gap-8 { gap: var(--spacing-8); }

.grid { display: grid; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* ==========================================
   Spacing Utilities
   ========================================== */
.mt-1 { margin-top: var(--spacing-1); }
.mt-2 { margin-top: var(--spacing-2); }
.mt-3 { margin-top: var(--spacing-3); }
.mt-4 { margin-top: var(--spacing-4); }
.mt-6 { margin-top: var(--spacing-6); }
.mt-8 { margin-top: var(--spacing-8); }
.mt-12 { margin-top: var(--spacing-12); }

.mb-1 { margin-bottom: var(--spacing-1); }
.mb-2 { margin-bottom: var(--spacing-2); }
.mb-3 { margin-bottom: var(--spacing-3); }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-6 { margin-bottom: var(--spacing-6); }
.mb-8 { margin-bottom: var(--spacing-8); }
.mb-12 { margin-bottom: var(--spacing-12); }

.py-4 { padding-top: var(--spacing-4); padding-bottom: var(--spacing-4); }
.py-6 { padding-top: var(--spacing-6); padding-bottom: var(--spacing-6); }
.py-8 { padding-top: var(--spacing-8); padding-bottom: var(--spacing-8); }
.py-12 { padding-top: var(--spacing-12); padding-bottom: var(--spacing-12); }
.py-16 { padding-top: var(--spacing-16); padding-bottom: var(--spacing-16); }
.py-20 { padding-top: var(--spacing-20); padding-bottom: var(--spacing-20); }

.px-4 { padding-left: var(--spacing-4); padding-right: var(--spacing-4); }
.px-6 { padding-left: var(--spacing-6); padding-right: var(--spacing-6); }

/* ==========================================
   Header / Navigation
   ========================================== */
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    background: var(--white);
    border-bottom: 1px solid var(--gray-200);
    z-index: 1000;
    transition: box-shadow var(--transition-normal);
}

.header.scrolled {
    box-shadow: var(--shadow-md);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    padding: 0 var(--spacing-6);
    max-width: var(--container-max);
    margin: 0 auto;
}

.logo {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--primary);
}

.logo svg,
.logo img {
    width: 32px;
    height: 32px;
}

.nav {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.nav-link {
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-full);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    transition: background var(--transition-fast);
}

.nav-link:hover {
    background: var(--gray-100);
}

.nav-divider {
    width: 1px;
    height: 24px;
    background: var(--gray-300);
    margin: 0 var(--spacing-2);
}

/* ==========================================
   Buttons
   ========================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-6);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    line-height: 1;
    transition: all var(--transition-fast);
    cursor: pointer;
    white-space: nowrap;
}

.btn-primary {
    background: var(--primary);
    color: var(--white);
}

.btn-primary:hover {
    background: var(--primary-dark);
    transform: scale(1.02);
}

.btn-secondary {
    background: var(--white);
    color: var(--black);
    border: 1px solid var(--black);
}

.btn-secondary:hover {
    background: var(--gray-100);
}

.btn-outline {
    background: transparent;
    color: var(--black);
    border: 1px solid var(--gray-300);
}

.btn-outline:hover {
    border-color: var(--black);
}

.btn-ghost {
    background: transparent;
    color: var(--gray-800);
}

.btn-ghost:hover {
    background: var(--gray-100);
}

.btn-lg {
    padding: var(--spacing-4) var(--spacing-8);
    font-size: var(--font-size-lg);
    border-radius: var(--radius-md);
}

.btn-sm {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
}

.btn-icon {
    padding: var(--spacing-3);
    border-radius: var(--radius-full);
}

.btn-rounded {
    border-radius: var(--radius-full);
}

/* ==========================================
   Hero Section
   ========================================== */
.hero {
    min-height: 600px;
    padding-top: calc(var(--header-height) + var(--spacing-12));
    padding-bottom: var(--spacing-16);
    background: linear-gradient(135deg, var(--gray-100) 0%, var(--white) 100%);
}

.hero-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-12);
    align-items: center;
    min-height: 500px;
}

.hero-content {
    max-width: 560px;
}

.hero-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.1;
    margin-bottom: var(--spacing-6);
    color: var(--black);
}

.hero-title span {
    color: var(--primary);
}

.hero-subtitle {
    font-size: var(--font-size-xl);
    color: var(--gray-600);
    margin-bottom: var(--spacing-8);
    line-height: var(--line-height-relaxed);
}

.hero-image {
    position: relative;
    height: 500px;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-2xl);
}

.hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 70%, rgba(0,0,0,0.2) 100%);
}

/* ==========================================
   Search Box (Airbnb Style)
   ========================================== */
.search-box {
    background: var(--white);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--gray-200);
    display: flex;
    align-items: stretch;
    max-width: 850px;
    position: relative;
    transition: box-shadow var(--transition-normal);
}

.search-box:hover,
.search-box:focus-within {
    box-shadow: var(--shadow-xl);
}

.search-box-field {
    flex: 1;
    padding: var(--spacing-4) var(--spacing-6);
    position: relative;
    cursor: pointer;
    border-radius: var(--radius-full);
    transition: background var(--transition-fast);
}

.search-box-field:hover {
    background: var(--gray-100);
}

.search-box-field:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 32px;
    background: var(--gray-300);
}

.search-box-label {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    color: var(--black);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-1);
}

.search-box-input {
    width: 100%;
    border: none;
    background: transparent;
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    outline: none;
}

.search-box-input::placeholder {
    color: var(--gray-500);
}

.search-box-input[type="date"] {
    cursor: pointer;
}

.search-box-btn {
    position: absolute;
    right: var(--spacing-2);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-4) var(--spacing-6);
    background: var(--primary);
    color: var(--white);
    border-radius: var(--radius-full);
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-fast);
}

.search-box-btn:hover {
    background: var(--primary-dark);
    transform: translateY(-50%) scale(1.02);
}

.search-box-btn svg {
    width: 16px;
    height: 16px;
}

/* Compact Search (for header) */
.search-compact {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    padding: var(--spacing-2) var(--spacing-2) var(--spacing-2) var(--spacing-5);
    background: var(--white);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    transition: box-shadow var(--transition-fast);
}

.search-compact:hover {
    box-shadow: var(--shadow-md);
}

.search-compact-text {
    display: flex;
    gap: var(--spacing-3);
    font-size: var(--font-size-sm);
}

.search-compact-divider {
    color: var(--gray-300);
}

.search-compact-btn {
    width: 32px;
    height: 32px;
    background: var(--primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
}

/* ==========================================
   Property Cards
   ========================================== */
.property-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-6);
}

.property-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--white);
    transition: transform var(--transition-normal);
}

.property-card:hover {
    transform: translateY(-4px);
}

.property-card-image {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.property-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.property-card:hover .property-card-image img {
    transform: scale(1.05);
}

.property-card-badge {
    position: absolute;
    top: var(--spacing-3);
    left: var(--spacing-3);
    padding: var(--spacing-1) var(--spacing-3);
    background: var(--white);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    box-shadow: var(--shadow-md);
}

.property-card-save {
    position: absolute;
    top: var(--spacing-3);
    right: var(--spacing-3);
    width: 32px;
    height: 32px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    opacity: 0;
    transition: opacity var(--transition-fast);
}

.property-card:hover .property-card-save {
    opacity: 1;
}

.property-card-save.saved {
    opacity: 1;
    color: var(--primary);
    background: var(--white);
}

.property-card-content {
    padding: var(--spacing-4) 0;
}

.property-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-1);
}

.property-card-location {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

.property-card-rating {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    font-size: var(--font-size-sm);
}

.property-card-rating svg {
    width: 14px;
    height: 14px;
    fill: var(--black);
}

.property-card-title {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.property-card-details {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-2);
}

.property-card-price {
    font-size: var(--font-size-base);
}

.property-card-price strong {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

/* ==========================================
   Section Styles
   ========================================== */
.section {
    padding: var(--spacing-16) 0;
}

.section-header {
    margin-bottom: var(--spacing-8);
}

.section-title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-2);
}

.section-subtitle {
    color: var(--gray-600);
    font-size: var(--font-size-lg);
}

/* ==========================================
   Destination Cards
   ========================================== */
.destination-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-4);
}

.destination-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    padding: var(--spacing-4);
    border-radius: var(--radius-lg);
    transition: background var(--transition-fast);
}

.destination-card:hover {
    background: var(--gray-100);
}

.destination-card-image {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
}

.destination-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.destination-card-name {
    font-weight: var(--font-weight-semibold);
    color: var(--black);
}

.destination-card-count {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

/* ==========================================
   Forms & Inputs
   ========================================== */
.form-group {
    margin-bottom: var(--spacing-6);
}

.form-label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--black);
    margin-bottom: var(--spacing-2);
}

.form-input {
    width: 100%;
    padding: var(--spacing-4);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-input:focus {
    outline: none;
    border-color: var(--black);
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1);
}

.form-input::placeholder {
    color: var(--gray-500);
}

.form-input.error {
    border-color: var(--warning);
}

.form-error {
    font-size: var(--font-size-sm);
    color: var(--warning);
    margin-top: var(--spacing-1);
}

.form-hint {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-top: var(--spacing-1);
}

textarea.form-input {
    min-height: 120px;
    resize: vertical;
}

select.form-input {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23717171' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 48px;
}

/* Checkbox & Radio */
.form-check {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    cursor: pointer;
}

.form-check-input {
    width: 20px;
    height: 20px;
    border: 2px solid var(--gray-400);
    border-radius: 4px;
    cursor: pointer;
    appearance: none;
    transition: all var(--transition-fast);
}

.form-check-input:checked {
    background: var(--black);
    border-color: var(--black);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}

.form-check-input[type="radio"] {
    border-radius: 50%;
}

/* ==========================================
   Cards
   ========================================== */
.card {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
}

.card-shadow {
    border: none;
    box-shadow: var(--shadow-card);
}

.card-hover:hover {
    box-shadow: var(--shadow-card-hover);
}

.card-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-4);
}

/* ==========================================
   Alerts & Messages
   ========================================== */
.alert {
    padding: var(--spacing-4) var(--spacing-5);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.alert-success {
    background: #d4edda;
    color: #155724;
}

.alert-error {
    background: #f8d7da;
    color: #721c24;
}

.alert-warning {
    background: #fff3cd;
    color: #856404;
}

.alert-info {
    background: #d1ecf1;
    color: #0c5460;
}

/* ==========================================
   Modal
   ========================================== */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-6);
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-normal);
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal {
    background: var(--white);
    border-radius: var(--radius-xl);
    max-width: 568px;
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    transform: translateY(20px);
    transition: transform var(--transition-normal);
}

.modal-overlay.active .modal {
    transform: translateY(0);
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-5) var(--spacing-6);
    border-bottom: 1px solid var(--gray-200);
}

.modal-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
}

.modal-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition-fast);
}

.modal-close:hover {
    background: var(--gray-100);
}

.modal-body {
    padding: var(--spacing-6);
    overflow-y: auto;
    max-height: calc(90vh - 140px);
}

.modal-footer {
    padding: var(--spacing-5) var(--spacing-6);
    border-top: 1px solid var(--gray-200);
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-3);
}

/* ==========================================
   Footer
   ========================================== */
.footer {
    background: var(--gray-100);
    border-top: 1px solid var(--gray-200);
    padding: var(--spacing-16) 0 var(--spacing-8);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-8);
    margin-bottom: var(--spacing-12);
}

.footer-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-4);
    color: var(--black);
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.footer-link {
    font-size: var(--font-size-sm);
    color: var(--gray-700);
    transition: color var(--transition-fast);
}

.footer-link:hover {
    color: var(--black);
    text-decoration: underline;
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--spacing-8);
    border-top: 1px solid var(--gray-300);
}

.footer-copyright {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.footer-social {
    display: flex;
    gap: var(--spacing-4);
}

.footer-social a {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gray-700);
    transition: color var(--transition-fast);
}

.footer-social a:hover {
    color: var(--black);
}

/* ==========================================
   Auth Pages
   ========================================== */
.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-6);
    background: var(--gray-100);
}

.auth-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: var(--spacing-10);
    width: 100%;
    max-width: 480px;
}

.auth-logo {
    text-align: center;
    margin-bottom: var(--spacing-8);
}

.auth-title {
    font-size: var(--font-size-2xl);
    text-align: center;
    margin-bottom: var(--spacing-2);
}

.auth-subtitle {
    text-align: center;
    color: var(--gray-600);
    margin-bottom: var(--spacing-8);
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    margin: var(--spacing-6) 0;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--gray-300);
}

.auth-divider span {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

.auth-footer {
    text-align: center;
    margin-top: var(--spacing-6);
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.auth-footer a {
    color: var(--primary);
    font-weight: var(--font-weight-semibold);
}

.auth-footer a:hover {
    text-decoration: underline;
}

/* ==========================================
   Dashboard
   ========================================== */
.dashboard-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    min-height: 100vh;
}

.dashboard-sidebar {
    background: var(--white);
    border-right: 1px solid var(--gray-200);
    padding: var(--spacing-6);
}

.dashboard-nav {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.dashboard-nav-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-sm);
    font-weight: var(--font-weight-medium);
    color: var(--gray-700);
    transition: all var(--transition-fast);
}

.dashboard-nav-item:hover,
.dashboard-nav-item.active {
    background: var(--gray-100);
    color: var(--black);
}

.dashboard-nav-item.active {
    font-weight: var(--font-weight-semibold);
}

.dashboard-content {
    padding: var(--spacing-8);
    background: var(--gray-100);
}

.dashboard-header {
    margin-bottom: var(--spacing-8);
}

.dashboard-title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-2);
}

.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-6);
}

.stat-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow-sm);
}

.stat-label {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--spacing-2);
}

.stat-value {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--black);
}

.stat-change {
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-1);
}

.stat-change.positive {
    color: var(--success);
}

.stat-change.negative {
    color: var(--warning);
}

/* ==========================================
   Price Comparison
   ========================================== */
.price-comparison {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow-card);
}

.price-comparison-header {
    margin-bottom: var(--spacing-6);
}

.price-comparison-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-4);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-3);
    transition: all var(--transition-fast);
}

.price-comparison-item:hover {
    border-color: var(--primary);
    background: rgba(255, 56, 92, 0.02);
}

.price-comparison-item.best {
    border-color: var(--success);
    background: rgba(0, 138, 5, 0.02);
}

.price-source {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.price-source-logo {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    object-fit: contain;
}

.price-source-name {
    font-weight: var(--font-weight-semibold);
}

.price-amount {
    text-align: right;
}

.price-total {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--black);
}

.price-nightly {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.price-badge {
    padding: var(--spacing-1) var(--spacing-2);
    background: var(--success);
    color: var(--white);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    border-radius: var(--radius-sm);
    margin-left: var(--spacing-2);
}

/* ==========================================
   Responsive Design
   ========================================== */
@media (max-width: 1024px) {
    .hero-split {
        grid-template-columns: 1fr;
        gap: var(--spacing-8);
    }
    
    .hero-content {
        max-width: 100%;
        text-align: center;
    }
    
    .hero-image {
        height: 400px;
    }
    
    .search-box {
        flex-direction: column;
        border-radius: var(--radius-xl);
        padding: var(--spacing-4);
    }
    
    .search-box-field::after {
        display: none;
    }
    
    .search-box-field {
        border-radius: var(--radius-md);
    }
    
    .search-box-btn {
        position: relative;
        right: auto;
        top: auto;
        transform: none;
        width: 100%;
        margin-top: var(--spacing-4);
    }
    
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .destination-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .dashboard-layout {
        grid-template-columns: 1fr;
    }
    
    .dashboard-sidebar {
        display: none;
    }
}

@media (max-width: 768px) {
    :root {
        --header-height: 64px;
    }
    
    .hero {
        min-height: auto;
        padding-top: calc(var(--header-height) + var(--spacing-8));
        padding-bottom: var(--spacing-10);
    }
    
    .hero-title {
        font-size: var(--font-size-3xl);
    }
    
    .hero-subtitle {
        font-size: var(--font-size-base);
    }
    
    .hero-image {
        height: 300px;
    }
    
    .section {
        padding: var(--spacing-10) 0;
    }
    
    .section-title {
        font-size: var(--font-size-xl);
    }
    
    .property-grid {
        grid-template-columns: 1fr;
    }
    
    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }
    
    .footer-bottom {
        flex-direction: column;
        gap: var(--spacing-4);
        text-align: center;
    }
    
    .nav {
        display: none;
    }
    
    .destination-grid {
        grid-template-columns: 1fr;
    }
    
    .auth-card {
        padding: var(--spacing-6);
    }
    
    .stat-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================
   Animations
   ========================================== */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { 
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

.animate-fade-in {
    animation: fadeIn 0.5s ease;
}

.animate-slide-up {
    animation: slideUp 0.5s ease;
}

/* ==========================================
   Loading States
   ========================================== */
.skeleton {
    background: linear-gradient(90deg, var(--gray-200) 25%, var(--gray-100) 50%, var(--gray-200) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
    border-radius: var(--radius-sm);
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.skeleton-text {
    height: 16px;
    margin-bottom: var(--spacing-2);
}

.skeleton-title {
    height: 24px;
    width: 60%;
    margin-bottom: var(--spacing-3);
}

.skeleton-image {
    aspect-ratio: 4/3;
}

/* ==========================================
   Utilities
   ========================================== */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.hidden { display: none !important; }
.block { display: block; }
.inline-block { display: inline-block; }

.overflow-hidden { overflow: hidden; }
.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rounded { border-radius: var(--radius-sm); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-full { border-radius: var(--radius-full); }

.shadow { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }

.w-full { width: 100%; }
.h-full { height: 100%; }

.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }

.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }

.z-10 { z-index: 10; }
.z-20 { z-index: 20; }
.z-50 { z-index: 50; }
