/* Auto-generated by scripts/css_mechanical_split.py
   Source: property_list_part_01.css
   Part 1/2 - load order critical.
   Do not reorder or merge without re-running the splitter. */

/* Auto-generated by scripts/css_mechanical_split.py
   Source: property_list.css
   Part 1/3 - load order critical.
   Do not reorder or merge without re-running the splitter. */

.topbar-inner{
    display:grid !important;
    grid-template-columns:auto minmax(0,1fr);
    gap:12px !important;
    align-items:center !important;
  }

  .brand{
    margin-left:18px;
  }

  .portal-col-search input,
  .portal-col-stack select,
  .portal-col-stack input{
    width:100%;
    outline:none;
    font-family:var(--font-body);
    color:var(--ink-strong);
    border:1px solid rgba(var(--brand-rgb), .14);
    background:rgba(255,255,255,.90);
    -webkit-appearance:none;
    appearance:none;
  }

  .portal-col-search input{
    min-height:42px;
    height:42px;
    border-radius:999px;
    padding:0 16px;
    font-size:13px;
  }

  .portal-col-stack{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }

  .portal-col-stack select,
  .portal-col-stack input{
    min-height:36px;
    height:36px;
    border-radius:999px;
    padding:0 12px;
    font-size:12px;
  }

  .portal-col-stack select{
    color:var(--brand-strong);
  }

  .portal-col-actions{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    justify-content:center;
    gap:8px;
    align-self:center;
  }

  .portal-actions-row{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
  }

  .portal-actions-row .btn{
    min-height:40px;
    padding:0 16px;
  }

  .portal-user-chip{
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:0 14px;
    border-radius:999px;
    background:#fff;
    border:1px solid var(--line);
    font-family:var(--font-display);
    font-size:13px;
    font-weight:600;
    color:var(--ink-strong);
    white-space:nowrap;
  }

  .portal-save-row{
    min-height:34px;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    width:100%;
  }

  .portal-save-hint{
    font-family:var(--font-body);
    font-size:12px;
    line-height:1.35;
    color:var(--muted);
    text-align:right;
    max-width:340px;
  }

  .portal-save-row .btn{
    min-height:34px;
    padding:0 14px;
    font-size:12px;
  }

  .portal-list-shell{
    display:grid;
    grid-template-columns:minmax(0,1fr) 580px;
    gap:18px;
    align-items:start;
    overflow:visible !important;
  }

  .portal-results-column{
    min-width:0;
    overflow:visible !important;
  }

  .portal-map-column{
    position:sticky;
    /*
      Offset più generoso per evitare che, durante lo scroll,
      il titolo "Mappa / Posizione annunci" venga tagliato
      o finisca sotto la testata sticky del portale.
    */
    top:calc(var(--topbar-h, 84px) + 34px);
    align-self:start;
    overflow:visible !important;
    scroll-margin-top:calc(var(--topbar-h, 84px) + 34px);
  }

  .portal-map-card{
    padding:18px;
    height:auto;
    max-height:calc(100vh - var(--topbar-h, 84px) - 58px);
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }

  .portal-map-tools{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    margin-bottom:10px;
  }

  .portal-map-tools .btn{
    min-height:38px;
    padding:0 14px;
  }

  .portal-map-hint{
    font-size:12px;
    color:var(--muted);
  }

  .portal-map-popup{
    min-width:220px;
    max-width:260px;
  }

  .portal-map-popup-title{
    font-family:var(--font-display);
    font-size:15px;
    font-weight:700;
    line-height:1.2;
    color:var(--ink-strong);
    margin:0 0 6px 0;
  }

  .portal-map-popup-price{
    font-family:var(--font-display);
    font-size:16px;
    font-weight:700;
    color:var(--ink-strong);
    margin:0 0 4px 0;
  }

  .portal-map-popup-city{
    font-size:12px;
    color:var(--muted);
    margin:0 0 8px 0;
  }

  .portal-map-popup-link{
    display:inline-flex;
    align-items:center;
    min-height:32px;
    padding:0 10px;
    border-radius:999px;
    background:var(--brand);
    color:#fff !important;
    text-decoration:none;
    font-size:12px;
    font-weight:600;
  }

  .portal-map-modal{
    position:fixed;
    inset:0;
    z-index:8000;
    display:none;
    align-items:center;
    justify-content:center;
    padding:24px;
    background:rgba(15,23,42,.52);
    backdrop-filter:blur(6px);
  }

  .portal-map-modal.is-open{
    display:flex;
  }

  .portal-map-modal-card{
    width:min(96vw, 1400px);
    height:min(90vh, 940px);
    background:#fff;
    border-radius:26px;
    box-shadow:0 24px 60px rgba(15,23,42,.22);
    border:1px solid rgba(var(--brand-rgb), .14);
    overflow:hidden;
    display:grid;
    grid-template-rows:auto 1fr;
  }

  .portal-map-modal-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:16px 18px;
    border-bottom:1px solid rgba(var(--brand-rgb), .10);
    background:rgba(255,255,255,.94);
  }

  .portal-map-modal-title{
    font-family:var(--font-display);
    font-size:20px;
    font-weight:700;
    color:var(--ink-strong);
  }

  .portal-map-modal-sub{
    margin-top:4px;
    font-size:12px;
    color:var(--muted);
  }

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

  .portal-map-close{
    min-width:42px;
    min-height:42px;
    padding:0 12px;
  }

  #portalMapModalCanvas{
    width:100%;
    height:100%;
    min-height:560px;
  }

  #portalMap{
    width:100%;
    height:calc(100vh - var(--topbar-h, 84px) - 108px);
    min-height:540px;
    border-radius:20px;
    overflow:hidden;
    flex:1 1 auto;
  }

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

  .portal-view-switch{
    display:flex;
    align-items:center;
    gap:8px;
  }

  .portal-view-switch a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    padding:0 14px;
    border-radius:999px;
    border:1px solid var(--line);
    background:#fff;
    color:var(--ink-strong);
    font-family:var(--font-display);
    font-size:13px;
    font-weight:600;
  }

  .portal-view-switch a.is-active{
    background:var(--brand);
    color:#fff;
    border-color:transparent;
  }

  .portal-results-grid{
    display:grid;
    gap:14px;
  }

  .portal-results-grid.is-card{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .portal-results-grid.is-list{
    grid-template-columns:1fr;
  }

  .portal-result-card{
    overflow:hidden;
    text-decoration:none;
    color:inherit;
    transition:.18s ease;
    border-radius:20px;
  }

  .portal-result-card:hover{
    transform:translateY(-2px);
    box-shadow:var(--shadow-strong);
  }

  .portal-result-card.is-map-active{
    box-shadow:0 0 0 2px rgba(var(--brand-rgb), .24), var(--shadow-strong);
  }

  .portal-mobile-map-toggle{
    display:none;
  }

  @media (max-width: 980px){
    .portal-mobile-map-toggle{
      position:fixed;
      right:16px;
      bottom:16px;
      z-index:1200;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height:46px;
      padding:0 18px;
      border:none;
      border-radius:999px;
      background:var(--brand);
      color:#fff;
      font-family:var(--font-display);
      font-size:13px;
      font-weight:700;
      box-shadow:0 14px 28px rgba(15,23,42,.18);
    }
  }

  .portal-results-grid.is-card .portal-result-card{
    display:block;
  }

  .portal-results-grid.is-list .portal-result-card{
    display:grid;
    grid-template-columns:210px minmax(0,1fr);
    align-items:stretch;
  }

  .portal-result-media{
    background:#e7efe9;
    overflow:hidden;
    position:relative;
  }

  .portal-results-grid.is-card .portal-result-media{
    aspect-ratio:16/10;
  }

