/* ================================================================
   REXVALUE — Lucietti Real Estate Brand System
   Fonts: Cormorant Garamond (Display) · DM Sans (UI) · JetBrains Mono (Data)
   Colors: Navy Midnight #1B2A4A · Warm Gold #C5A55A · Deep Ink #0F1A2E
           Warm Ivory #F7F5F0 · Slate #2D3748 · Steel Blue #8B9BB4 · Ice Mist #D4E4E8
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=DM+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
    /* ── Brand Palette ── */
    --navy:        #1B2A4A;
    --gold:        #C5A55A;
    --gold-dark:   #A8863C;
    --gold-light:  #D4B97A;
    --deep-ink:    #0F1A2E;
    --ivory:       #F7F5F0;
    --ivory-dark:  #EDE9E1;
    --slate:       #2D3748;
    --steel:       #8B9BB4;
    --ice:         #D4E4E8;
    --ice-light:   #EAF2F5;

    /* ── Semantic ── */
    --bg:           #F7F5F0;
    --bg-dark:      #EDE9E1;
    --text:         #2D3748;
    --text-light:   #8B9BB4;
    --text-muted:   #A0AEBF;
    --primary:      #1B2A4A;
    --primary-light: #2D4070;
    --primary-dark:  #0F1A2E;
    --accent:       #C5A55A;
    --border:       #DDD8CF;

    /* ── Status ── */
    --success:  #1E6B4A;
    --warning:  #B5760F;
    --danger:   #B03030;
    --blue:     #1E5A9C;
    --cyan:     #0F6B7A;
    --magenta:  #C5A55A;
    --orange:   #B5760F;

    /* ── Tinted BGs ── */
    --green-bg:   #E6F2EC;
    --blue-bg:    #E2EBF6;
    --magenta-bg: #F5EDD8;
    --orange-bg:  #F8EED8;
    --yellow-bg:  #FAF2DC;
    --cyan-bg:    #E0EFF1;

    --shadow:    0 1px 4px rgba(27,42,74,0.08);
    --shadow-lg: 0 6px 28px rgba(27,42,74,0.13);
    --radius:    10px;
}

/* ── Reset ── */
* { margin:0; padding:0; box-sizing:border-box; }

body {
    font-family: 'DM Sans', sans-serif;
    background: var(--ivory);
    color: var(--slate);
    min-height: 100vh;
    font-size: 13px;
    line-height: 1.6;
}

/* Tipografia per ruolo */
h1,h2,h3,h4 {
    font-family: 'DM Sans', sans-serif;
    font-weight: 700;
    color: var(--navy);
    letter-spacing: -0.01em;
}
.display-title {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 600;
    letter-spacing: 0.04em;
}
/* I numeri KPI usano JetBrains Mono */
.stat-value {
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 500;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-thumb { background: var(--gold-light); border-radius: 3px; }
::-webkit-scrollbar-track { background: var(--ivory-dark); }

a { color: var(--navy); text-decoration: none; }
a:hover { color: var(--gold); }

/* ══════════════════════════════════════════
   LOGIN
══════════════════════════════════════════ */
.login-screen {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
    position: relative;
    overflow: hidden;
}
.login-screen::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 50% at 50% 120%, rgba(255,255,255,0.08) 0%, transparent 60%);
}
.login-screen.agente     { background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); }
.login-screen.segnalatore{ background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%); }

.login-container { width:100%; max-width:400px; padding:24px; position:relative; z-index:1; }

.login-logo { text-align:center; margin-bottom:32px; }
.logo-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.1rem;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    display: block;
}
.login-logo .logo-sub {
    color: var(--gold);
    font-size: 0.62rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    font-family: 'DM Sans', sans-serif;
    font-weight: 500;
    display: block;
    margin-top: 5px;
}
.login-logo-line {
    width: 36px; height: 1px;
    background: var(--gold);
    margin: 10px auto 0;
    opacity: 0.55;
}

.login-box {
    background: #fff;
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.25);
    border: none;
}
.login-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 22px;
    text-align: center;
    color: var(--navy);
    letter-spacing: 0.03em;
}
.login-links { text-align:center; margin-top:22px; }
.login-links a { color:rgba(255,255,255,0.6); font-size:0.72rem; margin:0 10px; letter-spacing:0.04em; }
.login-links a:hover { color: var(--gold); }

/* ══════════════════════════════════════════
   FORMS
══════════════════════════════════════════ */
.form-group { margin-bottom:14px; }
.form-group label {
    display:block;
    font-size:0.6rem;
    color: var(--steel);
    margin-bottom:5px;
    text-transform:uppercase;
    letter-spacing:0.09em;
    font-weight:700;
}
.form-input, .form-select, .form-textarea {
    width:100%;
    padding:9px 12px;
    background: var(--ivory);
    border:1px solid var(--border);
    border-radius: var(--radius);
    color: var(--slate);
    font-family:'DM Sans',sans-serif;
    font-size:0.85rem;
    transition:all 0.2s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline:none;
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(197,165,90,0.14);
    background: #fff;
}
.form-select {
    cursor:pointer; appearance:none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238B9BB4' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 10px center; padding-right:30px;
}
.form-textarea { min-height:70px; resize:vertical; }
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
.form-row-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.form-section {
    font-size:0.6rem; font-weight:700; color: var(--gold-dark);
    text-transform:uppercase; letter-spacing:0.1em;
    margin:18px 0 10px; padding-bottom:6px;
    border-bottom:1px solid var(--gold-light);
}
.form-hint { font-size:0.64rem; color: var(--text-muted); margin-top:4px; }

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:5px;
    padding:8px 16px;
    font-family:'DM Sans',sans-serif; font-size:0.74rem; font-weight:600;
    border-radius: var(--radius); cursor:pointer; transition:all 0.2s; border:none;
    letter-spacing:0.02em;
}
.btn-primary   { background:var(--navy);    color:#fff; box-shadow:0 2px 8px rgba(27,42,74,0.22); }
.btn-primary:hover   { background:var(--deep-ink); box-shadow:0 4px 16px rgba(27,42,74,0.32); }
.btn-accent    { background:var(--gold);    color:var(--deep-ink); box-shadow:0 2px 8px rgba(197,165,90,0.28); }
.btn-accent:hover    { background:var(--gold-dark); }
.btn-secondary { background:#fff; border:1px solid var(--border); color:var(--slate); }
.btn-secondary:hover { border-color:var(--gold); color:var(--navy); }
.btn-success   { background:var(--success); color:#fff; }
.btn-success:hover   { filter:brightness(1.1); }
.btn-danger    { background:var(--danger);  color:#fff; }
.btn-danger:hover    { filter:brightness(1.1); }
.btn-blue      { background:var(--blue);    color:#fff; }
.btn-blue:hover      { filter:brightness(1.1); }
.btn-cyan      { background:var(--cyan);    color:#fff; }
.btn-cyan:hover      { filter:brightness(1.1); }
.btn-warning   { background:var(--warning); color:#fff; }
.btn-warning:hover   { filter:brightness(1.1); }
.btn-sm   { padding:5px 10px; font-size:0.68rem; }
.btn-full { width:100%; }
.btn svg  { width:14px; height:14px; }

/* ══════════════════════════════════════════
   LAYOUT — SIDEBAR + MAIN
══════════════════════════════════════════ */
.dashboard { display:none; min-height:100vh; }
.dashboard.active { display:flex; }

.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(15,26,46,0.55); z-index:99; }
.sidebar-overlay.active { display:block; }

.sidebar {
    width:240px;
    background: var(--deep-ink);
    height:100vh; position:fixed; left:0; top:0;
    display:flex; flex-direction:column;
    z-index:100; transition:transform 0.3s;
    border-right:1px solid rgba(197,165,90,0.12);
    overflow: hidden; /* sidebar itself doesn't scroll */
}

.sidebar-header { 
    padding:20px 16px 16px; 
    border-bottom:1px solid rgba(197,165,90,0.12);
    flex-shrink: 0; /* NEVER shrink or scroll — always pinned at top */
    background: var(--deep-ink);
    z-index: 2;
}

.sidebar-nav { flex:1; padding:14px 8px; overflow-y:auto; min-height:0; }

.sidebar-footer { 
    padding:12px 8px; 
    border-top:1px solid rgba(197,165,90,0.1);
    flex-shrink: 0; /* footer also pinned at bottom */
    background: var(--deep-ink);
}
.sidebar-header .logo-text {
    font-family:'Cormorant Garamond',serif;
    font-size:1.3rem; color:#fff;
    letter-spacing:0.1em; text-transform:uppercase;
    display:block;
}
.sidebar-header .logo-sub {
    font-size:0.52rem; color:var(--gold);
    letter-spacing:0.22em; text-transform:uppercase;
    margin-top:2px; display:block;
    font-family:'DM Sans',sans-serif; font-weight:500;
}
.sidebar-user {
    margin-top:12px; padding:10px 12px;
    background:rgba(197,165,90,0.08);
    border-radius:8px; border:1px solid rgba(197,165,90,0.14);
}
.sidebar-user-name  { font-weight:600; font-size:0.85rem; color:#fff; }
.sidebar-user-role  {
    font-size:0.57rem; text-transform:uppercase;
    letter-spacing:0.08em; margin-top:2px;
    color:var(--gold); font-weight:500;
}
.sidebar-user-role.admin      { color:var(--gold); }
.sidebar-user-role.agente     { color:var(--ice); }
.sidebar-user-role.segnalatore{ color:var(--ice); }

.nav-section { margin-bottom:20px; }
.nav-section-title {
    font-size:0.53rem; color:rgba(139,155,180,0.65);
    text-transform:uppercase; letter-spacing:0.13em;
    padding:0 10px; margin-bottom:6px; font-weight:700;
}
.nav-item {
    display:flex; align-items:center; gap:9px;
    padding:9px 12px; color:rgba(212,228,232,0.65);
    border-radius:8px; cursor:pointer;
    font-size:0.78rem; transition:all 0.2s; margin-bottom:2px; font-weight:400;
}
.nav-item svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.5; flex-shrink:0; }
.nav-item:hover { background:rgba(255,255,255,0.06); color:#fff; }
.nav-item.active {
    background:rgba(197,165,90,0.14);
    color:var(--gold); font-weight:600;
    border-left:2px solid var(--gold); padding-left:10px;
}
.nav-item.active.agente     { color:var(--ice); border-left-color:var(--ice); background:rgba(212,228,232,0.1); }
.nav-item.active.segnalatore{ color:var(--ice); border-left-color:var(--ice); background:rgba(212,228,232,0.1); }
.nav-badge {
    background:var(--danger); color:#fff;
    font-size:0.54rem; padding:2px 6px; border-radius:10px; margin-left:auto;
    font-family:'JetBrains Mono',monospace;
}
.logout-btn { width:100%; justify-content:flex-start; gap:8px; color:rgba(212,228,232,0.55); background:transparent; border:none; }
.logout-btn:hover { color:#fff; background:rgba(255,255,255,0.05); }

/* ══════════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════════ */
/* ── ROOT: html/body non scrollano, main-content scrolla ── */
html, body {
    height: 100%;
    overflow: hidden; /* body non scrolla mai */
}

.dashboard {
    height: 100%;
    overflow: clip;
}

.main-content {
    flex: 1;
    margin-left: 240px;
    height: 100vh;
    overflow-y: auto;          /* SOLO main-content scrolla */
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

.content-header {
    padding: 14px 24px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    position: sticky;
    top: 0;                    /* sticky dentro main-content che scrolla */
    background: rgba(247,245,240,0.98);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 200;
}
.content-header h1 {
    font-size:1rem; font-family:'DM Sans',sans-serif;
    font-weight:700; color:var(--navy); letter-spacing:-0.01em;
}
.header-actions { display:flex; gap:8px; }
.content-body { padding:20px 24px; max-width:1400px; }

/* ══════════════════════════════════════════
   STAT CARDS
══════════════════════════════════════════ */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:14px; margin-bottom:20px; }
.stat-card {
    background:#fff; border:1px solid var(--border);
    border-radius:12px; padding:16px;
    box-shadow:var(--shadow); transition:transform 0.2s,box-shadow 0.2s;
}
.stat-card:hover { transform:translateY(-1px); box-shadow:var(--shadow-lg); }
.stat-card.green  { border-left:3px solid var(--success); background:linear-gradient(135deg,#fff 55%,var(--green-bg)); }
.stat-card.blue   { border-left:3px solid var(--blue);    background:linear-gradient(135deg,#fff 55%,var(--blue-bg));  }
.stat-card.magenta{ border-left:3px solid var(--gold);    background:linear-gradient(135deg,#fff 55%,var(--magenta-bg));}
.stat-card.orange { border-left:3px solid var(--warning); background:linear-gradient(135deg,#fff 55%,var(--orange-bg));}
.stat-card.yellow { border-left:3px solid var(--warning); background:linear-gradient(135deg,#fff 55%,var(--yellow-bg));}
.stat-card.cyan   { border-left:3px solid var(--cyan);    background:linear-gradient(135deg,#fff 55%,var(--cyan-bg));  }

.stat-label {
    font-size:0.6rem; color:var(--steel);
    text-transform:uppercase; letter-spacing:0.08em;
    margin-bottom:6px; font-weight:700;
}
.stat-value {
    font-family:'JetBrains Mono',monospace !important;
    font-size:1.35rem; font-weight:500;
    color:var(--navy); line-height:1.2;
}
.stat-value.green  { color:var(--success); }
.stat-value.red    { color:var(--danger);  }
.stat-value.blue   { color:var(--blue);    }
.stat-value.magenta{ color:var(--gold-dark);}
.stat-value.orange { color:var(--warning); }
.stat-value.cyan   { color:var(--cyan);    }
.stat-sub { font-size:0.63rem; color:var(--text-muted); margin-top:5px; }

/* ══════════════════════════════════════════
   CARDS
══════════════════════════════════════════ */
.card {
    background:#fff; border:1px solid var(--border);
    border-radius:12px; margin-bottom:16px;
    box-shadow:var(--shadow); overflow:hidden;
}
.card-header {
    padding:13px 16px; border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
    gap:10px; flex-wrap:wrap; background:var(--ivory);
}
.card-header h3 { font-size:0.85rem; font-weight:700; color:var(--navy); }
.card-header.green  { background:var(--green-bg);   border-left:3px solid var(--success); }
.card-header.blue   { background:var(--blue-bg);    border-left:3px solid var(--blue);    }
.card-header.magenta{ background:var(--magenta-bg); border-left:3px solid var(--gold);    }
.card-header.orange { background:var(--orange-bg);  border-left:3px solid var(--warning); }
.card-header.cyan   { background:var(--cyan-bg);    border-left:3px solid var(--cyan);    }
.card-body         { padding:16px; }
.card-body.compact { padding:12px; }

/* ══════════════════════════════════════════
   TABLES
══════════════════════════════════════════ */
.table-wrapper { overflow-x:auto; }
.table { width:100%; border-collapse:collapse; font-size:0.8rem; }
.table th, .table td { padding:10px 12px; text-align:left; border-bottom:1px solid var(--border); vertical-align:middle; }
.table th {
    font-size:0.59rem; color:var(--steel);
    text-transform:uppercase; letter-spacing:0.08em; font-weight:700;
    background:var(--ivory); white-space:nowrap;
}
.table tbody tr:hover { background:var(--ivory); }
.table tbody tr:last-child td { border-bottom:none; }
/* Numeri in tabella → Mono */
.table td strong { font-family:'JetBrains Mono',monospace; font-weight:500; font-size:0.78rem; }

/* ══════════════════════════════════════════
   STATUS BADGES
══════════════════════════════════════════ */
.status {
    display:inline-flex; align-items:center; gap:5px;
    padding:3px 8px; border-radius:20px;
    font-size:0.6rem; font-weight:700;
    text-transform:uppercase; letter-spacing:0.04em;
}
.status-dot { width:5px; height:5px; border-radius:50%; }
.status-success  { background:var(--green-bg);             color:var(--success); }
.status-success  .status-dot { background:var(--success); }
.status-warning  { background:var(--yellow-bg);            color:var(--warning); }
.status-warning  .status-dot { background:var(--warning); }
.status-danger   { background:rgba(176,48,48,0.1);         color:var(--danger);  }
.status-danger   .status-dot { background:var(--danger);  }
.status-info     { background:var(--blue-bg);              color:var(--blue);    }
.status-info     .status-dot { background:var(--blue);    }
.status-gray     { background:var(--ivory-dark);           color:var(--steel);   }
.status-gray     .status-dot { background:var(--steel);   }
.status-magenta  { background:var(--magenta-bg);           color:var(--gold-dark);}
.status-magenta  .status-dot { background:var(--gold);    }
.status-cyan     { background:var(--cyan-bg);              color:var(--cyan);    }
.status-cyan     .status-dot { background:var(--cyan);    }

/* ══════════════════════════════════════════
   ACTION BUTTONS
══════════════════════════════════════════ */
.action-btn {
    width:28px; height:28px;
    background:var(--ivory); border:1px solid var(--border); border-radius:6px;
    color:var(--steel); cursor:pointer;
    display:inline-flex; align-items:center; justify-content:center;
    transition:all 0.2s; font-size:0.75rem; vertical-align:middle;
}
.action-btn:hover { border-color:var(--gold); color:var(--navy); background:var(--magenta-bg); }
.actions-cell { white-space:nowrap; }
.actions-cell .action-btn { margin-right:4px; }
.actions-cell .action-btn:last-child { margin-right:0; }

/* ══════════════════════════════════════════
   MODAL
══════════════════════════════════════════ */
.modal-overlay {
    position:fixed; inset:0; background:rgba(15,26,46,0.6);
    display:none; align-items:center; justify-content:center;
    z-index:1000; padding:16px; backdrop-filter:blur(4px);
}
.modal-overlay.active { display:flex; }
.modal {
    background:#fff; border-radius:14px; width:100%;
    max-width:580px; max-height:90vh; overflow-y:auto; -webkit-overflow-scrolling:touch;
    box-shadow:0 20px 60px rgba(15,26,46,0.28);
    border:1px solid rgba(197,165,90,0.15);
}
.modal-header {
    padding:14px 18px; border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
    position:sticky; top:0; background:var(--ivory); z-index:10;
}
.modal-header h3 { font-size:0.95rem; color:var(--navy); }
.modal-close {
    width:28px; height:28px; background:var(--ivory-dark);
    border:none; border-radius:6px; color:var(--steel); cursor:pointer;
    display:flex; align-items:center; justify-content:center; font-size:1rem; transition:all 0.2s;
}
.modal-close:hover { background:rgba(176,48,48,0.1); color:var(--danger); }
.modal-body { padding:18px; }
.modal-footer {
    padding:14px 18px; border-top:1px solid var(--border);
    display:flex; gap:10px; justify-content:flex-end; background:var(--ivory);
}

/* ══════════════════════════════════════════
   TABS
══════════════════════════════════════════ */
.tabs { display:flex; gap:5px; margin-bottom:14px; flex-wrap:wrap; }
.tab-btn {
    padding:6px 14px;
    background:#fff; border:1px solid var(--border); border-radius:20px;
    color:var(--steel); font-size:0.69rem; cursor:pointer;
    transition:all 0.2s; font-weight:600; letter-spacing:0.03em;
}
.tab-btn:hover { border-color:var(--gold); color:var(--navy); }
.tab-btn.active { background:var(--navy); border-color:var(--navy); color:#fff; }
.tab-btn.active.agente     { background:var(--navy); }
.tab-btn.active.segnalatore{ background:var(--navy); }

/* ══════════════════════════════════════════
   SECTION HEADERS
══════════════════════════════════════════ */
.section-header {
    display:flex; align-items:center; gap:10px;
    margin-bottom:14px; padding:10px 14px; border-radius:var(--radius);
}
.section-header.green  { background:var(--green-bg);   border-left:3px solid var(--success); }
.section-header.blue   { background:var(--blue-bg);    border-left:3px solid var(--blue);    }
.section-header.magenta{ background:var(--magenta-bg); border-left:3px solid var(--gold);    }
.section-header.orange { background:var(--orange-bg);  border-left:3px solid var(--warning); }
.section-header.cyan   { background:var(--cyan-bg);    border-left:3px solid var(--cyan);    }
.section-header h2 { font-size:0.85rem; }

/* ══════════════════════════════════════════
   SUMMARY / INFO BOX
══════════════════════════════════════════ */
.summary-box { background:var(--ivory); border-radius:var(--radius); padding:14px; }
.summary-row {
    display:flex; justify-content:space-between; align-items:center;
    padding:6px 0; border-bottom:1px solid var(--border); font-size:0.8rem;
}
.summary-row:last-child { border-bottom:none; }
.summary-row.total {
    font-weight:700; font-size:0.9rem; color:var(--navy);
    border-top:2px solid var(--gold); margin-top:8px; padding-top:10px; border-bottom:none;
}
.info-box  { background:var(--ivory); border-radius:var(--radius); padding:12px; margin-bottom:10px; }
.info-row  { display:flex; justify-content:space-between; padding:4px 0; font-size:0.8rem; }
.info-label{ color:var(--steel); }
.info-value{ font-weight:600; color:var(--navy); }

/* ══════════════════════════════════════════
   TAGS
══════════════════════════════════════════ */
.tag {
    display:inline-flex; padding:3px 9px;
    background:var(--ivory-dark); border-radius:20px;
    font-size:0.6rem; color:var(--steel); margin:2px; font-weight:600; letter-spacing:0.03em;
}
.tag.primary { background:rgba(27,42,74,0.1);  color:var(--navy); }
.tag.success { background:var(--green-bg);      color:var(--success); }
.tag.warning { background:var(--yellow-bg);     color:var(--warning); }
.tag.blue    { background:var(--blue-bg);       color:var(--blue); }
.tag.cyan    { background:var(--cyan-bg);       color:var(--cyan); }
.tag.gold    { background:var(--magenta-bg);    color:var(--gold-dark); }

/* ══════════════════════════════════════════
   GRID / FILTERS / TOAST / MISC
══════════════════════════════════════════ */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }

.filters-bar {
    display:flex; gap:10px; flex-wrap:wrap;
    margin-bottom:16px; padding:12px 14px;
    background:#fff; border:1px solid var(--border); border-radius:var(--radius);
}
.filters-row { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; align-items:center; }
.filter-group { display:flex; flex-direction:column; gap:4px; }
.filter-group label { font-size:0.57rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.07em; font-weight:700; }
.filter-group select { padding:6px 10px; font-size:0.75rem; min-width:140px; }

.toast-container { position:fixed; bottom:20px; right:20px; z-index:2000; }
.toast {
    background:#fff; border:1px solid var(--border); border-radius:var(--radius);
    padding:12px 16px; display:flex; align-items:center; gap:10px;
    margin-top:10px; box-shadow:var(--shadow-lg);
    animation:slideIn 0.3s ease; font-size:0.8rem; min-width:260px;
}
@keyframes slideIn { from{transform:translateX(100%);opacity:0} to{transform:translateX(0);opacity:1} }
.toast.success { border-left:3px solid var(--success); }
.toast.error   { border-left:3px solid var(--danger);  }
.toast.info    { border-left:3px solid var(--gold);    }

.empty-state { text-align:center; padding:48px 20px; color:var(--text-muted); }
.empty-state svg { width:48px; height:48px; margin-bottom:12px; opacity:0.3; }
.empty-state p { font-size:0.85rem; }

.checkbox-group { display:flex; flex-wrap:wrap; gap:8px; padding:10px; background:var(--ivory); border-radius:8px; }
.checkbox-group.zones-group { max-height:150px; overflow-y:auto; }
.checkbox-label {
    display:flex; align-items:center; gap:6px;
    padding:4px 10px; background:#fff; border:1px solid var(--border);
    border-radius:6px; font-size:0.75rem; cursor:pointer; transition:all 0.2s;
}
.checkbox-label:hover { border-color:var(--gold); }
.checkbox-label input[type="checkbox"] { width:13px; height:13px; accent-color:var(--navy); }
.checkbox-label:has(input:checked) { color:var(--navy); font-weight:600; }

.flag-pagato {
    display:inline-flex; align-items:center; gap:4px;
    padding:3px 9px; border-radius:6px;
    font-size:0.67rem; font-weight:700;
}
.flag-pagato.si { background:var(--green-bg); color:var(--success); }
.flag-pagato.no { background:rgba(176,48,48,0.08); color:var(--danger); }

/* ══════════════════════════════════════════
   DUBAI ZONES
══════════════════════════════════════════ */
.dubai-zones-map { background:linear-gradient(135deg,var(--ice-light),var(--ice)); border-radius:16px; padding:20px; }
.zone-area { background:#fff; border-radius:10px; padding:14px; margin-bottom:12px; box-shadow:var(--shadow); border-left:3px solid var(--gold); }
.zone-area:last-child { margin-bottom:0; }
.zone-area[data-area="beach"]        { border-left-color:var(--cyan);    }
.zone-area[data-area="downtown"]     { border-left-color:var(--navy);    }
.zone-area[data-area="new"]          { border-left-color:var(--gold);    }
.zone-area[data-area="communities"]  { border-left-color:var(--success); }
.zone-area[data-area="premium"]      { border-left-color:var(--gold-dark);}
.zone-area[data-area="traditional"]  { border-left-color:var(--steel);   }
.zone-area-title { font-size:0.72rem; font-weight:700; color:var(--navy); letter-spacing:0.04em; margin-bottom:10px; }
.zone-buttons { display:flex; flex-wrap:wrap; gap:8px; }
.zone-btn {
    display:inline-flex; align-items:center; padding:7px 14px;
    background:var(--ivory); border:1px solid var(--border); border-radius:20px;
    font-size:0.75rem; font-weight:500; cursor:pointer; transition:all 0.2s;
}
.zone-btn:hover { border-color:var(--gold); background:#fff; transform:translateY(-1px); }
.zone-btn.selected, .zone-btn:has(input:checked) {
    background:var(--navy); border-color:var(--navy); color:#fff;
    box-shadow:0 4px 12px rgba(27,42,74,0.22);
}
.zone-btn input[type="checkbox"] { display:none; }

.dubai-map-visual { position:relative; background:linear-gradient(180deg,#bfdbfe 0%,#93c5fd 100%); border-radius:16px; padding:20px; margin-bottom:16px; min-height:300px; overflow:hidden; }
.dubai-map-visual::before { content:''; position:absolute; top:0; right:0; width:70%; height:100%; background:linear-gradient(135deg,#fef3c7 0%,#fde68a 50%,#d4d4d4 100%); clip-path:polygon(30% 0,100% 0,100% 100%,0% 100%); }
.dubai-map-visual .sea-label { position:absolute; left:20px; bottom:20px; color:#1d4ed8; font-size:0.7rem; font-weight:600; opacity:0.7; }
.map-zones-container { position:relative; z-index:1; display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.map-zone-item {
    background:rgba(255,255,255,0.95); border-radius:10px; padding:10px 14px;
    font-size:0.75rem; font-weight:600; cursor:pointer; transition:all 0.2s;
    border:2px solid transparent; text-align:center; box-shadow:0 2px 8px rgba(0,0,0,0.08);
}
.map-zone-item:hover { transform:scale(1.05); }
.map-zone-item.selected { background:var(--navy); color:#fff; border-color:var(--deep-ink); }
.map-zone-item.beach     { border-left:3px solid var(--cyan);   }
.map-zone-item.downtown  { border-left:3px solid var(--navy);   }
.map-zone-item.new       { border-left:3px solid var(--gold);   }
.map-zone-item.community { border-left:3px solid var(--success);}
.map-zone-item.premium   { border-left:3px solid var(--gold-dark);}

/* ══════════════════════════════════════════
   CURRENCY SELECTOR
══════════════════════════════════════════ */
.currency-selector {
    padding:10px 12px; background:rgba(197,165,90,0.06); border-radius:8px;
    margin-bottom:12px; border:1px solid rgba(197,165,90,0.18);
}
.currency-selector label { display:block; font-size:0.64rem; font-weight:700; color:var(--steel); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.06em; }
.currency-selector select { width:100%; padding:7px 10px; border:1px solid var(--border); border-radius:6px; font-size:0.8rem; background:#fff; cursor:pointer; }

/* ══════════════════════════════════════════
   MOBILE
══════════════════════════════════════════ */
.mobile-menu-btn {
    display:none; width:36px; height:36px;
    background:#fff; border:1px solid var(--border); border-radius:8px;
    color:var(--slate); cursor:pointer; align-items:center; justify-content:center;
}
.mobile-menu-btn svg { width:20px; height:20px; stroke:currentColor; fill:none; }

@media (max-width:1024px) {
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .main-content { margin-left:0; }
    .mobile-menu-btn { display:flex; }
    .form-row,.form-row-3,.form-row-4 { grid-template-columns:1fr; }
    .grid-2,.grid-3 { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .filters-bar { flex-direction:column; }
    .filter-group select { width:100%; }
}

/* ═══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — NO HORIZONTAL SCROLL — NO ZOOM
   Tutte le sezioni: admin, agente, segnalatore
   Breakpoint principale: ≤768px (mobile + tablet piccolo)
═══════════════════════════════════════════════════════════ */

/* Previeni overflow orizzontale globalmente */
html, body {
    overflow-x: hidden;
    max-width: 100vw;
}

* {
    max-width: 100%;
}

/* Safe area per notch iPhone/Android PWA */
body {
    padding-top: 0;
}

.dashboard {
    overflow: clip; /* clip only, doesn't break sticky */
}

/* (content-header sticky already defined globally) */

/* ── MOBILE: ≤768px ─────────────────────────────────────── */
@media (max-width: 768px) {

    /* Layout */
    html, body { overflow: hidden !important; height: 100% !important; }

    .main-content {
        margin-left: 0;
        height: 100vh;
        overflow-y: auto !important;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }

    .content-body {
        padding: 10px 10px 80px 10px;
        overflow-x: hidden;
    }

    .content-header {
        padding: 10px 12px;
        position: sticky !important;
        top: 0 !important;
        z-index: 200 !important;
        background: rgba(247,245,240,0.98) !important;
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
    }

    .content-header h1 { font-size: 0.95rem; }

    /* Sidebar */
    .sidebar {
        padding-top: max(12px, env(safe-area-inset-top, 0px));
        padding-bottom: max(12px, env(safe-area-inset-bottom, 0px));
    }

    .sidebar-footer {
        padding-bottom: max(12px, env(safe-area-inset-bottom, 0px));
    }

    /* Cards */
    .card { border-radius: 8px; margin-bottom: 10px; }
    .card-header { padding: 10px 12px; }
    .card-header h3 { font-size: 0.82rem; }
    .card-body { padding: 10px 12px; }
    .card-body.compact { padding: 6px 10px; }

    /* Stats grid — sempre 2 colonne */
    .stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .stat-card { padding: 10px 10px; }
    .stat-label { font-size: 0.6rem; }
    .stat-value { font-size: 0.95rem; }
    .stat-sub { font-size: 0.6rem; }

    /* Grid → 1 colonna */
    .grid-2, .grid-3 { grid-template-columns: 1fr; }
    .form-row, .form-row-3, .form-row-4 { grid-template-columns: 1fr; gap: 8px; }

    /* Filtri → verticali */
    .filters-row {
        flex-direction: column !important;
        gap: 6px !important;
        align-items: stretch !important;
    }
    .filters-row input,
    .filters-row select {
        max-width: 100% !important;
        width: 100% !important;
        min-width: 0 !important;
    }

    /* ══ TABELLE → CARD VERTICALI ══
       Le tabelle .table diventano liste di card su mobile.
       Ogni <tr> diventa una card, ogni <td> mostra la label dall'header.
    */
    .table-wrapper {
        overflow: hidden !important;
        overflow-x: hidden !important;
        margin: 0;
    }

    .table {
        min-width: 0 !important;
        width: 100% !important;
        border-collapse: collapse;
        font-size: 0.78rem;
    }

    /* Nascondi thead — i label vengono dai data-label */
    .table thead { display: none; }

    /* Ogni riga diventa una card */
    .table tbody tr {
        display: block;
        background: #fff;
        border: 1px solid var(--border);
        border-radius: 8px;
        margin-bottom: 8px;
        padding: 10px 12px;
        box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    }
    .table tbody tr:hover { background: #fff; }

    /* Ogni cella diventa una riga con label */
    .table tbody td {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        padding: 4px 0;
        border: none;
        font-size: 0.78rem;
        gap: 8px;
    }

    /* Label della colonna (da data-label o prima parola visibile) */
    .table tbody td::before {
        content: attr(data-label);
        font-size: 0.65rem;
        font-weight: 600;
        color: var(--text-muted);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        white-space: nowrap;
        min-width: 80px;
        flex-shrink: 0;
    }

    /* Celle azioni — full width */
    .table tbody td.actions-cell {
        justify-content: flex-end;
        border-top: 1px solid var(--border);
        margin-top: 4px;
        padding-top: 8px;
        flex-wrap: wrap;
        gap: 6px;
    }
    .table tbody td.actions-cell::before { display: none; }

    /* Righe subtotale (header persona) → card intestazione */
    .table tbody tr[style*="background:#f0f9ff"],
    .table tbody tr[style*="background:#f0f4ff"] {
        background: var(--navy) !important;
        color: #fff;
        border-color: var(--navy);
    }
    .table tbody tr[style*="background:#f0f9ff"] td,
    .table tbody tr[style*="background:#f0f4ff"] td {
        color: #fff;
        flex-direction: column;
    }

    /* Bottoni action più grandi su mobile */
    .action-btn {
        width: 32px;
        height: 32px;
        font-size: 0.9rem;
        border-radius: 6px;
    }

    /* btn-sm → dimensione adeguata al touch */
    .btn { font-size: 0.78rem; padding: 8px 12px; }
    .btn-sm { font-size: 0.72rem; padding: 6px 10px; }

    /* Tabs → scroll orizzontale interno senza overflow pagina */
    .tabs {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
        overflow: visible;
    }
    .tab-btn { padding: 5px 8px; font-size: 0.63rem; }

    /* Form inputs */
    .form-input, .form-select { font-size: 0.82rem; padding: 8px 10px; }
    .form-group label { font-size: 0.73rem; }

    /* Info boxes */
    .info-box { font-size: 0.8rem; }
    .info-row { flex-direction: column; gap: 1px; padding: 5px 0; }
    .info-label { font-size: 0.68rem; color: var(--text-muted); }
    .info-value { font-size: 0.82rem; font-weight: 600; }

    /* Summary */
    .summary-row { font-size: 0.78rem; }

    /* Modal */
    .modal {
        margin: 8px;
        max-height: calc(100dvh - env(safe-area-inset-top, 0px) - 16px);
        border-radius: 12px;
        overflow-y: auto;
    }
    .modal-body { padding: 12px; }
    .modal-footer { padding: 10px 12px; gap: 8px; }
    .modal-footer .btn { flex: 1; }
    .modal-header { padding: 12px 14px; }

    /* Header actions → comprimi */
    .header-actions { gap: 4px; }
    .header-actions .btn { padding: 6px 8px; font-size: 0.7rem; }

    /* Login */
    .login-container { padding: 0 14px; }
    .login-box { padding: 20px 16px; }
    .login-title { font-size: 1.2rem; }

    /* Nav badge */
    .nav-badge { font-size: 0.58rem; padding: 1px 5px; }

    /* Flag pagato */
    .flag-pagato { font-size: 0.65rem; padding: 2px 6px; }

    /* Accordion bottone */
    button[onclick*="nextElementSibling"] {
        font-size: 0.78rem !important;
        padding: 8px 12px !important;
    }

    /* Sezione albero agenti/segnalatori */
    [style*="border-left:3px solid"] {
        margin-left: 8px !important;
    }
    [style*="margin-left:20px"],
    [style*="margin-left:24px"],
    [style*="margin-left:32px"],
    [style*="margin-left:40px"] {
        margin-left: 8px !important;
    }

    /* Stat cards span-2 → full width */
    .stat-card[style*="grid-column:span 2"] {
        grid-column: span 1 !important;
    }
}

/* ── PICCOLI (≤480px) ──────────────────────────────────── */
@media (max-width: 480px) {

    .content-body { padding: 8px 8px 72px 8px; }

    .stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 6px;
    }

    .stat-card { padding: 8px 10px; }
    .stat-value { font-size: 0.9rem; }

    .card-header h3 { font-size: 0.78rem; }
    .card-body { padding: 8px 10px; }

    .table tbody tr { padding: 8px 10px; }
    .table tbody td { font-size: 0.74rem; }
    .table tbody td::before { font-size: 0.62rem; min-width: 70px; }

    .btn { font-size: 0.74rem; padding: 7px 10px; }
    .btn-sm { font-size: 0.68rem; padding: 5px 8px; }

    .modal { margin: 4px; }
}

/* ── MOLTO PICCOLI (≤360px) ────────────────────────────── */
@media (max-width: 360px) {

    .content-body { padding: 6px 6px 64px 6px; }

    .stats-grid { grid-template-columns: 1fr 1fr; gap: 5px; }

    .stat-value { font-size: 0.85rem; }
    .stat-label { font-size: 0.55rem; }

    .card-header h3 { font-size: 0.74rem; }

    .tabs { gap: 3px; }
    .tab-btn { padding: 4px 6px; font-size: 0.58rem; }
}

/* SVG MAP ZONES */
.multi-select-dropdown { position:relative; }
.multi-select-dropdown .multi-select-display { min-height:38px; }
.map-zone-svg,.map-zone-cliente { transition:all 0.2s ease; opacity:0.85; }
.map-zone-svg:hover,.map-zone-cliente:hover { opacity:1; transform:scale(1.05); filter:brightness(1.1); }
.map-zone-svg.selected rect,.map-zone-svg.selected ellipse,
.map-zone-cliente.selected rect,.map-zone-cliente.selected ellipse { stroke-width:4; filter:drop-shadow(0 0 8px rgba(197,165,90,0.5)); }
.map-zone-svg.selected,.map-zone-cliente.selected { opacity:1; }
