@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&family=DM+Sans:wght@400;500;600&display=swap');

:root {
  --primary:   #1e3a5f;
  --accent:    #ff6b35;
  --accent2:   #00c2cb;
  --green:     #10b981;
  --light:     #f0f4f8;
  --white:     #ffffff;
  --gray:      #64748b;
  --border:    #e2e8f0;
  --dark:      #0f172a;
  --card-shadow: 0 4px 20px rgba(0,0,0,.08);
  --radius:    14px;
  --radius-sm: 8px;
}

*{ box-sizing:border-box; margin:0; padding:0 }
body{ font-family:'DM Sans',system-ui,sans-serif; background:var(--light); color:var(--dark); line-height:1.5; min-height:100vh }
a{ text-decoration:none; color:inherit }
img{ display:block; max-width:100% }

/* ── NAVBAR ── */
.navbar{ background:var(--primary); position:sticky; top:0; z-index:200; box-shadow:0 2px 20px rgba(0,0,0,.2) }
.navbar-inner{ max-width:1280px; margin:0 auto; padding:0 24px; display:flex; align-items:center; gap:16px; height:68px }
.navbar-logo{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.5rem; font-weight:900; color:white; letter-spacing:-.5px; flex-shrink:0 }
.navbar-logo span{ color:var(--accent) }
.nav-search{ flex:1; display:flex; max-width:480px; background:rgba(255,255,255,.12); border-radius:10px; overflow:hidden; border:1.5px solid rgba(255,255,255,.2); transition:all .2s }
.nav-search:focus-within{ background:white; border-color:var(--accent2) }
.nav-search:focus-within input{ color:var(--dark) }
.nav-search input{ flex:1; border:none; outline:none; padding:0 14px; font-size:.92rem; font-family:inherit; height:42px; background:transparent; color:white }
.nav-search input::placeholder{ color:rgba(255,255,255,.6) }
.nav-search:focus-within input::placeholder{ color:#94a3b8 }
.nav-search button{ background:var(--accent); border:none; padding:0 16px; cursor:pointer; font-size:1rem; height:42px; transition:background .2s }
.nav-search button:hover{ background:#e55a25 }
.nav-actions{ display:flex; align-items:center; gap:10px; margin-left:auto; flex-shrink:0 }

/* ── BUTTONS ── */
.btn{ display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:10px; font-weight:700; font-size:.9rem; cursor:pointer; border:none; font-family:inherit; transition:all .2s; white-space:nowrap }
.btn-primary{ background:var(--accent); color:white }
.btn-primary:hover{ background:#e55a25; transform:translateY(-1px) }
.btn-secondary{ background:white; color:var(--primary); border:2px solid var(--border) }
.btn-secondary:hover{ border-color:var(--primary) }
.btn-outline{ background:transparent; color:white; border:2px solid rgba(255,255,255,.4) }
.btn-outline:hover{ border-color:white; background:rgba(255,255,255,.1) }
.btn-success{ background:var(--green); color:white }
.btn-success:hover{ background:#059669; transform:translateY(-1px) }
.btn-danger{ background:#fee2e2; color:#dc2626; border:1px solid #fca5a5 }
.btn-danger:hover{ background:#fecaca }
.btn-full{ width:100%; justify-content:center }
.btn-lg{ padding:14px 30px; font-size:1rem }
.btn-post{ background:var(--accent); color:white; border:none; border-radius:10px; padding:10px 20px; font-weight:700; font-size:.88rem; cursor:pointer; font-family:inherit; transition:all .2s; display:inline-flex; align-items:center; gap:7px }
.btn-post:hover{ background:#e55a25; transform:translateY(-1px) }

/* ── HERO ── */
.hero{ background:linear-gradient(135deg,var(--primary) 0%,#2d5a8e 50%,#1a4a7a 100%); padding:70px 24px 90px; position:relative; overflow:hidden }
.hero::before{ content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") }
.hero-content{ max-width:1280px; margin:0 auto; text-align:center; position:relative }
.hero h1{ font-family:'Plus Jakarta Sans',sans-serif; color:white; font-size:clamp(2rem,5vw,3.2rem); font-weight:900; line-height:1.15; margin-bottom:14px }
.hero h1 span{ color:var(--accent) }
.hero p{ color:rgba(255,255,255,.75); font-size:1.1rem; margin-bottom:36px }

/* Hero search box */
.hero-search-box{ background:white; border-radius:20px; padding:20px 24px; max-width:900px; margin:0 auto; box-shadow:0 20px 60px rgba(0,0,0,.25) }
.hero-search-grid{ display:grid; grid-template-columns:1fr 1fr 1fr 1fr auto; gap:12px; align-items:end }
.hs-group label{ display:block; font-size:.75rem; font-weight:700; color:var(--gray); text-transform:uppercase; letter-spacing:.6px; margin-bottom:6px }
.hs-group select, .hs-group input{ width:100%; padding:11px 14px; border:2px solid var(--border); border-radius:10px; font-family:inherit; font-size:.92rem; outline:none; transition:border-color .2s; background:white; color:var(--dark) }
.hs-group select:focus, .hs-group input:focus{ border-color:var(--accent2) }
.hs-search-btn{ background:var(--accent); color:white; border:none; border-radius:10px; padding:12px 28px; font-weight:800; font-size:1rem; cursor:pointer; font-family:inherit; white-space:nowrap; transition:all .2s; height:48px; display:flex; align-items:center; gap:8px }
.hs-search-btn:hover{ background:#e55a25; transform:translateY(-1px) }
.hero-stats{ display:flex; justify-content:center; gap:40px; margin-top:36px }
.hero-stat{ text-align:center; color:white }
.hero-stat strong{ font-family:'Plus Jakarta Sans',sans-serif; display:block; font-size:1.8rem; font-weight:900; color:var(--accent2) }
.hero-stat span{ font-size:.85rem; opacity:.75 }

/* ── TYPE PILLS ── */
.type-pills{ background:white; border-bottom:2px solid var(--border); overflow-x:auto; scrollbar-width:none }
.type-pills::-webkit-scrollbar{ display:none }
.type-pills-inner{ display:flex; gap:6px; max-width:1280px; margin:0 auto; padding:12px 24px }
.type-pill{ display:flex; align-items:center; gap:7px; padding:9px 18px; border-radius:50px; border:2px solid var(--border); background:white; font-weight:600; font-size:.85rem; cursor:pointer; font-family:inherit; transition:all .2s; white-space:nowrap; color:var(--gray) }
.type-pill:hover, .type-pill.active{ background:var(--primary); color:white; border-color:var(--primary) }
.type-pill span{ font-size:1.1rem }

/* ── PROPERTY CARDS ── */
.prop-card{ background:white; border-radius:var(--radius); overflow:hidden; box-shadow:var(--card-shadow); transition:transform .25s, box-shadow .25s; display:flex; flex-direction:column; border:1px solid var(--border) }
.prop-card:hover{ transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.14) }
.prop-card-img-wrap{ position:relative; overflow:hidden }
.prop-card-img{ width:100%; aspect-ratio:16/10; object-fit:cover; background:#e2e8f0; transition:transform .4s }
.prop-card:hover .prop-card-img{ transform:scale(1.04) }
.prop-card-badges{ position:absolute; top:12px; left:12px; display:flex; gap:6px; flex-wrap:wrap }
.badge-vanzare{ background:#ff6b35; color:white; font-size:.7rem; font-weight:800; padding:4px 10px; border-radius:20px; letter-spacing:.3px }
.badge-inchiriere{ background:#00c2cb; color:white; font-size:.7rem; font-weight:800; padding:4px 10px; border-radius:20px; letter-spacing:.3px }
.badge-type{ background:rgba(0,0,0,.55); color:white; font-size:.7rem; font-weight:700; padding:4px 10px; border-radius:20px; backdrop-filter:blur(4px) }
.badge-featured{ position:absolute; top:12px; right:12px; background:#fbbf24; color:#78350f; font-size:.7rem; font-weight:800; padding:4px 10px; border-radius:20px }
.prop-card-body{ padding:16px; flex:1; display:flex; flex-direction:column; gap:6px }
.prop-card-price{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.25rem; font-weight:900; color:var(--accent) }
.prop-card-title{ font-weight:700; font-size:.92rem; color:var(--dark); line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
.prop-card-loc{ font-size:.82rem; color:var(--gray) }
.prop-card-details{ display:flex; gap:12px; font-size:.82rem; color:var(--primary); font-weight:600; flex-wrap:wrap; margin-top:4px }
.prop-card-details .dot{ color:var(--border) }
.prop-card-meta{ font-size:.76rem; color:#94a3b8; margin-top:auto; padding-top:8px; border-top:1px solid var(--border) }

/* ── GRID LAYOUT ── */
.container{ max-width:1280px; margin:0 auto; padding:0 24px }
.listings-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:20px }
.section{ padding:40px 0 }
.section-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px }
.section-title{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.4rem; font-weight:800; color:var(--dark) }
.section-link{ color:var(--accent); font-weight:700; font-size:.9rem; display:flex; align-items:center; gap:4px }

/* ── SEARCH PAGE ── */
.search-layout{ display:grid; grid-template-columns:300px 1fr; gap:24px; align-items:start; padding:28px 0 }
.filters-panel{ background:white; border-radius:var(--radius); padding:22px; box-shadow:var(--card-shadow); border:1px solid var(--border); position:sticky; top:84px }
.filters-panel h3{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1rem; font-weight:800; margin-bottom:18px; padding-bottom:12px; border-bottom:2px solid var(--border); color:var(--dark) }
.filter-group{ margin-bottom:20px }
.filter-group label{ display:block; font-size:.8rem; font-weight:700; color:var(--gray); text-transform:uppercase; letter-spacing:.5px; margin-bottom:8px }
.filter-group select, .filter-group input{ width:100%; padding:10px 12px; border:2px solid var(--border); border-radius:10px; font-family:inherit; font-size:.9rem; outline:none; transition:border-color .2s }
.filter-group select:focus, .filter-group input:focus{ border-color:var(--accent2) }
.price-row, .range-row{ display:grid; grid-template-columns:1fr 1fr; gap:8px }

/* ── DETAIL PAGE ── */
.detail-layout{ display:grid; grid-template-columns:1fr 380px; gap:28px; align-items:start; padding:28px 0 60px }
.detail-gallery{ border-radius:var(--radius); overflow:hidden }
.main-image{ width:100%; aspect-ratio:16/10; object-fit:cover; background:#e2e8f0; cursor:zoom-in }
.thumb-strip{ display:flex; gap:8px; margin-top:10px; flex-wrap:wrap }
.thumb{ width:80px; height:60px; object-fit:cover; border-radius:8px; cursor:pointer; opacity:.6; transition:all .2s; border:3px solid transparent }
.thumb:hover, .thumb.active{ opacity:1; border-color:var(--accent) }
.detail-info{ background:white; border-radius:var(--radius); padding:24px; box-shadow:var(--card-shadow); border:1px solid var(--border) }
.detail-price{ font-family:'Plus Jakarta Sans',sans-serif; font-size:2.2rem; font-weight:900; color:var(--accent) }
.detail-title{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.4rem; font-weight:800; margin:10px 0 6px; color:var(--dark) }
.detail-specs{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:16px 0 }
.spec-item{ background:var(--light); border-radius:10px; padding:12px 14px }
.spec-item .spec-label{ font-size:.72rem; font-weight:700; color:var(--gray); text-transform:uppercase; letter-spacing:.5px; margin-bottom:3px }
.spec-item .spec-val{ font-weight:800; font-size:.95rem; color:var(--dark) }
.seller-card{ background:white; border-radius:var(--radius); padding:20px; box-shadow:var(--card-shadow); border:1px solid var(--border); margin-top:16px }
.seller-avatar{ width:48px; height:48px; border-radius:50%; background:var(--primary); display:flex; align-items:center; justify-content:center; color:white; font-weight:900; font-size:1.2rem; flex-shrink:0 }

/* ── MAP ── */
#listing-map{ height:300px; border-radius:var(--radius); overflow:hidden; margin-top:16px; border:1px solid var(--border) }
#mini-map{ height:200px; border-radius:10px; overflow:hidden; margin-top:12px; border:1px solid var(--border) }

/* ── FORMS ── */
.form-group{ margin-bottom:18px }
.form-group label{ display:block; margin-bottom:7px; font-weight:700; font-size:.88rem; color:var(--dark) }
.form-group input, .form-group select, .form-group textarea{
  width:100%; padding:12px 14px; border:2px solid var(--border); border-radius:10px;
  font-size:.95rem; font-family:inherit; outline:none; transition:border-color .2s; background:white }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{ border-color:var(--accent2) }
.form-group textarea{ resize:vertical; min-height:130px }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px }
.form-row-3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px }
.error-box{ background:#fee2e2; color:#dc2626; padding:13px 16px; border-radius:10px; margin-bottom:16px; font-size:.9rem; border:1px solid #fca5a5; display:none }
.tx-selector{ display:flex; gap:10px; margin-bottom:4px }
.tx-btn{ flex:1; padding:12px; border:2px solid var(--border); border-radius:10px; text-align:center; cursor:pointer; font-weight:700; font-size:.9rem; transition:all .2s; background:white; font-family:inherit }
.tx-btn.active{ border-color:var(--accent); background:#fff7f5; color:var(--accent) }

/* ── POST LISTING ── */
.post-wrap{ max-width:820px; margin:0 auto; padding:28px 24px 60px }
.post-card{ background:white; border-radius:var(--radius); padding:28px; box-shadow:var(--card-shadow); border:1px solid var(--border); margin-bottom:20px }
.post-card-title{ font-family:'Plus Jakarta Sans',sans-serif; font-size:.82rem; font-weight:800; color:var(--gray); text-transform:uppercase; letter-spacing:.6px; margin-bottom:20px; padding-bottom:12px; border-bottom:2px solid var(--border) }
.upload-zone{ border:2px dashed var(--accent2); border-radius:12px; padding:32px; text-align:center; cursor:pointer; transition:background .2s; background:#f0fdfe }
.upload-zone:hover{ background:#e0fafa }
.img-preview-grid{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px }
.img-preview{ position:relative; width:110px; height:80px; border-radius:10px; overflow:hidden; border:2px solid var(--border) }
.img-preview img{ width:100%; height:100%; object-fit:cover }
.img-remove{ position:absolute; top:3px; right:3px; background:rgba(0,0,0,.65); color:white; border:none; border-radius:50%; width:22px; height:22px; font-size:.75rem; cursor:pointer; display:flex; align-items:center; justify-content:center }
.progress-bar{ height:5px; background:var(--border); border-radius:3px; margin-top:10px; display:none; overflow:hidden }
.progress-fill{ height:100%; background:var(--accent2); transition:width .3s }

/* ── AUTH ── */
.auth-page{ min-height:calc(100vh - 68px); display:flex; align-items:center; justify-content:center; padding:40px 20px; background:linear-gradient(135deg, var(--primary) 0%, #2d5a8e 100%) }
.auth-card{ background:white; border-radius:20px; padding:44px; width:100%; max-width:480px; box-shadow:0 24px 80px rgba(0,0,0,.25) }
.auth-logo{ text-align:center; margin-bottom:28px; font-family:'Plus Jakarta Sans',sans-serif; font-size:2rem; font-weight:900; color:var(--primary) }
.auth-logo span{ color:var(--accent) }
.auth-title{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.6rem; font-weight:900; margin-bottom:6px }
.auth-sub{ color:var(--gray); margin-bottom:28px }

.hs-search-btn2{ background:var(--green); color:white; border:none; border-radius:10px; padding:12px 9px; font-weight:100; font-size:1rem; cursor:pointer; font-family:inherit; white-space:nowrap; transition:all .2s; height:28px; width:110px; display: flex; align-items:center; justify-content: right; gap:8px }
.hs-search-btn2:hover{ background:#059669; transform:translateY(-1px) }



/* ── MY LISTINGS ── */
.my-row{ background:white; border-radius:var(--radius); padding:16px 20px; margin-bottom:12px; display:grid; grid-template-columns:100px 1fr auto; gap:18px; align-items:center; border:1px solid var(--border); box-shadow:0 1px 8px rgba(0,0,0,.05); transition:box-shadow .2s }
.my-row:hover{ box-shadow:0 4px 20px rgba(0,0,0,.1) }
.my-row-img{ width:100px; height:75px; object-fit:cover; border-radius:10px; background:#e2e8f0 }
.status-badge{ display:inline-block; padding:4px 12px; border-radius:20px; font-size:.72rem; font-weight:800; letter-spacing:.3px }
.status-activ{ background:#d1fae5; color:#065f46 }
.status-inactiv{ background:#fef3c7; color:#92400e }
.status-vandut{ background:#fee2e2; color:#991b1b }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:28px }
.stat-card{ background:white; border-radius:var(--radius); padding:20px; text-align:center; border:1px solid var(--border); box-shadow:0 1px 8px rgba(0,0,0,.05) }
.stat-num{ font-family:'Plus Jakarta Sans',sans-serif; font-size:2rem; font-weight:900; color:var(--primary) }
.stat-label{ font-size:.82rem; color:var(--gray); margin-top:4px }

/* ── MISC ── */
.spinner{ width:44px; height:44px; border:4px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto }
@keyframes spin{ to{ transform:rotate(360deg) } }
.empty-state{ text-align:center; padding:80px 20px }
.empty-state .icon{ font-size:4rem; margin-bottom:16px }
.empty-state h3{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.4rem; font-weight:800; margin-bottom:8px }
.empty-state p{ color:var(--gray); margin-bottom:24px }
.pagination{ display:flex; gap:8px; justify-content:center; padding:36px 0; flex-wrap:wrap }
.page-btn{ width:42px; height:42px; border-radius:10px; border:2px solid var(--border); background:white; font-weight:700; cursor:pointer; font-family:inherit; transition:all .2s; font-size:.9rem }
.page-btn:hover, .page-btn.active{ background:var(--primary); color:white; border-color:var(--primary) }

footer{ background:var(--primary); color:rgba(255,255,255,.65); padding:48px 24px 28px; margin-top:60px }
.footer-inner{ max-width:1280px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px }
.footer-brand .logo{ font-family:'Plus Jakarta Sans',sans-serif; font-size:1.5rem; font-weight:900; color:white; margin-bottom:10px }
.footer-brand .logo span{ color:var(--accent) }
.footer-brand p{ font-size:.88rem; line-height:1.6 }
.footer-col h4{ color:white; font-weight:800; margin-bottom:14px; font-size:.95rem }
.footer-col a{ display:block; margin-bottom:8px; font-size:.88rem; transition:color .2s }
.footer-col a:hover{ color:var(--accent2) }
.footer-bottom{ max-width:1280px; margin:32px auto 0; border-top:1px solid rgba(255,255,255,.12); padding-top:22px; display:flex; justify-content:space-between; align-items:center; font-size:.84rem; flex-wrap:wrap; gap:10px }

@keyframes slideIn{ from{ opacity:0; transform:translateX(40px) } to{ opacity:1; transform:translateX(0) } }

@media(max-width:1024px){
  .hero-search-grid{ grid-template-columns:1fr 1fr; }
  .detail-layout{ grid-template-columns:1fr }
  .search-layout{ grid-template-columns:1fr }
  .filters-panel{ position:static }
  .footer-inner{ grid-template-columns:1fr 1fr }
}
@media(max-width:768px){
  .stats-grid{ grid-template-columns:1fr 1fr }
  .hero-search-grid{ grid-template-columns:1fr }
  .listings-grid{ grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px }
  .form-row, .form-row-3{ grid-template-columns:1fr }
  .hero{ padding:48px 20px 70px }
  .hero-stats{ gap:24px }
  .my-row{ grid-template-columns:80px 1fr }
  .auth-card{ padding:30px 20px }
  .footer-inner{ grid-template-columns:1fr }
}
@media(max-width:480px){
  .listings-grid{ grid-template-columns:1fr }
}
