@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700;800&display=swap');

:root{
  --bg: #f6f7f8;
  --surface: #ffffff;
  --brand: #007e33;
  --brand-100: #eaf6ef;
  --brand-600: #00692b;
  --muted: #6c757d;
  --accent: #ffb400;
  --card-shadow: 0 8px 30px rgba(10,20,30,0.06);
  --radius: 10px;
  --section-vertical: 56px; /* standard section vertical padding */
  --section-vertical-lg: 88px; /* larger sections like hero */
  --hero-min-height: 220px; /* compact hero min height */
  --hero-content-padding: 20px;
  --color-band-thickness: 8px;
  --card-gap: 20px;
  --img-ratio: 16/9;
  --homepage-img-ratio: 4/3;
  --listview-img-width: 160px;
  /* Animation speed variables (easy tuning) */
  --marquee-duration: 28s; /* desktop announcement ticker (was 18s) */
  --marquee-duration-tablet: 20s; /* tablet announcement duration */
  --promo-duration: 60s; /* promo scroller (was 30s) */
  --promo-duration-mobile: var(--promo-duration); /* unified: use desktop duration everywhere */
  --marquee-duration-mobile: 20s; /* mobile announcement duration */
}

/* Strong overrides for small mobile viewports to ensure previous rules take effect even when cached or overridden elsewhere */
@media (max-width:480px) {
  /* hide debug banner */
  #dev-debug-banner { display: none !important; }

  /* announcement should be a normal block above header */
  .announcement-bar { position: static !important; width: 100% !important; margin: 0 !important; padding: 6px 12px !important; box-shadow: none !important; }
  .announcement-inner { justify-content: flex-start !important; }

  /* header simplified: logo left, controls right on same line (centered vertically with logo) */
  .header-container, .header-grid { display: flex !important; grid-template-columns: none !important; align-items: center !important; justify-content: space-between !important; padding: 8px !important; gap: 8px !important; }
  .header-left, .header-right { display:flex !important; align-items:center !important; gap:8px !important; }
  .header-right { position: static !important; right: auto !important; top: auto !important; transform: none !important; align-items: center !important; }

  /* Prefer compact brand (icon) only */
  .brand-full, .logo h1 { display: none !important; visibility: hidden !important; height: 0 !important; margin: 0 !important; padding: 0 !important; }
  .brand-short { display: inline-block !important; visibility: visible !important; }

  /* show lang picker and hamburger inline, vertically centered with logo */
  .header-right .lang-picker, .hamburger, #mobile-hamburger { display: inline-flex !important; align-items: center !important; }

  /* Push hamburger to the far right on mobile */
  #mobile-hamburger { margin-left: auto !important; }

  /* show login button as compact icon; hide secondary icons and register link */
  #favorites-btn, #dossier-btn, .header-right .register-btn { display: none !important; }
  .header-right .login-btn { display: inline-flex !important; align-items: center !important; justify-content: center !important; width: 36px !important; height: 36px !important; padding: 0 !important; background: transparent !important; border: none !important; color: var(--brand) !important; }
  /* publish CTA styling moved to mobile-only media query further below */

  /* reduce hero/search top padding so content sits naturally below header */
  main, .search-row, .promo-scroller { padding-top: 8px !important; }

  /* prevent horizontal overflow */
  html, body { overflow-x: hidden !important; }

/* Mobile-only: compact floating publish CTA */
@media (max-width:425px) {
  #publish-btn-mobile {
    position: fixed !important;
    bottom: 14px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 2000 !important;
    padding: 8px 14px !important;
    border-radius: 20px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.12) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: normal !important;
    min-width: 125px !important;
    max-width: calc(100% - 32px) !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    font-size: 0.98rem !important;
  }
}
}

  /* Strong final override: ensure any earlier fixed positioning of the header action cluster
     is removed on small screens. Uses a selector with the same specificity as problematic
     rules and appears after them so it wins. */
  @media (max-width:425px) {
    .header-container .header-right,
    header.header-main .header-right {
      position: static !important;
      right: auto !important;
      top: auto !important;
      transform: none !important;
      z-index: auto !important;
    }
  }



  /* Override: force header action cluster to remain non-fixed on very small screens
     This ensures language/menu icons stay in the header under the announcement bar. */
  @media (max-width:425px) {
    .header-container .header-right {
      position: static !important;
      right: auto !important;
      top: auto !important;
      z-index: auto !important;
    }
    /* ensure content isn't bumped by any earlier fixed padding rules */
    main, .search-row, .promo-scroller { padding-top: 8px !important; }
  }

/* Position language picker next to auth buttons on desktop */
@media (min-width:900px) {
  /* ensure header-right remains a flex container */
  .header-right { display:flex; align-items:center; gap:10px; }
  /* prefer auth buttons to appear before the language picker */
  .login-btn { order: 1; }
  .register-btn { order: 2; }
  .lang-picker { order: 3; margin-left:8px; display:inline-flex; }
}

/* Make header action buttons visible on very small phones (<=320px)
   Overrides any pruning performed by `mobile-prune.js` (fd-pruned class) */
@media (max-width:320px) {
  #favorites-btn, #dossier-btn, .header-right .register-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
  }
  /* If mobile-prune.js added .fd-pruned, override it here */
  #favorites-btn.fd-pruned, #dossier-btn.fd-pruned, .header-right .register-btn.fd-pruned {
    display: inline-flex !important;
  }
}

/* Compact adjustments for small mobile widths (apply from 320px and below up to small mobile range)
   These rules reduce padding/font sizes and hide secondary label text to avoid overflow when all
   header action buttons are visible. */
@media (max-width:420px) {
  /* Brand: prefer compact short brand on small screens */
  .brand-short { display: inline-block !important; visibility: visible !important; }
  .brand-full, .logo h1 { display: none !important; visibility: hidden !important; height: 0 !important; margin: 0 !important; padding: 0 !important; }

  /* Header spacing and sizing */
  .header-container { padding: 8px !important; }
  .header-right { gap: 6px; align-items:center; }
  .logo-img img { width:36px; height:36px; object-fit:contain; }

  /* Keep all action buttons visible but compact to avoid overflow */
  #favorites-btn, #dossier-btn, .header-right .register-btn { display: inline-flex !important; align-items:center !important; }
  .icon-btn { padding: 6px !important; border-radius:6px !important; }
  .icon-btn .badge { padding: 2px 4px !important; font-size:0.72rem !important; margin-left:4px !important; }
  .header-right .register-btn { padding:6px 8px !important; font-size:0.88rem !important; border-radius:6px !important; }

  /* Hide long dossier text, keep icon + badge */
  #dossier-btn > span:not(.badge) { display: none !important; }
  /* Hide language code text to save space (flag remains) */
  .lang-current .lang-code { display: none !important; }

  /* Hamburger alignment */
  #mobile-hamburger { margin-left: auto !important; order: 3 !important; }

  /* compact login button */
  .header-right .login-btn { width:34px !important; height:34px !important; }

  /* search box slightly smaller */
  .search-box { padding:8px !important; gap:8px !important; }
  .search-box input#site-search{padding:10px 12px; font-size:0.98rem}

  /* publish CTA adjustments */
  #publish-btn-mobile { min-width: 120px !important; font-size: 0.95rem !important; }
}

/* Replace circular search icon with rounded-rectangle centered under input on small mobile */
@media (max-width:420px) {
  .search-box { flex-direction: column; align-items: stretch; padding:8px 10px !important; }
  .search-box .search-input-wrap { width: 100%; }
  .search-box input#site-search { width: 100%; padding:12px 14px; font-size:1rem; }
  .search-circle-btn {
    /* rectangular rounded style */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    padding: 8px 14px !important;
    border-radius: 12px !important;
    height: auto !important;
    margin: 10px auto 0 auto !important;
    box-shadow: 0 8px 22px rgba(34,136,58,0.18) !important;
    font-size: 0.98rem !important;
  }
  .search-circle-btn i { font-size: 16px !important; }
  .search-circle-btn { background: linear-gradient(180deg,#2ea044,#21893a) !important; color:#fff !important; border: none !important; }
  .search-circle-btn .search-btn-text { display: inline-block !important; margin-left: 8px !important; font-weight:700 !important; color:#fff !important; }
  /* ensure icon and text are centered together */
  .search-circle-btn { gap:8px; }
}

@media (max-width:320px) {
  .search-box { padding:6px 8px !important; }
  .search-circle-btn { padding: 7px 12px !important; font-size: 0.92rem !important; border-radius: 10px !important; }
}

/* hide search button text by default (desktop) */
.search-btn-text{display:none}

/* Stronger compaction for the smallest phones (<=320px) */
@media (max-width:320px) {
  .header-right { gap: 4px; }
  .icon-btn { padding: 4px !important; }
  .icon-btn .badge { padding: 1px 4px !important; font-size:0.68rem !important; }
  .header-right .register-btn { padding:6px 6px !important; font-size:0.82rem !important; }
  .header-right .login-btn { width:32px !important; height:32px !important; }
  #publish-btn-mobile { min-width: 110px !important; font-size: 0.92rem !important; padding:10px 14px !important; }
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background:var(--bg);
  color:#1f2933;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.5;
}

.container{max-width:1200px;margin:0 auto;padding:0 18px;width:100%}

/* Trust strip */
.trust-strip{background:linear-gradient(90deg,#f7fffa,#eef7ee);padding:8px 0;border-bottom:1px solid rgba(0,0,0,0.04);color:var(--muted);font-weight:600}
.trust-item{font-size:0.95rem}

/* Announcement bar (Zone 1) */
.announcement-bar{background:linear-gradient(90deg,#fff8e6,#fff);border-bottom:1px solid rgba(0,0,0,0.04);padding:8px 0}
.announcement-inner{display:flex;align-items:center;justify-content:center}
.announcement-inner span{font-weight:700;color:#0b6620}

/* Global marquee for announcement (respect user motion preferences) */
@media (prefers-reduced-motion: no-preference) {
  .announcement-inner{overflow:hidden}
  /* By default (desktop) keep the announcement text fixed */
  .announcement-inner span{display:inline-block;white-space:nowrap;padding-left:4%;animation:none}
  @keyframes fd-marquee{0%{transform:translateX(100%)}100%{transform:translateX(-100%)}}
}
@media (prefers-reduced-motion: reduce){
  .announcement-inner span{animation:none}
}

/* Header layout adjustments */
.header-grid{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px}
.header-left{display:flex;align-items:center;gap:12px}
.header-center{display:flex;align-items:center;justify-content:center}
.header-right{display:flex;align-items:center;gap:10px;justify-self:end}
.header-search{display:flex;gap:12px;align-items:center;width:100%;background:#fff;border-radius:28px;padding:12px 16px;box-shadow:0 12px 30px rgba(10,20,30,0.06)}
.header-search .search-input-wrap{flex:1;position:relative}
.icon-btn{background:transparent;border:0;padding:8px 10px;border-radius:8px;cursor:pointer;position:relative}
.icon-btn .badge{background:var(--accent);color:#111;border-radius:999px;padding:2px 6px;font-weight:700;margin-left:6px}
.lang-select{padding:6px;border-radius:6px}

/* Custom language picker styles */
.lang-picker{position:relative;display:inline-block}
.lang-current{display:inline-flex;align-items:center;gap:8px;background:transparent;border:0;padding:6px 8px;border-radius:6px;cursor:pointer;color:var(--muted);font-weight:700}
.lang-current .lang-flag{width:20px;height:14px;display:inline-block;object-fit:cover}
.lang-current .lang-code{letter-spacing:0.06em}
.lang-list{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border-radius:8px;box-shadow:var(--card-shadow);list-style:none;margin:0;padding:6px 0;min-width:120px;display:none;z-index:1500}
.lang-list[aria-hidden="false"],.lang-list.show{display:block}
.lang-list li{padding:8px 12px;cursor:pointer;display:flex;gap:8px;align-items:center}
.lang-list li:hover{background:rgba(0,0,0,0.03)}
.lang-list .lang-flag{width:18px;height:12px;display:inline-block;object-fit:cover}

/* Subnav pills (Zone 3) */
.subnav{background:transparent;padding:12px 0;border-bottom:1px solid rgba(0,0,0,0.04)}
.subnav-inner{display:flex;align-items:center;gap:18px}
.subnav-pills{display:flex;gap:12px;justify-content:center;flex:1}
.subnav-pills .pill{background:#fff;border-radius:999px;padding:10px 18px;text-decoration:none;color:var(--muted);font-weight:800;box-shadow:var(--card-shadow)}
.subnav-pills .pill .pill-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:8px}
.subnav-pills .pill .pill-icon svg{width:16px;height:16px}
.subnav-pills .pill#services-pill{display:inline-flex;align-items:center;gap:8px}
.subnav .catalogue{flex:0 0 auto}
.subnav-actions{flex:0 0 auto}

/* Left spacer to visually balance the subnav and help center the pills */
.left-spacer{width:160px;min-width:120px;flex:0 0 auto;display:flex;align-items:center}
@media (min-width:1400px){.left-spacer{width:220px;min-width:160px}}
@media (max-width:900px){.left-spacer{width:120px;min-width:80px}}
/* New search row styles */
.search-row{background:transparent;padding:18px 0;border-bottom:1px solid rgba(0,0,0,0.03)}
.search-row-inner{align-items:center}
.header-search.wide{display:flex;align-items:center;gap:12px;background:#fff;border-radius:999px;padding:14px 18px;box-shadow:0 18px 36px rgba(6,12,10,0.06);height:56px}
.header-search.wide input{height:32px;border:0;font-size:1rem;padding:8px 12px;border-radius:8px}
.catalogue-left{flex:0 0 auto;border:0;background:transparent;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:700;display:flex;align-items:center;gap:8px}
  .catalogue-left .btn-secondary{border-radius:8px}
.search-row .btn-primary{height:40px}

/* Big rounded search appearance matching example attachment */
.search-container{max-width:980px;margin:0 auto}
.search-box{display:flex;align-items:center;gap:12px;background:#fff;border-radius:999px;padding:10px 12px;box-shadow:0 12px 30px rgba(10,20,30,0.06)}
.search-box .search-input-wrap{flex:1;position:relative}
.search-box input#site-search{width:100%;border:0;outline:none;padding:16px 20px;border-radius:999px;font-size:1.05rem;color:#222}

@media (min-width:1366px){
  :root{ --hero-min-height: 320px; }
  .promo-scroller{height:160px}
}
.search-box input#site-search::placeholder{color:#9aa1a6}
.search-circle-btn{background:linear-gradient(180deg,#2ea044,#21893a);border:0;color:#fff;width:48px;height:48px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;box-shadow:0 8px 22px rgba(34,136,58,0.18)}
.search-circle-btn i{pointer-events:none}
.search-box .autocomplete-list{left:12px;right:70px;top:calc(100% + 8px)}

@media (max-width:768px){
  .search-row{padding:12px 0}
  .search-container{max-width:100%}
  .search-box{padding:8px;gap:8px}
  .search-circle-btn{width:44px;height:44px}
  .search-box input#site-search{padding:12px 14px;font-size:1rem}
}

/* ensure promo-carousel visual not visible after removal */
.promo-carousel{display:none}

/* Showcase grids (Zone 5) */
.category-showcase{padding:18px 0}
.category-row{margin-top:12px}
.category-row h3{display:flex;justify-content:space-between;align-items:center;gap:12px}
.showcase-grid{grid-template-columns:repeat(3,1fr);gap:14px}
.showcase-grid .property-card{min-height:140px;border-radius:10px;padding:8px;display:flex;flex-direction:column;justify-content:space-between;background:transparent;box-shadow:0 6px 18px rgba(6,12,10,0.04)}
.showcase-grid .property-img{height:110px;overflow:hidden;border-radius:8px}
.showcase-grid .property-img img{width:100%;height:100%;object-fit:cover;display:block}
.showcase-grid .property-content{padding:8px}
.showcase-grid .property-price{color:var(--brand);font-weight:800;margin-bottom:6px;font-size:1.05rem}
.showcase-grid .property-address{color:var(--muted);font-size:0.9rem;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.property-badge{background:#ffb400;color:#111;padding:6px 10px;border-radius:6px;font-weight:700;font-size:0.9rem}
.see-more{font-weight:700;color:var(--brand);text-decoration:none}

/* Partners (Zone 6) tweaks */
.partners{padding:10px 0}
.partners-carousel{overflow-x:auto}
.partners-carousel::-webkit-scrollbar{height:8px}
.partners-carousel::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.06);border-radius:8px}
.partner-item{flex:0 0 auto;background:transparent;border-radius:6px;padding:6px;box-shadow:none;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.partner-item img{height:200px;width:auto;object-fit:cover;border-radius:8px;display:block}

@media (max-width:1000px){
  .partner-item img{height:160px}
}
@media (max-width:900px){
  .promo-scroller .promo-track img{height:90px}
  .promo-scroller{padding:12px 0}
  .promo-scroller .promo-track{animation-duration:var(--promo-duration)}
}
.promo-scroller{overflow:hidden;background:transparent;padding:12px 0;box-sizing:border-box;display:flex;align-items:center;height:220px}
.promo-scroller .promo-track{display:flex;gap:12px;align-items:center;white-space:nowrap;will-change:transform}
.promo-scroller .promo-track img{height:200px;width:auto;border-radius:8px;flex:0 0 auto;object-fit:cover;display:block;line-height:0}
.promo-scroller .promo-track{animation:scroll-left 30s linear infinite;will-change:transform}

@keyframes scroll-left{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* Hide categories button when requested by design */
#categories-btn, .catalogue-left { display: none !important; }

/* Hide mobile publish CTA by default; shown only via mobile media-query overrides */
#publish-btn-mobile { display: none !important; }

/* Utility to shift elements to the right (apply to selectors marked in the screenshot) */
.shift-right { margin-left: 20px !important; transform: none !important; }

/* Small helper: hide elements (used by mobile-prune.js). Keeps nodes in DOM but hides visually */
.fd-pruned { display: none !important; }

/* Nudge header-right group to the right on desktop to match visual request */
@media (min-width:900px){
  /* Keep a small desktop offset so header alignment remains unchanged */
  .header-right { transform: translateX(22px); }
}

@media (max-width:900px){
  .promo-scroller .promo-track img{height:90px}
  .promo-scroller{padding:12px 0}
  .promo-scroller .promo-track{animation-duration:40s}
}

/* Trust strip moved near footer visually but kept as separate block */
.trust-strip{margin-top:12px}

/* Header */
.header{background:var(--surface);position:sticky;top:0;z-index:1200;box-shadow:0 6px 20px rgba(12,20,30,0.06)}
.header-container{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.header-main{padding:18px 0}
.logo{display:flex;align-items:center;gap:12px}
.logo-img img{width:44px;height:44px;object-fit:contain}
.logo h1{
  font-size:18px;
  color:var(--brand);
  margin:0;
  font-weight:800;
  /* On wide screens show the full title (no truncation) so it matches the reference image */
  /* allow the site title to wrap and always be fully visible */
  white-space:normal;
  overflow:visible;
  text-overflow:unset;
  max-width:none; /* remove artificial cap so the full text can be shown (wraps if needed) */
}

/* Default brand span visibility: show full brand, hide short label (desktop/default) */
.brand-short{display:none}
.brand-full{display:inline}

/* Brand link used in some pages (inline anchor), make it match the .logo h1 style */
.logo .brand, a.brand {
  font-size:18px;
  color:var(--brand);
  font-weight:800;
  text-decoration:none;
  display:inline-block;
  margin-left:8px;
}

/* Improve service panel hero appearance: remove heavy full-width gradient and use a subtle left brand band */
.panel-hero{
  /* override any inline background gradient used in some pages */
  background:transparent !important;
  padding:10px 14px !important;
  border-left:6px solid var(--brand) !important;
  color:var(--brand-600) !important;
  border-radius:6px !important;
  margin-bottom:12px !important;
  font-weight:800 !important;
  box-shadow:none !important;
}
.panel-hero h4{margin:0;font-size:1rem;color:inherit}

/* Slightly soften the active nav item and ensure spacing matches the design */
.left-nav .nav-list a{padding:12px 16px}
.left-nav .nav-list a.active{background:#f6fff8;border-left-color:var(--brand);color:var(--brand)}

/* Ensure right column headings are readable */
.service-panel h3{margin-top:12px;color:#0b2a3a}

nav ul{display:flex;gap:20px;list-style:none;margin:0;padding:0}
nav a{color:inherit;text-decoration:none;font-weight:600;padding:6px 8px;border-radius:8px;transition:background .15s,color .15s}
nav a:hover{background:rgba(0,0,0,0.03)}

.auth-buttons{display:flex;align-items:center;gap:10px}
.auth-buttons button{border:1px solid transparent;padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:700}
.login-btn{background:transparent;color:var(--brand);border-color:rgba(0,126,51,0.12);padding:8px 12px;border-radius:8px}
.register-btn{background:var(--brand);color:#fff;box-shadow:0 8px 24px rgba(0,126,51,0.12);padding:8px 12px;border-radius:8px;text-decoration:none;font-weight:800;display:inline-block}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:6px;width:36px;height:26px;border:none;background:transparent;cursor:pointer;padding:0}
.hamburger span{display:block;height:3px;background:var(--brand);border-radius:3px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Mobile menu */
.mobile-menu{position:fixed;right:-100%;top:0;height:100vh;width:82%;max-width:420px;background:var(--surface);box-shadow:-12px 0 30px rgba(5,10,15,0.08);z-index:1300;padding:80px 22px 22px;transition:right .28s ease}
.mobile-menu.active{right:0}
.mobile-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.mobile-nav a{font-weight:700;color:inherit;text-decoration:none;padding:10px 6px;border-radius:8px}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);opacity:0;visibility:hidden;transition:all .2s;z-index:1200}
.overlay.active{opacity:1;visibility:visible}

/* Hero */
.hero{padding:calc(var(--section-vertical) + 8px) 0;background:linear-gradient(180deg, rgba(0,126,51,0.92) 0%, rgba(0,126,51,0.85) 100%);color:#fff;text-align:center}
.hero .container{display:flex;flex-direction:column;align-items:center;gap:8px}
.hero h2{font-size:1.5rem;margin:0;font-weight:800;letter-spacing:-0.02em;line-height:1.05}
.hero p{max-width:720px;margin:0 auto;color:rgba(255,255,255,0.92);font-size:0.92rem}

/* Hero carousel */
.hero-outer{position:relative;margin-bottom:22px}
.hero-carousel{position:relative;overflow:hidden;border-radius:12px}
.hero-slide{min-height:var(--hero-min-height);background-size:cover;background-position:center;display:flex;align-items:center;position:relative}
/* green overlay to restore site identity while preserving the background image */
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,126,51,0.86),rgba(0,126,51,0.6));mix-blend-mode:multiply;pointer-events:none;z-index:1}
.hero-slide .hero-content{padding:var(--hero-content-padding) 14px;color:#fff;background:linear-gradient(90deg,rgba(0,0,0,0.08),transparent);max-width:680px;position:relative;z-index:2}
.carousel-prev,.carousel-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.92);border:none;padding:8px 10px;border-radius:8px;cursor:pointer;font-weight:700}
.carousel-prev{left:12px}
.carousel-next{right:12px}

/* Search overlay (over hero) */
.search-overlay{margin-top:-56px;position:relative;z-index:60}
.search-box{background:rgba(255,255,255,0.98)}
.search-box{display:flex;gap:10px;background:#fff;border-radius:12px;padding:10px 8px;box-shadow:var(--card-shadow);align-items:center}
.search-category{border:0;padding:10px 12px;border-radius:8px;background:#f6f7f8}
.search-input-wrap{position:relative;flex:1}
.autocomplete-list{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 8px 20px rgba(10,20,30,0.06);max-height:200px;overflow:auto;display:none;z-index:90}
.autocomplete-list li{padding:10px 12px;list-style:none;cursor:pointer}
.autocomplete-list li:hover{background:#f0f5f0}

/* Cookie consent banner */
.cookie-banner{position:fixed;left:12px;right:12px;bottom:18px;background:#fff;border-radius:10px;box-shadow:0 18px 40px rgba(10,20,30,0.12);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:9999}
.cookie-banner p{margin:0;color:#111}
.cookie-banner .cookie-actions{display:flex;gap:8px}
.cookie-accept{background:var(--brand);color:#fff;padding:8px 12px;border-radius:8px;border:0;cursor:pointer}
.cookie-decline{background:transparent;border:1px solid #ddd;padding:8px 12px;border-radius:8px;cursor:pointer}

.search-container{margin-top:14px;width:100%;max-width:820px}
.search-box{display:flex;gap:10px;background:#fff;border-radius:12px;padding:10px 8px;box-shadow:var(--card-shadow);align-items:center}
.search-box input{padding:12px 14px}
.search-box input{flex:1;border:0;padding:12px 16px;border-radius:8px;font-size:0.98rem;outline:none}
.search-btn{background:var(--brand);color:#fff;border:0;padding:12px 18px;border-radius:10px;font-weight:800;cursor:pointer}
.filter-toggle{background:transparent;border:1px solid rgba(255,255,255,0.18);color:#fff;padding:8px 12px;border-radius:8px}

.active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.filter-badge{background:rgba(255,255,255,0.12);padding:6px 12px;border-radius:999px;color:#fff;font-weight:600}

/* Sections */
.section-title{text-align:center;margin-bottom:18px}
.section-title h2{color:var(--brand);font-size:1.45rem;margin:0 0 8px}
.section-title p{color:var(--muted);margin:0}

/* Distinct styling for homepage featured to make them more prominent */
#homepage-featured { margin-top: 8px; }
#homepage-featured .property-card{min-height:220px;border-radius:10px;display:flex;flex-direction:column}
#homepage-featured .property-img{aspect-ratio: var(--homepage-img-ratio);overflow:hidden}
#homepage-featured .property-img img{border-radius:8px}
#homepage-featured .property-content{padding:12px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
#homepage-featured .property-price{font-size:1.25rem}
#homepage-featured .property-address{font-size:0.95rem}
#homepage-featured .property-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(10,20,30,0.12)}


.feature-card{background:var(--surface);padding:18px;border-radius:12px;box-shadow:var(--card-shadow);text-align:center}
.feature-icon{width:56px;height:56px;border-radius:999px;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 10px}

/* Properties grid */
.properties{padding:calc(var(--section-vertical) - 6px) 0;background:transparent}
.properties-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--card-gap)}
.property-card{background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow);transition:transform .18s}
.property-card:hover{transform:translateY(-6px)}
.property-img{background:linear-gradient(180deg,#e9efe9,#f0f5f0);display:block;align-items:flex-end;padding:0;overflow:hidden;border-radius:8px;aspect-ratio: var(--img-ratio)}
.property-img img{width:100%;height:100%;object-fit:cover;display:block}
.property-badge{background:var(--accent);color:#111;padding:6px 10px;border-radius:8px;font-weight:700}
.property-content{padding:14px}
.property-price{color:var(--brand);font-weight:800;font-size:1.15rem;margin-bottom:6px}
.property-address{color:var(--muted);margin-bottom:8px}
.property-features{display:flex;gap:10px;color:var(--muted);font-weight:600;border-top:1px solid #f0f0f0;padding-top:10px;margin-top:10px}

/* Marketplace refinements (inspired by compact marketplaces like eBay, adapted) */
.listing-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.listing-breadcrumb{font-size:0.95rem;color:var(--muted)}
.sort-bar{display:flex;gap:10px;align-items:center}
.view-toggle{display:flex;gap:8px}
.view-toggle .btn-secondary{padding:8px 10px;border-radius:8px}
.view-toggle .btn-secondary.active{background:#f0f5f0;border:1px solid rgba(0,0,0,0.06)}

/* List view layout (compact) */
.property-card.list-view{display:flex;gap:16px;align-items:stretch;padding:12px}
.property-card.list-view .property-img{flex:0 0 var(--listview-img-width);aspect-ratio:4/3;border-radius:8px;align-items:center;justify-content:center;overflow:hidden}
.property-card.list-view .property-img img{width:100%;height:100%;object-fit:cover}
.property-card.list-view .property-content{padding:6px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.property-card .seller-info{font-size:0.9rem;color:var(--muted);margin-top:6px}
.property-card .price-block{min-width:180px;text-align:right;display:flex;flex-direction:column;justify-content:center;gap:6px}
.property-card .price-block .property-price{font-size:1.4rem}
.property-card .price-block .btn-contact-listing{width:100%}

/* Breadcrumb and compact pagination */
.breadcrumb{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:0.95rem;margin-bottom:8px}
.breadcrumb a{color:var(--muted);text-decoration:none}
.pagination{display:flex;gap:8px;align-items:center}

@media (max-width:768px){
  .property-card.list-view{flex-direction:column}
  .property-card.list-view .property-img{width:100%;height:160px}
  .property-card .price-block{text-align:left;min-width:unset}
}

/* Tablet-specific tweaks (~768px) */
@media (min-width:520px) and (max-width:900px){
  /* Announcement bar: single-line and marquee-like scroll if too long */
  .announcement-inner{overflow:hidden}
  .announcement-inner span{display:inline-block;white-space:nowrap;padding-left:100%;animation:fd-marquee var(--marquee-duration-tablet) linear infinite}
  @keyframes fd-marquee{0%{transform:translateX(0%)}100%{transform:translateX(-100%)}}

  /* Hide login/register buttons in header (they remain in mobile menu) */
  .header-right .login-btn, .header-right .register-btn{display:none !important}

  /* Keep header controls aligned to the right on tablet (no manual translation) */
  .header-right { transform: none; justify-self: end; margin-left: auto; justify-content:flex-end; }

  /* Keep search input and icon on same line for tablet widths */
  .search-box{flex-direction:row;align-items:center}
  .search-box .search-input-wrap{flex:1}
  .search-circle-btn{margin-left:8px;flex:0 0 auto}

  /* Tablet: ensure the site title (company name) is readable — allow wrapping and smaller font */
  .logo h1{
    /* Force single-line display on tablet: reduce size and prevent wrapping */
    font-size:13px;
    white-space:nowrap; /* keep on one line */
    overflow:visible;
    text-overflow:unset;
    max-width:none;
    line-height:1.05;
  }

  /* Reduce logo image and spacing on tablet to free horizontal space */
  .logo{gap:6px}
  .logo-img img{width:36px;height:36px}

  /* Show the publish button placed in search row, hide the one in subnav */
  #publish-btn-mobile{display:inline-block !important}
  .subnav .subnav-actions{display:none}

  /* On tablet show only the short brand text next to the logo */
  .brand-short{display:inline !important}
  .brand-full{display:none !important}
}

/* Ensure header uses a stable flex layout on tablet and push controls to the far right */
@media (min-width:520px) and (max-width:900px){
  .header-container{display:flex !important;justify-content:space-between !important;align-items:center !important;position:relative !important}
  .header-left{flex:0 0 auto}
  /* Move the logo block slightly to the right on tablet to match requested alignment */
  .header-left{margin-left:30px !important}
  .header-center{flex:1 1 auto}
  /* Option B: pin controls to the far right of the header container */
  .header-right{
    flex:0 0 auto;
    margin-left:0 !important;
    position:absolute !important;
    right:18px !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    justify-content:flex-end !important;
    z-index:1300 !important;
  }

  /* Place the round search button inside the search box on the right */
  .search-box{position:relative}
  .search-circle-btn{position:absolute !important;right:18px !important;top:50% !important;transform:translateY(-50%) !important;margin-left:0 !important;flex:0 0 auto}
  /* Make room for the button so the input text doesn't go underneath */
  .search-box .search-input-wrap input#site-search{padding-right:88px}

  /* Lift promo scroller to align horizontally with the search row and enlarge promo images for tablet */
  .promo-scroller{
    margin-top:28px !important; /* add vertical gap below search row */
    height:160px !important;
    z-index:1;
  }
  .promo-scroller .promo-track img{
    height:140px !important;
    width:auto !important;
  }
}

/* Mobile: enable announcement marquee on very small screens using the mobile duration */
@media (max-width:519px) and (prefers-reduced-motion: no-preference) {
  .announcement-inner{overflow:hidden}
  .announcement-inner span{display:inline-block;white-space:nowrap;padding-left:100%;animation:fd-marquee var(--marquee-duration-mobile) linear infinite}
}

/* Blog / Guide */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.blog-card{background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow)}
.blog-img{height:140px;background:#e9ecef}
.blog-content{padding:16px}
.blog-date{color:var(--muted);font-size:0.9rem}
.read-more{color:var(--brand);text-decoration:none;font-weight:700}

/* Footer */
/* footer: use a softer dark green that matches brand instead of pure black */
footer{background:linear-gradient(180deg,#053d20,#072f19);color:#eaf6ef;padding:48px 0;margin-top:30px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:22px}
.footer-column h3{color:var(--accent);margin:0 0 10px}
.footer-column ul{padding:0;margin:0;list-style:none}
.footer-column li{margin-bottom:8px}
.footer-column a{color:inherit;text-decoration:none}
.social-links{display:flex;gap:10px}
.social-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,0.04);color:#fff}
.copyright{color:rgba(255,255,255,0.6);text-align:center;padding-top:18px;border-top:1px solid rgba(255,255,255,0.04);margin-top:18px}

/* Modal */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(2,6,23,0.65);z-index:1600;align-items:center;justify-content:center;padding:24px}
.modal-backdrop.active{display:flex}
.modal{background:var(--surface);border-radius:18px;max-width:720px;width:100%;padding:20px;box-shadow:0 20px 50px rgba(10,20,30,0.12)}
.modal .close{position:absolute;right:18px;top:12px;border:none;background:transparent;font-size:22px;cursor:pointer}

/* Utilities */
.btn-primary{background:var(--brand);color:#fff;padding:10px 16px;border-radius:10px;border:0;cursor:pointer;font-weight:700}

.btn-block{display:block;width:100%}

/* Large black CTA inside modal like example */
.modal.modal-auth .large-cta{background:#111;color:#fff;border-radius:28px;padding:14px 18px;font-size:1.05rem;display:block;text-align:center;border:0;box-shadow:none}
.modal.modal-auth .large-cta:hover{opacity:0.95}
.copy-muted{color:var(--muted)}

/* Footer tweaks */
footer{padding:32px 0}
footer .footer-column h3{font-size:1rem;margin-bottom:8px}
footer .footer-column p, footer .footer-column ul, footer .footer-column li{font-size:0.95rem}
footer .copyright{padding-top:12px}

/* Responsive tweaks */
@media (max-width:992px){
  nav, .auth-buttons{display:none}
  .hamburger{display:flex}
  .header-grid{grid-template-columns:1fr 1fr}
  .header-right{justify-content:flex-end}
  .subnav-pills{display:none}
  .showcase-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .hero{padding:44px 0}
  .hero h2{font-size:1.6rem}
  .search-box{flex-direction:column;align-items:stretch}
  .search-btn{width:100%}
  .property-img{height:140px}
  .header-grid{grid-template-columns:1fr}
  .header-center{order:3;width:100%}
  .header-right{order:2}
}
@media (max-width:480px){
  .logo h1{font-size:16px}
  .hero{padding:42px 0}
}

/* On narrower viewports keep the header compact and truncate the long title to prevent layout break */
@media (max-width:992px){
  .logo h1{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}

/* Override: Tablet-specific — ensure full company title is readable (placed after truncation rules) */
@media (min-width:520px) and (max-width:900px){
  .logo h1{
    max-width:unset !important;
    white-space:normal !important; /* allow wrapping on tablet */
    overflow:visible !important;
    text-overflow:unset !important;
    font-size:16px !important;
    line-height:1.05 !important;
    word-break:break-word !important;
  }
}

/* Megamenu */
.megamenu{display:none;background:var(--surface);box-shadow:0 8px 30px rgba(10,20,30,0.06);border-top:1px solid #f0f0f0}
.megamenu.active{display:block}
.megamenu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:22px 18px}
.mega-column h4{margin:0 0 8px}
.mega-column ul{list-style:none;padding:0;margin:0}
.mega-column li{margin-bottom:8px}

/* Partners carousel */
.partners-carousel{display:flex;gap:16px;align-items:center;overflow:hidden;padding:10px 0}
.partner-item{flex:0 0 180px;background:#fff;border-radius:8px;padding:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--card-shadow)}
.partner-item img{max-width:100%;height:64px;object-fit:contain}

/* Color band (thin animated band above hero) */
.color-band{height:var(--color-band-thickness);width:100%;position:absolute;left:0;top:0;z-index:3}
.color-band.band-green{background:linear-gradient(90deg,#007e33,#009944)}
.color-band.band-red{background:linear-gradient(90deg,#c8102e,#e03b3b)}
.color-band.band-yellow{background:linear-gradient(90deg,#f7d117,#f1c40f)}

@media (max-width:768px){
  :root{--hero-min-height:180px;--hero-content-padding:14px;--color-band-thickness:6px}
  .search-overlay{margin-top:-48px}
  .hero h2{font-size:1.25rem}
}

/* Service portal (compact button + popover) */
.service-portal{position:relative;display:flex;align-items:center;margin-right:12px}
.service-btn{display:inline-flex;align-items:center;gap:8px;border:0;background:transparent;padding:6px 10px;border-radius:999px;cursor:pointer;font-weight:700;color:var(--brand);box-shadow:none}
.service-btn:hover{box-shadow:0 6px 18px rgba(6,12,10,0.04)}
.service-icon-wrap{width:34px;height:34px;border-radius:8px;background:var(--brand);display:inline-flex;align-items:center;justify-content:center;color:#fff;margin-right:8px}
.service-icon{color:inherit;display:inline-block}
.service-label{font-size:0.95rem;color:var(--brand)}

/* Popover */
.service-pop{position:absolute;top:calc(100% + 10px);left:0;background:var(--surface);border-radius:10px;box-shadow:0 18px 40px rgba(10,20,30,0.12);padding:10px 6px;min-width:240px;z-index:1600;border:1px solid rgba(0,0,0,0.04);display:none}
.service-pop[aria-hidden="false"], .service-pop.show{display:block}
.service-pop ul{list-style:none;padding:6px;margin:0;display:flex;flex-direction:column;gap:6px}
.service-pop a{display:block;padding:8px 12px;border-radius:8px;text-decoration:none;color:var(--muted);background:transparent;font-weight:700}
.service-pop a:hover{background:rgba(0,126,51,0.05);color:var(--brand)}
@media (max-width:900px){ .service-portal{margin-right:8px} .service-pop{left:auto;right:0;min-width:200px} }

/* === Added: modal-auth specific styles (only for the login modal zone) === */
.modal.modal-auth{max-width:920px;display:grid;grid-template-columns:1fr 320px;grid-auto-rows:1fr;gap:0;overflow:hidden;position:relative}
.auth-left{padding:22px 26px;background:#fff}
.modal.modal-auth{max-height:84vh}
.modal.modal-auth .auth-left, .modal.modal-auth .auth-right{overflow:auto;min-height:0;-webkit-overflow-scrolling:touch;touch-action:auto}
.auth-brand-img{width:72px;height:auto;display:block;margin:0 0 10px}
.auth-left .btn-social img{margin-right:12px}
.auth-right{background:linear-gradient(180deg,var(--brand),var(--brand-600));color:#fff;display:flex;align-items:center;justify-content:center}
.auth-right-inner{padding:22px;max-width:260px;margin:0 auto;text-align:center}
.brand-mark{width:64px;height:64px;border-radius:16px;background:var(--brand);margin-bottom:12px;box-shadow:0 12px 30px rgba(0,126,51,0.12)}
auth-left h2{margin:6px 0 6px;font-size:1.35rem;color:var(--brand);font-weight:800}
auth-sub{color:var(--muted);margin-bottom:10px}
auth-form input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid #eef3ef;margin-bottom:14px;font-size:0.98rem;background:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6)}
password-wrap{position:relative}
password-wrap .pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;background:transparent;font-size:18px;cursor:pointer}

/* Registration page centered card */
.register-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:28px 18px}
.register-card{max-width:720px;width:100%;background:var(--surface);border-radius:14px;box-shadow:var(--card-shadow);padding:28px;display:flex;flex-direction:column;gap:18px}
.register-brand{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.register-brand .auth-brand-img{width:64px;height:auto}
.register-brand h1{margin:4px 0 0;font-size:1.5rem;color:var(--brand)}
.register-brand .copy-muted{color:var(--muted);margin:0}
.register-form{display:flex;flex-direction:column;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.form-label{font-weight:700;color:var(--muted);font-size:0.95rem}
.form-input{padding:12px 14px;border-radius:10px;border:1px solid #eef3ef;font-size:1rem;outline:none}
.form-input:focus{box-shadow:0 6px 18px rgba(0,126,51,0.08);border-color:rgba(0,126,51,0.12)}
.form-error{color:#c82333;margin-top:8px;min-height:18px}
.register-foot{margin-top:6px;color:var(--muted)}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);border:0;background:transparent;font-size:18px;cursor:pointer}

@media (max-width:720px){
  .register-card{padding:18px;border-radius:12px}
  .register-page{min-height:70vh;padding:18px}
}

/* Social buttons: large rounded outline like the example */
.btn-social{display:inline-flex;align-items:center;gap:10px;justify-content:center;padding:12px 14px;border-radius:28px;border:1px solid rgba(0,0,0,0.08);background:transparent;font-weight:700}
.btn-social img{width:18px;height:18px}
.btn-social.btn-fb{border-color:rgba(24,119,242,0.18);background:#f7fbff}
.btn-social.btn-google{background:#fff;border-color:rgba(0,0,0,0.06)}
.btn-social.btn-apple{background:#111;color:#fff;border-color:rgba(255,255,255,0.06)}

/* OR separator */
.or-sep{display:flex;align-items:center;gap:12px;margin:18px 0 14px}
.or-sep::before, .or-sep::after{content:'';flex:1;height:1px;background:rgba(0,0,0,0.06)}
.or-sep span{padding:8px 12px;border-radius:999px;background:#f4f6f4;color:var(--muted);font-weight:800}

/* Checkbox styling similar to example (larger square) */
.checkbox input[type="checkbox"]{width:18px;height:18px;vertical-align:middle;margin-right:8px}
.checkbox{display:inline-flex;align-items:center;gap:8px;font-weight:700}

/* Smaller tweaks for spacing in modal */
.auth-left .muted.small{font-size:0.85rem}
.auth-left p{margin:8px 0 12px}

/* small row alignments inside modal */
.auth-left .row-between.small{display:flex;align-items:center;justify-content:space-between;gap:8px}
.auth-left .row-between.small .checkbox{font-weight:700}
.auth-left #need-help{color:var(--muted);text-decoration:underline}
.auth-left #need-help:hover{text-decoration:none}
.row-between{display:flex;align-items:center;justify-content:space-between}
.row-between.small{font-size:0.95rem;margin-bottom:10px}
.checkbox{display:inline-flex;align-items:center;gap:8px}
.checkbox input{width:16px;height:16px}
.link.small{color:var(--brand);text-decoration:none}
.btn-block{display:block}
.form-error{color:#b41616;margin-top:8px;font-size:0.95rem}
.socials{display:flex;flex-direction:column;gap:10px}
.btn-social{display:flex;align-items:center;gap:12px;border-radius:12px;padding:12px 14px;border:0;cursor:pointer;font-weight:800}
.btn-social img{width:20px;height:20px}
.btn-social.btn-google{background:#fff;color:#111;border:1px solid rgba(0,0,0,0.08)}
.btn-social.btn-fb{background:#f4f8ff;color:#1f4fa8}
.btn-social.btn-apple{background:#111;color:#fff}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,0.18);padding:8px 12px;border-radius:999px;font-weight:700}
.auth-right h3{margin:0 0 8px;font-size:1.25rem}
.muted{color:rgba(255,255,255,0.92)}
.terms{font-size:0.85rem;margin-top:18px}

@media (max-width:920px){
  .modal.modal-auth{grid-template-columns:1fr;max-width:520px}
  .auth-right{order:2;padding:18px}
  .auth-left{order:1;padding:18px}
}

/* small helpers for the login zone */
.modal-header-actions .btn-outline{font-weight:700}
.recaptcha-placeholder{font-size:0.95rem}
.auth-left .socials .btn-social{font-size:0.98rem}
.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}

/* end added block */

/* Improvements: visible labels, large CTA and mobile tweak */
.form-label{display:block;font-weight:700;margin-bottom:6px;color:var(--muted)}
.large-cta{padding:14px 18px;font-size:1.05rem;border-radius:12px}
.btn-social span{display:inline-block;vertical-align:middle;margin-left:12px}

@media (max-width:520px){
  .modal.modal-auth{max-width:92vw;padding:8px}
  .auth-left{padding:16px}
  .auth-right{display:none}
}

/* Tablet (768–1023px): lift language picker and hamburger into header aligned with logo */
@media (min-width:768px) and (max-width:1023px) {
  /* keep header content compact on tablet */
  header.header-main .container { align-items: center; padding-top:8px; padding-bottom:8px; }
  header.header-main .logo { margin-top:0; }
  header.header-main .main-nav { margin-top:0; }
  /* fix the action cluster to the top-right of the viewport on tablets so it doesn't overlap the hero */
  header.header-main .header-right {
    position: fixed;
    right: 18px;
    top: 12px;
    transform: none;
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 1600;
  }
  header.header-main .header-right .lang-picker { order: 0; margin: 0 6px 0 0; }
  header.header-main .header-right .login-btn, header.header-main .header-right .register-btn { order: 1; }
  header.header-main .header-right .hamburger { order: 2; }
}

/* Mobile <=425px: compact header adjustments and mobile improvements */
@media (max-width:425px){
  /* Keep and extend the announcement banner to full width on small screens without overflow */
  .announcement-bar{ display:block !important; width:calc(100% + 36px) !important; margin-left:-18px !important; margin-right:-18px !important; padding:8px 18px !important; }

  /* Header: keep logo + brand + hamburger on small screens only */
  header.header-main .main-nav,
  header.header-main .lang-picker,
  header.header-main .register-btn,
  header.header-main .login-btn { display: none !important; }
  header.header-main .logo, header.header-main .brand { display: inline-flex !important; align-items:center !important; }
  header.header-main #mobile-hamburger { display:inline-flex !important; margin-left:auto !important; }
  header.header-main .logo img { height:32px !important; }
  header.header-main .brand { font-size:0.9rem !important; }
  .announcement-bar .container{ max-width:100% !important; padding:0 !important; margin:0 !important; }
  .announcement-inner{ justify-content:flex-start !important; }
  .announcement-inner span{ padding-right:12px; display:block; }

  /* Mobile: make announcement a single-line scrolling marquee */
  .announcement-inner{ overflow:hidden !important; }
  .announcement-inner span{ display:inline-block !important; white-space:nowrap !important; padding-left:6px !important; font-size:0.95rem !important; }
  @media (prefers-reduced-motion: no-preference){
    .announcement-inner span{ animation: fd-marquee var(--marquee-duration-mobile) linear infinite !important; }
  }
  @media (prefers-reduced-motion: reduce){
    .announcement-inner span{ animation: none !important; }
  }

  /* Compact auth buttons: display as circular tap targets */
  .header-right .login-btn, .header-right .register-btn{
    width:44px !important;
    height:44px !important;
    padding:0 !important;
    border-radius:50% !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    background-repeat:no-repeat !important;
    background-position:center !important;
    background-size:20px 20px !important;
    color:transparent !important; /* hide visible label while preserving accessible text */
    font-size:0 !important;
    border:0 !important;
    box-shadow:none !important;
  }
  /* Use the existing SVG icon (keeps current asset); if you want white-on-green circle, replace the SVG accordingly */
  .header-right .login-btn{ background-image: url('../images/icons/user-mobile.svg') !important; }
  .header-right .register-btn{ background-image: url('../images/icons/user-mobile.svg') !important; }

  /* Keep language picker and mobile publish visible */
  .header-right .lang-picker{ margin-right:6px }
  #publish-btn-mobile{ display:inline-block !important }

  /* Make the hamburger easier to tap (larger hit area) */
  .hamburger{ width:48px !important; height:48px !important; padding:8px !important; box-sizing:content-box; }
  .hamburger span{ height:3px }

  /* Hide favorites and dossier icons on non-profile pages to reduce header clutter */
  #favorites-btn, #dossier-btn, .header-right #favorites-btn, .header-right #dossier-btn { display: none !important; }
  body.profile-page #favorites-btn, body.profile-page #dossier-btn { display: inline-flex !important; }

  /* Extend search row and elements to full container width */
  .search-row{ padding:12px 0; }
  .search-row-inner{ flex-wrap:wrap; gap:8px; }
  .search-container{ flex:1 1 100%; min-width:100%; }
  .search-box{ width:100%; padding:12px 14px; gap:8px; }
  .search-box input#site-search{ padding:14px 16px; font-size:1rem; }
  .search-circle-btn{ width:44px; height:44px; flex-shrink:0; }

  /* Extend header elements */
  .header-container{ padding:12px 0; }
  .header-grid{ gap:8px; }
  .logo-img img{ width:40px; height:40px; }
  .logo h1{ font-size:16px; }

  /* Properties: switch to single-column cards to avoid truncation */
  .properties-grid, .showcase-grid { display:block !important; }
  .properties-grid .property-card, .showcase-grid .property-card, .properties-grid .card, .showcase-grid .card { width:100% !important; margin-bottom:12px !important; box-sizing:border-box !important; }

  /* Reduce search input padding to bring content higher on mobile */
  .search-box .search-input-wrap input{ padding:10px 12px !important; }

  /* Ensure all buttons and links are easily tappable (min 44x44px) */
  .pill{ padding:8px 14px; font-size:0.9rem; }
  .btn-primary{ padding:10px 16px; font-size:0.95rem; }
}

/* Also apply tablet header layout to small mobile screens per user request */
@media (max-width:425px) {
  /* keep header compact */
  .header-container { align-items: center; padding-top:8px; padding-bottom:8px; }
  .header-container .header-right {
    position: static !important;
    transform: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }
  .header-container .header-right .lang-picker { order: 0; margin: 0 6px 0 0; }
  .header-container .header-right .login-btn, .header-container .header-right .register-btn { order: 1; }
  .header-container .header-right .hamburger { order: 2; }
  /* Ensure content sits naturally under header (no large fixed cluster) */
  main, .search-row, .promo-scroller { padding-top: 8px; }
}

/* Mobile header realignment: keep announcement bar separate and place logo + lang + hamburger on one line */
@media (max-width:425px){
  /* Make announcement a normal block above the header and avoid overlap */
  .announcement-bar { position: static !important; width: 100% !important; margin-left: 0 !important; margin-right: 0 !important; padding: 6px 12px !important; box-shadow: none !important; }
  .announcement-inner { justify-content: flex-start !important; }

  /* Restore header to normal flow under the announcement */
  .header-container { position: static !important; padding-top: 8px !important; padding-bottom: 8px !important; }
  .header-grid { display: flex !important; grid-template-columns: none !important; align-items: center !important; justify-content: space-between !important; gap: 8px !important; }

  /* Ensure left (logo) and right (controls) align on same baseline */
  .header-left, .header-right { display:flex !important; align-items:center !important; gap:8px !important; }
  .header-right { position: static !important; right: auto !important; top: auto !important; transform: none !important; }

  /* Force lang picker and hamburger to sit inline next to logo */
  .logo { display:flex !important; align-items:center !important; gap:10px !important; }
  .brand-short{ display:inline-block !important; }
  .brand-full{ display:none !important; }
  .logo h1{ display:none !important; }
  .header-right .lang-picker{ display:inline-flex !important; order: 1 !important; }
  #mobile-hamburger, .hamburger{ display:inline-flex !important; order: 2 !important; }

  /* Remove the extra top padding we previously added so content sits under header naturally */
  main, .search-row, .promo-scroller { padding-top: 8px !important; }
}

/* Additional header simplification for very small screens */
@media (max-width:425px){
  /* Hide debug banner on small mobile to avoid covering controls */
  #dev-debug-banner{ display:none !important; }

  /* Prefer the short brand (icon) only — hide long title to free space */
  .brand-full{ display:none !important; }
  .logo h1{ display:none !important; }
  .brand-short{ display:inline-block !important; }

  /* Hide secondary header icons to reduce clutter (favorites/dossier/login/register) */
  .header-right .login-btn, .header-right .register-btn, #favorites-btn, #dossier-btn { display: none !important; }

  /* Ensure the hamburger and language picker remain visible and tappable */
  .header-right .lang-picker, .hamburger { display:inline-flex !important; z-index:1700 !important; }

  /* Hide the subnav publish button and show a single floating publish CTA */
  .subnav .subnav-actions{ display:none !important; }
  #publish-btn-mobile{
    position: fixed !important;
    bottom: 14px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index:1700 !important;
    padding:12px 18px !important;
    border-radius:28px !important;
    box-shadow:0 10px 30px rgba(0,0,0,0.12) !important;
    width:auto !important;
    display:inline-block !important;
  }

  /* Make sure header container doesn't push content off-screen */
  .header-container { padding-left: 12px !important; padding-right: 12px !important; }
}

/* Additional micro-fixes for very small screens to ensure a single-column flow */
@media (max-width:425px){
  /* remove left spacer that reserves empty space in some layouts */
  .left-spacer { display: none !important; }

  /* force header and search row into a single column flow */
  .header-grid { grid-template-columns: 1fr !important; }
  .search-row-inner { flex-direction: column !important; align-items: stretch !important; }
  .search-container { width: 100% !important; flex: 1 1 100% !important; }

  /* reduce promo scroller height and avoid overflow on tiny screens */
  .promo-scroller { height: auto !important; padding: 8px 0 !important; }
  .promo-scroller .promo-track img { height: 88px !important; object-fit:cover; }

  /* prevent accidental horizontal overflow from fixed header or large elements */
  html, body { overflow-x: hidden; min-width: 0; }

  /* ensure footer columns stack and don't force wide layout */
  .footer-grid { display: block !important; }
  .footer-column { width: 100% !important; box-sizing: border-box; padding: 8px 0 !important; }
}

/* Property card mobile refinements: reduce vertical whitespace, keep images consistent and readable */
@media (max-width:425px){
  .properties-grid .property-card,
  .showcase-grid .property-card {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    margin: 0 0 12px !important;
    padding: 10px !important;
    box-shadow: 0 6px 18px rgba(6,12,10,0.06) !important;
    border-radius: 10px !important;
    background: var(--surface) !important;
    box-sizing: border-box !important;
  }

  .properties-grid .property-img,
  .showcase-grid .property-img {
    height: 140px !important;
    aspect-ratio: auto !important;
    overflow: hidden !important;
    border-radius: 8px !important;
  }
  .properties-grid .property-img img,
  .showcase-grid .property-img img { width:100% !important; height:100% !important; object-fit:cover !important; display:block !important; }

  .properties-grid .property-content,
  .showcase-grid .property-content { padding: 8px 6px !important; }

  .properties-grid .property-price,
  .showcase-grid .property-price { font-size: 1.05rem !important; margin-bottom:6px !important; }

  .properties-grid .property-address,
  .showcase-grid .property-address { font-size: 0.9rem !important; color: var(--muted) !important; white-space: normal !important; overflow:visible !important; }

  .properties-grid .property-features { display: none !important; }
  .properties-grid .price-block { text-align: left !important; min-width: unset !important; }

  /* Make CTA buttons full-width inside cards for easier tapping */
  .property-card .btn-contact-listing, .property-card .see-more { width: 100% !important; display:block !important; }
}

/* === FINAL: Mobile header single-line (logo, lang, user, hamburger) (<=480px) === */
@media (max-width:480px) {
  /* Hide debug banner */
  #dev-debug-banner { display: none !important; }

  /* Announcement: static block above header */
  .announcement-bar { position: static !important; width: 100% !important; margin: 0 !important; padding: 6px 12px !important; box-shadow: none !important; }
  .announcement-inner { justify-content: flex-start !important; overflow: hidden !important; }
  .announcement-inner span { font-size: 0.9rem !important; display: inline-block !important; white-space: nowrap !important; padding-left: 100% !important; animation: fd-marquee-mobile var(--marquee-duration-mobile) linear infinite !important; }
  @keyframes fd-marquee-mobile { 0% { transform: translateX(0%); } 100% { transform: translateX(-100%); } }

  /* Header: single flex line (logo LEFT, controls RIGHT) */
  header { position: static !important; padding: 6px 12px !important; }
  .header-container, .header-grid {
    display: flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 !important;
    gap: 6px !important;
    flex-wrap: nowrap !important;
  }

  /* Left: logo only (small) */
  .header-left { display: flex !important; align-items: center !important; gap: 0 !important; flex: 0 0 auto !important; }
  .logo { display: flex !important; align-items: center !important; gap: 6px !important; flex: 0 0 auto !important; }
  .logo-img img { width: 38px !important; height: 38px !important; }
  .logo h1 { display: none !important; }
  .brand-full { display: none !important; }
  .brand-short { display: inline-block !important; font-size: 0.9rem !important; color: var(--brand) !important; }

  /* Right: lang-picker, login icon, hamburger on same line */
  .header-right {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    flex: 0 0 auto !important;
    position: static !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
  }

  /* Language picker */
  .header-right .lang-picker { display: inline-flex !important; align-items: center !important; }
  .lang-current { padding: 4px 6px !important; display: inline-flex !important; align-items: center !important; gap: 2px !important; border: 0 !important; background: transparent !important; }
  .lang-flag { width: 16px !important; height: 12px !important; }
  .lang-code { font-size: 0.75rem !important; margin: 0 2px !important; }
  .lang-current i { font-size: 0.7rem !important; margin-left: 1px !important; }

  /* Login button: compact icon (user) */
  .header-right .login-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    color: var(--brand) !important;
    font-size: 0 !important;
    cursor: pointer !important;
    flex: 0 0 36px !important;
    overflow: hidden !important;
  }
  .header-right .login-btn i {
    font-size: 18px !important;
    display: inline-block !important;
    line-height: 1 !important;
  }

  /* Register: show as compact icon on mobile */
  .header-right .register-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    color: transparent !important;
    font-size: 0 !important;
    cursor: pointer !important;
    flex: 0 0 36px !important;
    overflow: hidden !important;
    background-image: url('../images/icons/user-mobile.svg') !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 20px 20px !important;
  }

  /* Hide favorites and dossier */
  #favorites-btn, #dossier-btn { display: none !important; }

  /* Hamburger visible and aligned */
  .hamburger, #mobile-hamburger {
    display: inline-flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    width: 36px !important;
    height: 36px !important;
    padding: 6px !important;
    background: transparent !important;
    border: 0 !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 36px !important;
  }
  .hamburger span, #mobile-hamburger span { width: 22px !important; height: 2px !important; background: var(--brand) !important; border-radius: 2px !important; }

  /* Floating publish CTA */
  #publish-btn-mobile { position: fixed !important; bottom: 14px !important; left: 50% !important; transform: translateX(-50%) !important; z-index: 1100 !important; padding: 12px 18px !important; border-radius: 28px !important; box-shadow: 0 10px 30px rgba(0,0,0,0.15) !important; display: inline-block !important; }

  /* Content: no extra padding */
  main, .search-row, .promo-scroller { padding-top: 8px !important; }

  /* Prevent horizontal overflow */
  html, body { overflow-x: hidden !important; }
}

