/* ============================================================
   Deweloper Portal – Frontend CSS
   ============================================================ */

:root {
    --dp-primary:   #e74c3c;
    --dp-secondary: #2c3e50;
    --dp-accent:    #f39c12;
    --dp-success:   #27ae60;
    --dp-bg:        #f8f9fa;
    --dp-border:    #dee2e6;
    --dp-radius:    8px;
    --dp-shadow:    0 2px 12px rgba(0,0,0,.12);
}

/* ---- Wrapper portalu ---- */
.dp-portal-wrap {
    position: relative;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ---- Filtry ---- */
.dp-filters {
    background: #fff;
    border: 1px solid var(--dp-border);
    border-radius: var(--dp-radius) var(--dp-radius) 0 0;
    padding: 14px 18px;
}
.dp-filters-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}
.dp-filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.dp-filter-group label {
    font-size: 11px;
    font-weight: 600;
    color: #666;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.dp-select, .dp-input {
    height: 36px;
    padding: 0 10px;
    border: 1px solid var(--dp-border);
    border-radius: var(--dp-radius);
    font-size: 14px;
    background: #fff;
    min-width: 160px;
}
.dp-toggle-group {
    display: flex;
    gap: 6px;
}
.dp-toggle {
    padding: 6px 12px;
    border: 1px solid var(--dp-border);
    border-radius: var(--dp-radius);
    background: #fff;
    font-size: 13px;
    cursor: pointer;
    transition: all .2s;
}
.dp-toggle.active {
    background: var(--dp-secondary);
    color: #fff;
    border-color: var(--dp-secondary);
}

/* ---- Mapa ---- */
.dp-map, #dp-map-full {
    width: 100%;
    border: 1px solid var(--dp-border);
    border-top: none;
    z-index: 0;
}

/* ---- Popup ---- */
.dp-popup { font-size: 13px; line-height: 1.5; min-width: 200px; }
.dp-popup h4 { margin: 6px 0 4px; font-size: 15px; font-weight: 700; }
.dp-popup-price { font-weight: 700; color: var(--dp-primary); font-size: 14px; margin: 4px 0; }
.dp-popup-address { color: #666; font-size: 12px; margin: 3px 0 8px; }

/* ---- Odznaki ---- */
.dp-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    margin-right: 4px;
    margin-bottom: 6px;
}
.dp-badge-featured { background: #fff3cd; color: #856404; }
.dp-badge-stage    { background: #e8f4fd; color: #0c6291; }

/* ---- Panel boczny ---- */
.dp-sidebar {
    position: absolute;
    top: 0;
    right: 0;
    width: 360px;
    max-width: 95vw;
    height: 100%;
    background: #fff;
    border-left: 1px solid var(--dp-border);
    overflow-y: auto;
    z-index: 999;
    transition: transform .3s ease;
    box-shadow: -4px 0 20px rgba(0,0,0,.1);
}
.dp-sidebar-hidden { transform: translateX(100%); }
.dp-sidebar-close {
    position: sticky;
    top: 0;
    float: right;
    margin: 12px 12px 0 0;
    background: transparent;
    border: none;
    font-size: 18px;
    cursor: pointer;
    z-index: 2;
    color: #666;
    padding: 4px 8px;
}
.dp-sidebar-close:hover { color: var(--dp-primary); }

/* ---- Szczegóły inwestycji (panel) ---- */
.dp-inv-detail { padding: 16px 20px 32px; }
.dp-inv-detail h2 { font-size: 20px; margin: 0 0 10px; line-height: 1.3; padding-right: 32px; }
.dp-inv-detail h3 { font-size: 15px; margin: 20px 0 8px; color: var(--dp-secondary); }
.dp-developer { font-weight: 600; color: #444; }
.dp-inv-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 14px 0;
}
.dp-stat {
    background: var(--dp-bg);
    border-radius: var(--dp-radius);
    padding: 8px 12px;
}
.dp-stat span  { display: block; font-size: 11px; color: #888; text-transform: uppercase; letter-spacing: .4px; }
.dp-stat strong{ display: block; font-size: 15px; color: var(--dp-secondary); margin-top: 2px; }
.dp-inv-content { font-size: 14px; line-height: 1.7; color: #444; margin: 12px 0; }

/* ---- Legenda RCN ---- */
.dp-legend {
    background: rgba(255,255,255,.9);
    padding: 8px 12px;
    border-radius: var(--dp-radius);
    font-size: 12px;
    box-shadow: var(--dp-shadow);
    backdrop-filter: blur(4px);
}
.dp-legend strong { display: block; margin-bottom: 6px; }

/* ---- Formularz leadowy ---- */
.dp-lead-form-wrap {
    border-top: 1px solid var(--dp-border);
    margin-top: 24px;
    padding-top: 16px;
}
.dp-lead-form-wrap h3 { margin-top: 0; }
.dp-lead-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.dp-lead-form input,
.dp-lead-form textarea {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--dp-border);
    border-radius: var(--dp-radius);
    font-size: 14px;
    box-sizing: border-box;
    transition: border-color .2s;
    font-family: inherit;
}
.dp-lead-form input:focus,
.dp-lead-form textarea:focus {
    outline: none;
    border-color: var(--dp-primary);
}
.dp-form-note {
    font-size: 11px;
    color: #999;
    margin: 4px 0 0;
    text-align: center;
}

/* ---- Przyciski ---- */
.dp-btn-primary, .dp-btn-secondary {
    display: inline-block;
    padding: 10px 20px;
    border-radius: var(--dp-radius);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    text-decoration: none;
    transition: all .2s;
    text-align: center;
}
.dp-btn-primary {
    background: var(--dp-primary);
    color: #fff;
}
.dp-btn-primary:hover  { background: #c0392b; color: #fff; }
.dp-btn-secondary {
    background: transparent;
    color: var(--dp-secondary);
    border: 2px solid var(--dp-secondary);
}
.dp-btn-secondary:hover { background: var(--dp-secondary); color: #fff; }

/* ---- Wykres cen ---- */
.dp-price-chart { max-height: 200px; margin-top: 8px; }

/* ---- Loading ---- */
.dp-loading {
    text-align: center;
    padding: 40px;
    font-size: 16px;
    color: #888;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
    .dp-filters-row { flex-direction: column; }
    .dp-sidebar      { width: 100%; height: 70%; top: auto; bottom: 0; border-left: none; border-top: 1px solid var(--dp-border); }
    .dp-inv-stats    { grid-template-columns: 1fr; }
    .dp-sidebar:not(.dp-sidebar-hidden) { transform: translateY(0); }
    .dp-sidebar-hidden { transform: translateY(100%); }
}

/* ============================================================
   Animowany Ticker RCN
   ============================================================ */
.dp-ticker-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    background: #0d3d22;
    color: #fff;
    height: 40px;
    overflow: hidden;
    font-size: .78rem;
    border-radius: 8px;
    position: relative;
}
.dp-ticker-label {
    flex-shrink: 0;
    padding: 0 14px;
    font-weight: 700;
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    background: #1a6b45;
    height: 100%;
    display: flex;
    align-items: center;
    white-space: nowrap;
    border-right: 1px solid rgba(255,255,255,.15);
}
.dp-ticker-track {
    flex: 1;
    overflow: hidden;
    height: 100%;
    position: relative;
}
.dp-ticker-inner {
    display: flex;
    align-items: center;
    height: 100%;
    white-space: nowrap;
    animation: dp-ticker-scroll linear infinite;
    will-change: transform;
}
.dp-ticker-inner:hover { animation-play-state: paused; }
@keyframes dp-ticker-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.dp-ticker-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 0 16px;
    text-decoration: none;
    color: rgba(255,255,255,.85);
    transition: color .15s;
    white-space: nowrap;
}
.dp-ticker-item:hover { color: #fff; }
.dp-ticker-item strong { color: #fff; font-weight: 700; }
.dp-ticker-item .dp-ticker-type {
    background: rgba(255,255,255,.1);
    padding: 1px 7px;
    border-radius: 4px;
    font-size: .65rem;
    color: rgba(255,255,255,.7);
}
.dp-ticker-item .dp-ticker-price {
    color: #86efac;
    font-weight: 700;
}
.dp-ticker-icon { font-size: .9rem; }
.dp-ticker-sep {
    color: rgba(255,255,255,.2);
    padding: 0 4px;
    font-size: .8rem;
}

@media (max-width: 480px) {
    .dp-ticker-label { display: none; }
    .dp-ticker-item  { padding: 0 10px; }
}

/* ── Alert email form ──────────────────────────────────────── */
.dp-alert-wrap{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:14px;padding:24px 24px 20px;margin:28px 0;}
.dp-alert-title{font-size:1rem;font-weight:800;color:#0d3d22;margin:0 0 4px;display:flex;align-items:center;gap:8px;}
.dp-alert-sub{font-size:.78rem;color:#4b7c5e;margin:0 0 18px;}
.dp-alert-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px;}
.dp-alert-row input,.dp-alert-row select{flex:1;min-width:160px;padding:9px 12px;border:1px solid #bbf7d0;border-radius:8px;font-size:.82rem;font-family:inherit;background:#fff;color:#111;}
.dp-alert-row input:focus,.dp-alert-row select:focus{outline:none;border-color:#1a6b45;}
.dp-alert-submit{width:100%;padding:11px;background:#1a6b45;color:#fff;border:none;border-radius:9px;font-size:.88rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s;margin-top:4px;}
.dp-alert-submit:hover{background:#0d3d22;}
.dp-alert-submit:disabled{opacity:.6;cursor:wait;}
.dp-alert-msg{margin-top:10px;padding:10px 14px;border-radius:8px;font-size:.8rem;font-weight:600;display:none;}
.dp-alert-msg.ok{background:#d1fae5;color:#065f46;display:block;}
.dp-alert-msg.err{background:#fee2e2;color:#991b1b;display:block;}
.dp-alert-privacy{font-size:.62rem;color:#6b7280;margin-top:8px;}

/* ── Wycena nieruchomości [dp_wycena] ── */
.dp-wycena-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:28px 28px 22px;max-width:720px;margin:0 auto;}
.dp-wycena-title{font-size:1.25rem;font-weight:700;color:#111;margin:0 0 4px;}
.dp-wycena-sub{font-size:.8rem;color:#6b7280;margin:0 0 20px;}
.dp-wycena-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px;}
.dp-wycena-field{display:flex;flex-direction:column;flex:1;min-width:160px;gap:5px;}
.dp-wycena-field label{font-size:.75rem;font-weight:600;color:#374151;}
.dp-wycena-field input,.dp-wycena-field select{padding:10px 13px;border:1.5px solid #d1d5db;border-radius:9px;font-size:.88rem;font-family:inherit;background:#f9fafb;color:#111;transition:border .15s;}
.dp-wycena-field input:focus,.dp-wycena-field select:focus{outline:none;border-color:#2563eb;background:#fff;}
.dp-wycena-btn{width:100%;padding:13px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s;}
.dp-wycena-btn:hover{opacity:.9;}
.dp-wycena-btn:disabled{opacity:.55;cursor:wait;}
/* wynik */
.dp-wycena-result{margin-top:22px;border-top:1px solid #f0f0f0;padding-top:18px;}
.dpw-main{text-align:center;margin-bottom:20px;}
.dpw-price-big{font-size:2.4rem;font-weight:800;color:#1d4ed8;line-height:1.1;}
.dpw-price-label{font-size:.8rem;color:#6b7280;margin:4px 0 8px;}
.dpw-range{font-size:.88rem;color:#374151;}
.dpw-stats{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:14px;}
.dpw-stat{flex:1;min-width:140px;background:#f0f7ff;border-radius:10px;padding:12px 10px;text-align:center;}
.dpw-stat-val{display:block;font-size:.95rem;font-weight:700;color:#1e3a8a;}
.dpw-stat-lbl{display:block;font-size:.7rem;color:#6b7280;margin-top:3px;}
.dpw-note{font-size:.7rem;color:#9ca3af;margin:4px 0 0;text-align:center;}
.dp-wycena-error{margin-top:14px;padding:10px 14px;background:#fef2f2;color:#991b1b;border-radius:8px;font-size:.84rem;font-weight:600;}
@media(max-width:600px){.dpw-price-big{font-size:1.8rem;}.dp-wycena-wrap{padding:18px 14px;}}

/* ── Porównywarka ── */
/* Przycisk "Dodaj do porównania" */
.dp-cmp-btn-add{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:#f0f7ff;color:#1e3a8a;border:1.5px solid #bfdbfe;border-radius:7px;font-size:.72rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap;}
.dp-cmp-btn-add:hover{background:#dbeafe;border-color:#93c5fd;}
.dp-cmp-btn-add.dp-cmp-added{background:#dcfce7;color:#15803d;border-color:#86efac;}
/* Floating bar */
#dp-compare-bar{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:#1e293b;color:#fff;padding:10px 20px;display:none;align-items:center;box-shadow:0 -4px 24px rgba(0,0,0,.25);}
.dp-cmp-bar-inner{max-width:1100px;margin:0 auto;width:100%;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.dp-cmp-chips{display:flex;gap:8px;flex-wrap:wrap;flex:1;align-items:center;}
.dp-cmp-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:600;}
.dp-cmp-chip-rm{background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:.75rem;padding:0 0 0 4px;line-height:1;}
.dp-cmp-chip-rm:hover{color:#fff;}
.dp-cmp-hint{font-size:.72rem;color:rgba(255,255,255,.45);font-style:italic;}
.dp-cmp-hint-need{font-size:.72rem;color:rgba(255,255,255,.45);}
.dp-cmp-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;}
.dp-cmp-btn{padding:7px 16px;border:none;border-radius:7px;font-size:.8rem;font-weight:700;cursor:pointer;font-family:inherit;}
.dp-cmp-btn-go{background:#2563eb;color:#fff;}
.dp-cmp-btn-go:hover{background:#1d4ed8;}
.dp-cmp-btn-clear{background:rgba(255,255,255,.1);color:#fff;}
.dp-cmp-btn-clear:hover{background:rgba(255,255,255,.2);}
/* Modal */
#dp-compare-modal{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;padding:20px;}
.dp-cmp-modal-inner{background:#fff;border-radius:18px;width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.3);}
.dp-cmp-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #e5e7eb;}
.dp-cmp-modal-title{font-size:1.05rem;font-weight:800;color:#111;margin:0;}
.dp-cmp-modal-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#6b7280;padding:4px 8px;border-radius:6px;}
.dp-cmp-modal-close:hover{background:#f3f4f6;}
.dp-cmp-table-wrap{overflow:auto;flex:1;}
.dp-cmp-table{width:100%;border-collapse:collapse;font-size:.85rem;}
.dp-cmp-table thead th{background:#f8fafc;padding:14px 16px;text-align:center;border-bottom:2px solid #e5e7eb;min-width:160px;position:relative;vertical-align:top;}
.dp-cmp-table thead th:first-child{min-width:120px;text-align:left;}
.dp-cmp-th-icon{font-size:1.5rem;margin-bottom:4px;}
.dp-cmp-th-msc{font-weight:800;font-size:.88rem;color:#111;}
.dp-cmp-th-title{font-size:.7rem;color:#6b7280;margin-top:2px;}
.dp-cmp-rm-col{position:absolute;top:6px;right:6px;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:.75rem;padding:2px 5px;border-radius:4px;}
.dp-cmp-rm-col:hover{background:#fee2e2;color:#dc2626;}
.dp-cmp-row-label{padding:11px 16px;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:#9ca3af;font-weight:600;background:#fafafa;border-bottom:1px solid #f3f4f6;white-space:nowrap;}
.dp-cmp-cell{padding:11px 16px;text-align:center;border-bottom:1px solid #f3f4f6;font-weight:600;color:#111;}
.dp-cmp-cell.dp-cmp-best{background:#dcfce7;color:#15803d;}
.dp-cmp-cell.dp-cmp-worst{background:#fef2f2;color:#b91c1c;}
.dp-cmp-link{color:#2563eb;text-decoration:none;font-weight:700;font-size:.8rem;}
.dp-cmp-link:hover{text-decoration:underline;}
.dp-cmp-modal-foot{padding:10px 24px;border-top:1px solid #f3f4f6;display:flex;gap:20px;}
.dp-cmp-legend{display:flex;align-items:center;gap:6px;font-size:.72rem;color:#6b7280;}
.dp-cmp-best-dot{width:10px;height:10px;background:#dcfce7;border:1.5px solid #86efac;border-radius:3px;display:inline-block;}
.dp-cmp-worst-dot{width:10px;height:10px;background:#fef2f2;border:1.5px solid #fca5a5;border-radius:3px;display:inline-block;}
/* Toast */
.dp-cmp-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:10px 20px;border-radius:8px;font-size:.82rem;z-index:10000;animation:dp-toast-in .2s ease;}
@keyframes dp-toast-in{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@media(max-width:640px){
  #dp-compare-bar{padding:8px 12px;}
  .dp-cmp-chips{gap:4px;}
  .dp-cmp-modal-inner{border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:80vh;}
  #dp-compare-modal{align-items:flex-end;padding:0;}
}
