:root{
    --bg:#f4f6f8;
    --card:#ffffff;
    --text:#1f2937;
    --muted:#6b7280;
    --primary:#2563eb;
    --primary-hover:#1d4ed8;
    --success:#16a34a;
    --warning:#facc15;
    --danger:#dc2626;
    --info:#0ea5e9;
    --border:#e5e7eb;
    --radius:16px;
    --shadow:0 8px 24px rgba(15,23,42,.07);
}

*{box-sizing:border-box}

body{
    margin:0;
    font-family:Arial,sans-serif;
    background:var(--bg);
    color:var(--text);
}

a{
    color:inherit;
    text-decoration:none;
}

.wrap{
    max-width:1400px;
    margin:auto;
    padding:18px;
}

.card,
.box,
.header{
    background:var(--card);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:18px;
    margin-bottom:16px;
}

.muted{
    color:var(--muted);
    font-size:14px;
}

.btn,
button{
    background:var(--primary);
    color:#fff;
    padding:10px 14px;
    border-radius:10px;
    border:0;
    cursor:pointer;
}

input,select,textarea{
    width:100%;
    padding:11px;
    border:1px solid var(--border);
    border-radius:10px;
    background:#fff;
    margin-top:6px;
}

label{
    display:block;
    margin-top:12px;
    font-weight:600;
}

/* Header globale */
.app-header{
    background:var(--card);
    border-radius:20px;
    box-shadow:var(--shadow);
    padding:16px 18px;
    margin-bottom:16px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
}

.app-logo{
    font-size:22px;
    font-weight:800;
}

.desktop-nav{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}

.desktop-nav a{
    background:var(--primary);
    color:#fff;
    padding:10px 14px;
    border-radius:10px;
    font-size:14px;
}

/* Bottom nav */
.mobile-bottom-nav{
    display:none;
}

/* Dashboard premium */
.dashboard-hero{
    display:grid;
    grid-template-columns:1.4fr .8fr;
    gap:16px;
    margin-bottom:16px;
}

.hero-card{
    background:linear-gradient(135deg,#1f2937,#2563eb);
    color:#fff;
    border-radius:22px;
    padding:22px;
    box-shadow:var(--shadow);
}

.hero-card h1{
    margin:0 0 8px;
    font-size:28px;
}

.hero-card p{
    margin:0;
    opacity:.9;
}

.quick-card{
    background:#fff;
    border-radius:22px;
    padding:18px;
    box-shadow:var(--shadow);
}

.quick-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
}

.quick-actions a{
    display:block;
    padding:14px;
    border-radius:14px;
    background:#f3f6fb;
    font-weight:700;
    text-align:center;
}

.kpi-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
    margin-bottom:16px;
}

.kpi-card{
    background:#fff;
    border-radius:20px;
    padding:18px;
    box-shadow:var(--shadow);
    border-left:6px solid var(--primary);
}

.kpi-card.danger{border-left-color:var(--danger)}
.kpi-card.warning{border-left-color:var(--warning)}
.kpi-card.success{border-left-color:var(--success)}

.kpi-card .label{
    color:var(--muted);
    font-size:14px;
    font-weight:700;
}

.kpi-card .number{
    font-size:34px;
    font-weight:900;
    margin-top:8px;
}

.dashboard-main{
    display:grid;
    grid-template-columns:2fr .9fr;
    gap:16px;
}

.ticket-card-row{
    display:grid;
    grid-template-columns:1fr auto;
    gap:10px;
    padding:14px;
    border-radius:16px;
    border:1px solid var(--border);
    margin-bottom:10px;
    background:#fff;
}

.ticket-card-row:hover{
    background:#f8fafc;
}

.ticket-title{
    display:block;
    font-weight:800;
    margin-bottom:6px;
}

.ticket-meta{
    color:var(--muted);
    font-size:13px;
}

.ticket-priority{
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
    white-space:nowrap;
}

.priority-urgente{background:#dc2626;color:#fff}
.priority-alta{background:#fef3c7;color:#92400e}
.priority-media{background:#fce7f3;color:#9d174d}
.priority-bassa{background:#f3f4f6;color:#374151}

.legend-compact{
    display:grid;
    gap:8px;
}

.legend-compact div{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:14px;
}

.legend-dot{
    width:14px;
    height:14px;
    border-radius:999px;
    display:inline-block;
}

/* Tabelle */
table{
    width:100%;
    border-collapse:collapse;
    background:#fff;
    border-radius:12px;
    overflow:hidden;
}

th,td{
    padding:12px;
    border-bottom:1px solid var(--border);
    text-align:left;
    font-size:14px;
}

th{
    background:#f8fafc;
}

/* Mobile */
@media(max-width:900px){
    .dashboard-hero,
    .dashboard-main{
        grid-template-columns:1fr;
    }

    .kpi-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media(max-width:768px){
    body{
        padding-bottom:86px;
    }

    .wrap{
        padding:10px;
    }

    .desktop-nav{
        display:none !important;
    }

    .mobile-bottom-nav{
        position:fixed;
        left:10px;
        right:10px;
        bottom:10px;
        z-index:9999;
        display:grid;
        grid-template-columns:repeat(5,1fr);
        gap:6px;
        background:#fff;
        border:1px solid var(--border);
        box-shadow:0 10px 30px rgba(0,0,0,.18);
        border-radius:22px;
        padding:8px;
    }

    .mobile-bottom-nav a{
        position:relative;
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        gap:3px;
        min-height:54px;
        border-radius:16px;
        color:#6b7280;
        font-size:20px;
    }

    .mobile-bottom-nav a small{
        font-size:11px;
        font-weight:700;
    }

    .mobile-bottom-nav a.active{
        background:#eef4ff;
        color:var(--primary);
    }

    .mobile-bottom-nav .main-action{
        background:var(--primary);
        color:#fff;
        transform:translateY(-8px);
        box-shadow:0 8px 18px rgba(37,99,235,.35);
    }

    .nav-badge{
        position:absolute;
        top:4px;
        right:18px;
        background:var(--danger);
        color:#fff;
        border-radius:999px;
        min-width:18px;
        height:18px;
        padding:0 5px;
        font-size:11px;
        display:inline-flex;
        align-items:center;
        justify-content:center;
        border:2px solid #fff;
    }
}

@media(max-width:600px){
    .hero-card h1{
        font-size:23px;
    }

    .kpi-grid{
        grid-template-columns:1fr 1fr;
    }

    .kpi-card{
        padding:14px;
    }

    .kpi-card .number{
        font-size:28px;
    }

    .quick-actions{
        grid-template-columns:1fr 1fr;
    }
}
.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    background:linear-gradient(135deg,#1f2937,#2563eb);
}

.login-card{
    width:100%;
    max-width:420px;
    background:#fff;
    border-radius:24px;
    padding:28px;
    box-shadow:0 20px 50px rgba(0,0,0,.22);
}

.login-logo{
    font-size:28px;
    font-weight:900;
    margin-bottom:6px;
}

.login-button{
    width:100%;
    margin-top:20px;
    padding:14px;
    font-size:16px;
    font-weight:800;
    border-radius:14px;
}

.alert{
    padding:12px;
    border-radius:12px;
    margin:16px 0;
}

.alert-danger{
    background:#fee2e2;
    color:#991b1b;
}
/* LOGIN PRO */
.login-screen .mobile-bottom-nav,
.login-screen .app-header{
    display:none !important;
}

.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
}

.login-card{
    width:100%;
    max-width:420px;
    background:#fff;
    border-radius:26px;
    padding:28px;
    box-shadow:0 20px 60px rgba(0,0,0,.12);
}

.login-logo{
    font-size:22px;
    font-weight:900;
    margin-bottom:4px;
}

.login-card .muted{
    margin-bottom:18px;
}

.login-card label{
    margin-top:14px;
    font-size:15px;
}

.login-card input{
    height:48px;
    font-size:16px;
    margin-top:6px;
}

.login-button{
    width:100%;
    height:50px;
    margin-top:22px;
    border-radius:14px;
    font-size:17px;
    font-weight:800;
}

@media(max-width:600px){
    .login-page{
        padding:18px;
    }

    .login-card{
        padding:22px;
        border-radius:22px;
    }
}
/* LOGIN PREMIUM */
body.login-screen{
    background:linear-gradient(135deg,#1f2937 0%,#2563eb 45%,#f4f6f8 100%);
    background-size:180% 180%;
    animation:loginGradient 10s ease infinite;
}

.login-card{
    animation:loginCardIn .55s ease both;
}

.login-logo{
    animation:logoPop .7s ease both;
}

@keyframes loginGradient{
    0%{background-position:0% 50%}
    50%{background-position:100% 50%}
    100%{background-position:0% 50%}
}

@keyframes loginCardIn{
    from{
        opacity:0;
        transform:translateY(18px) scale(.98);
    }
    to{
        opacity:1;
        transform:translateY(0) scale(1);
    }
}

@keyframes logoPop{
    0%{
        opacity:0;
        transform:scale(.8) rotate(-4deg);
    }
    70%{
        transform:scale(1.05) rotate(1deg);
    }
    100%{
        opacity:1;
        transform:scale(1) rotate(0);
    }
}

/* TICKET LIST PREMIUM */
.ticket-page-title{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:center;
    flex-wrap:wrap;
}

.ticket-filters{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:12px;
}

.ticket-list-desktop{
    display:block;
}

.ticket-list-mobile{
    display:none;
}

.ticket-badge{
    display:inline-block;
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
}

.ticket-card-mobile{
    background:#fff;
    border-radius:18px;
    padding:16px;
    box-shadow:var(--shadow);
    margin-bottom:12px;
    border-left:6px solid var(--primary);
}

.ticket-card-mobile.urgent{border-left-color:var(--danger);}
.ticket-card-mobile.high{border-left-color:var(--warning);}
.ticket-card-mobile.closed{border-left-color:var(--success);}

.ticket-card-title{
    font-size:17px;
    font-weight:900;
    margin-bottom:6px;
}

.ticket-card-meta{
    font-size:13px;
    color:var(--muted);
    margin-bottom:8px;
}

.ticket-card-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    margin-top:12px;
}

.ticket-card-actions a,
.ticket-card-actions button{
    width:100%;
    text-align:center;
}

@media(max-width:800px){
    .ticket-filters{
        grid-template-columns:1fr;
    }

    .ticket-list-desktop{
        display:none;
    }

    .ticket-list-mobile{
        display:block;
    }
}
/* TICKET DETAIL PREMIUM */
.ticket-detail-hero{
    background:linear-gradient(135deg,#1f2937,#2563eb);
    color:#fff;
    border-radius:22px;
    padding:22px;
    box-shadow:var(--shadow);
    margin-bottom:16px;
}

.ticket-detail-hero h1{
    margin:0 0 8px;
    font-size:28px;
}

.ticket-detail-grid{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:16px;
}

.ticket-info-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}

.info-pill{
    background:#f8fafc;
    border:1px solid var(--border);
    border-radius:14px;
    padding:12px;
}

.info-pill strong{
    display:block;
    margin-bottom:4px;
}

.ticket-section-title{
    margin:0 0 14px;
}

.ticket-action-stack{
    display:grid;
    gap:10px;
}

.attachment-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    gap:12px;
}

.attachment-card{
    border:1px solid var(--border);
    border-radius:16px;
    padding:12px;
    background:#fff;
}

.attachment-card img{
    width:100%;
    max-height:180px;
    object-fit:cover;
    border-radius:12px;
    margin-top:10px;
}

.comment-item,
.log-item,
.chat-message{
    padding:12px 0;
    border-bottom:1px solid var(--border);
}

.chat-box{
    border:1px solid var(--border);
    border-radius:16px;
    padding:12px;
    max-height:340px;
    overflow:auto;
    background:#f8fafc;
    margin-bottom:12px;
}

@media(max-width:900px){
    .ticket-detail-grid,
    .ticket-info-grid{
        grid-template-columns:1fr;
    }

    .ticket-detail-hero h1{
        font-size:23px;
    }
}

.mobile-actions-box{
    display:none !important;
}

.desktop-actions-box{
    display:block !important;
}

@media(max-width:900px){
    .desktop-actions-box{
        display:none !important;
    }

    .mobile-actions-box{
        display:block !important;
    }
}
/* FIX definitivo box azioni dettaglio ticket */
.box.mobile-actions-box{
    display:none !important;
}

.box.desktop-actions-box{
    display:block !important;
}

@media(max-width:900px){
    .box.desktop-actions-box{
        display:none !important;
    }

    .box.mobile-actions-box{
        display:block !important;
    }
}
/* CREATE TICKET PREMIUM */
.create-ticket-hero{
    background:linear-gradient(135deg,#1f2937,#2563eb);
    color:#fff;
    border-radius:22px;
    padding:22px;
    box-shadow:var(--shadow);
    margin-bottom:16px;
}

.create-ticket-hero h1{
    margin:0 0 8px;
    font-size:28px;
}

.create-ticket-layout{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}

.form-section-title{
    margin:0 0 12px;
    font-size:20px;
}

.form-help{
    color:var(--muted);
    font-size:13px;
    margin-top:6px;
}

.radio-card-group{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:10px;
    margin-top:10px;
}

.radio-card-group label,
.checkbox-card label{
    border:1px solid var(--border);
    border-radius:14px;
    padding:12px;
    background:#fff;
    display:flex;
    align-items:center;
    gap:8px;
    font-weight:700;
}

.form-footer-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:18px;
}

@media(max-width:900px){
    .create-ticket-layout{
        grid-template-columns:1fr;
    }

    .radio-card-group{
        grid-template-columns:1fr;
    }

    .create-ticket-hero h1{
        font-size:23px;
    }

    .form-footer-actions .btn,
    .form-footer-actions button{
        width:100%;
    }
}
/* NOTIFICATIONS PREMIUM */
.notifications-hero{
    background:linear-gradient(135deg,#1f2937,#2563eb);
    color:#fff;
    border-radius:22px;
    padding:22px;
    box-shadow:var(--shadow);
    margin-bottom:16px;
}

.notifications-hero h1{
    margin:0 0 8px;
    font-size:28px;
}

.notification-toolbar{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    flex-wrap:wrap;
}

.notification-tabs{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}

.notification-item{
    background:#fff;
    border-radius:18px;
    padding:16px;
    box-shadow:var(--shadow);
    margin-bottom:12px;
    border-left:6px solid #d1d5db;
}

.notification-item.unread{
    border-left-color:var(--primary);
    background:#eef4ff;
}

.notification-main{
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:14px;
    align-items:flex-start;
}

.notification-icon{
    width:44px;
    height:44px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#f3f4f6;
    font-size:22px;
}

.notification-title{
    font-weight:900;
    margin-bottom:5px;
}

.notification-message{
    margin-top:8px;
    white-space:pre-line;
}

.notification-actions{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin-top:12px;
}

@media(max-width:700px){
    .notification-main{
        grid-template-columns:auto 1fr;
    }

    .notification-main > div:last-child{
        grid-column:1 / -1;
    }

    .notifications-hero h1{
        font-size:23px;
    }

    .notification-actions .btn,
    .notification-actions button{
        width:100%;
        text-align:center;
    }
}
	
	/* DASHBOARD MINI CHART */
.mini-chart{
    display:flex;
    align-items:flex-end;
    gap:6px;
    height:180px;
    padding:14px;
    background:#f8fafc;
    border-radius:18px;
    border:1px solid var(--border);
}

.chart-bar{
    flex:1;
    min-width:6px;
    background:linear-gradient(180deg,#2563eb,#1d4ed8);
    border-radius:8px 8px 0 0;
    position:relative;
}

.chart-bar span{
    position:absolute;
    bottom:100%;
    left:50%;
    transform:translateX(-50%);
    font-size:11px;
    color:var(--muted);
    margin-bottom:4px;
}

.chart-labels{
    display:flex;
    justify-content:space-between;
    margin-top:8px;
    font-size:12px;
    color:var(--muted);
}
/* DITTE ESTERNE MOBILE */

.company-mobile-list{
    display:none;
}

.company-card{
    background:#fff;
    border-radius:18px;
    padding:16px;
    margin-bottom:14px;
    box-shadow:var(--shadow);
    border:1px solid var(--border);
}

.company-card-title{
    font-size:18px;
    font-weight:800;
    margin-bottom:8px;
}

.company-card-meta{
    margin-bottom:6px;
    color:var(--muted);
    font-size:14px;
}

.company-card-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:14px;
}

@media(max-width:768px){

    .company-desktop-table{
        display:none;
    }

    .company-mobile-list{
        display:block;
    }
}
/* ADMIN LOCATION MOBILE PACK */
.admin-filter-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr auto;
    gap:14px;
    align-items:end;
}

.admin-filter-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.admin-card-list-mobile{
    display:none;
}

.admin-mobile-card{
    background:#fff;
    border-radius:18px;
    padding:16px;
    margin-bottom:14px;
    box-shadow:var(--shadow);
    border:1px solid var(--border);
}

.admin-mobile-card-title{
    font-size:18px;
    font-weight:800;
    margin-bottom:8px;
}

.admin-mobile-card-meta{
    margin-bottom:6px;
    color:var(--muted);
    font-size:14px;
}

.admin-mobile-card-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:14px;
}

@media(max-width:768px){
    .admin-filter-grid{
        grid-template-columns:1fr;
    }

    .admin-table-desktop{
        display:none !important;
    }

    .admin-card-list-mobile{
        display:block !important;
    }

    .admin-mobile-card-actions .btn,
    .admin-mobile-card-actions button{
        width:100%;
        text-align:center;
    }
}
/* ADMIN LOCATIONS LAYOUT FIX */
.location-admin-top{
    display:grid;
    grid-template-columns:1.4fr .9fr;
    gap:16px;
    align-items:stretch;
    margin-bottom:16px;
}

.location-actions-card{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    flex-wrap:wrap;
}

.location-actions-card .btn,
.location-actions-card button{
    min-height:48px;
}

.admin-card-list-mobile{
    display:none;
}

@media(max-width:768px){
    .location-admin-top{
        grid-template-columns:1fr;
    }

    .admin-table-desktop,
    .table-wrap{
        display:none !important;
    }

    .admin-card-list-mobile{
        display:block !important;
    }

    .admin-mobile-card{
        background:#fff;
        border-radius:18px;
        padding:16px;
        margin-bottom:14px;
        box-shadow:var(--shadow);
        border:1px solid var(--border);
    }

    .admin-mobile-card-title{
        font-size:18px;
        font-weight:800;
        margin-bottom:8px;
    }

    .admin-mobile-card-meta{
        margin-bottom:6px;
        color:var(--muted);
        font-size:14px;
    }

    .admin-mobile-card-actions{
        display:grid;
        grid-template-columns:1fr;
        gap:8px;
        margin-top:14px;
    }

    .admin-mobile-card-actions .btn,
    .admin-mobile-card-actions button{
        width:100%;
        text-align:center;
    }
}
/* FORCE MOBILE ADMIN TABLE FIX */
@media(max-width:768px){

    .admin-table-desktop,
    .table-wrap,
    table.table{
        display:none !important;
    }

    .admin-card-list-mobile{
        display:block !important;
    }

    .admin-mobile-card{
        display:block !important;
    }
}
/* ADMIN HEADER + LOCATION FIX DEFINITIVO */

.container{
    max-width:1400px;
    margin:auto;
    padding:32px 18px;
}

.topbar{
    background:#fff;
    border-bottom:1px solid var(--border);
    box-shadow:0 4px 18px rgba(15,23,42,.04);
}

.topbar-inner{
    max-width:1400px;
    margin:auto;
    padding:18px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
    flex-wrap:wrap;
}

.brand{
    display:block;
    font-size:24px;
    font-weight:900;
    color:var(--text);
}

.small-muted{
    color:var(--muted);
    font-size:14px;
}

.nav{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.nav a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:46px;
    padding:10px 16px;
    border-radius:12px;
    background:#eef2ff;
    color:var(--text);
    font-weight:600;
}

.nav a.active{
    background:var(--primary);
    color:#fff;
}

.page-header{
    margin-bottom:18px;
}

.page-title{
    font-size:34px;
    margin:0 0 8px;
}

.page-subtitle{
    color:var(--muted);
    margin:0;
}

.location-admin-top{
    display:grid !important;
    grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);
    gap:16px;
    align-items:stretch;
    margin-bottom:16px;
}

.location-actions-card{
    display:flex !important;
    align-items:center;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap;
}

.location-actions-card form{
    margin:0;
}

.location-actions-card .btn,
.location-actions-card button{
    min-height:50px;
}

.admin-card-list-mobile{
    display:none !important;
}

.admin-table-desktop{
    display:block !important;
}

@media(max-width:768px){
    .container{
        padding:18px 10px 100px;
    }

    .topbar-inner{
        align-items:flex-start;
    }

    .nav{
        width:100%;
        overflow-x:auto;
        flex-wrap:nowrap;
        padding-bottom:4px;
    }

    .nav a{
        white-space:nowrap;
    }

    .location-admin-top{
        grid-template-columns:1fr !important;
    }

    .location-actions-card{
        justify-content:stretch;
        align-items:stretch;
    }

    .location-actions-card .btn,
    .location-actions-card button,
    .location-actions-card form{
        width:100%;
        text-align:center;
    }

    .admin-table-desktop{
        display:none !important;
    }

    .admin-card-list-mobile{
        display:block !important;
    }

    .admin-mobile-card{
        display:block !important;
        background:#fff;
        border-radius:18px;
        padding:16px;
        margin-bottom:14px;
        box-shadow:var(--shadow);
        border:1px solid var(--border);
    }

    .admin-mobile-card-title{
        font-size:18px;
        font-weight:800;
        margin-bottom:8px;
    }

    .admin-mobile-card-meta{
        margin-bottom:6px;
        color:var(--muted);
        font-size:14px;
    }

    .admin-mobile-card-actions{
        display:grid;
        grid-template-columns:1fr;
        gap:8px;
        margin-top:14px;
    }

    .admin-mobile-card-actions .btn,
    .admin-mobile-card-actions button,
    .admin-mobile-card-actions form{
        width:100%;
        text-align:center;
    }
}
/* QUICK ACTIONS PREMIUM */

.qa-top-layout{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:16px;
    margin-bottom:16px;
}

.qa-actions-box{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    flex-wrap:wrap;
}

.qa-actions-box .btn{
    min-height:48px;
}

.qa-mobile-list{
    display:none;
}

.qa-card{
    background:#fff;
    border-radius:20px;
    padding:16px;
    margin-bottom:14px;
    box-shadow:var(--shadow);
    border:1px solid var(--border);
}

.qa-card-title{
    display:flex;
    align-items:center;
    gap:10px;
    font-size:18px;
    font-weight:900;
    margin-bottom:10px;
}

.qa-icon{
    width:42px;
    height:42px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#eef2ff;
    font-size:22px;
}

.qa-meta{
    margin-bottom:6px;
    color:var(--muted);
    font-size:14px;
}

.qa-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    margin-top:14px;
}

.qa-actions .btn,
.qa-actions button,
.qa-actions form{
    width:100%;
    text-align:center;
}

@media(max-width:768px){

    .qa-top-layout{
        grid-template-columns:1fr;
    }

    .qa-actions-box{
        justify-content:stretch;
        align-items:stretch;
    }

    .qa-actions-box .btn,
    .qa-actions-box form{
        width:100%;
    }

    .qa-desktop-table{
        display:none !important;
    }

    .qa-mobile-list{
        display:block !important;
    }
}
/* QUICK ACTIONS FIX DEFINITIVO */
.qa-desktop-table{
    display:block !important;
}

.qa-mobile-list{
    display:none !important;
}

@media(max-width:768px){
    .qa-desktop-table{
        display:none !important;
    }

    .qa-mobile-list{
        display:block !important;
    }
}

/* ADMIN HEADER MOBILE SENZA SCROLL ORIZZONTALE */
@media(max-width:768px){
    .nav{
        width:100%;
        display:grid !important;
        grid-template-columns:1fr 1fr;
        gap:8px;
        overflow-x:visible !important;
        flex-wrap:wrap !important;
        padding-bottom:0 !important;
    }

    .nav a{
        width:100%;
        white-space:normal !important;
        text-align:center;
        min-height:44px;
        padding:10px 8px;
    }
}
/* ADMIN DASHBOARD GRID FIX */
.admin-modules-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:16px;
}

.admin-module-card{
    background:#fff;
    border-radius:18px;
    padding:20px;
    box-shadow:var(--shadow);
}

@media(max-width:1000px){
    .admin-modules-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media(max-width:768px){
    .admin-modules-grid{
        grid-template-columns:1fr;
    }
}
/* GRID-3 FIX */
.grid-3{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
}

@media(max-width:1100px){
    .grid-3{
        grid-template-columns:repeat(2,1fr);
    }
}

@media(max-width:768px){
    .grid-3{
        grid-template-columns:1fr;
    }
}
/* QR SEGNALAZIONE */

.qr-page{
    max-width:900px;
    margin:auto;
}

.qr-header{
    margin-bottom:20px;
}

.qr-location-title{
    font-size:28px;
    font-weight:900;
    margin:0 0 6px;
}

.qr-location-meta{
    color:var(--muted);
}

.qr-layout{
    display:grid;
    grid-template-columns:1.3fr .7fr;
    gap:18px;
}

.qr-sidebar{
    display:flex;
    flex-direction:column;
    gap:16px;
}

.quick-group-title{
    font-size:15px;
    font-weight:900;
    margin:14px 0 8px;
    color:var(--text);
}

.quick-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.quick-action-btn{
    border:none;
    background:#eef2ff;
    color:#1e293b;
    padding:12px 16px;
    border-radius:14px;
    font-weight:700;
    cursor:pointer;
    transition:.18s;
}

.quick-action-btn:hover{
    transform:translateY(-1px);
    background:#dbeafe;
}

.qr-form-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:20px;
}

.qr-status-box{
    border-radius:16px;
    padding:16px;
    background:#f8fafc;
    border:1px solid var(--border);
}

.qr-status-box h3{
    margin-top:0;
}

@media(max-width:768px){

    .qr-layout{
        grid-template-columns:1fr;
    }

    .quick-actions{
        display:grid;
        grid-template-columns:1fr;
    }

    .quick-action-btn{
        width:100%;
        text-align:left;
    }

    .qr-location-title{
        font-size:24px;
    }

    .qr-form-actions{
        display:grid;
        grid-template-columns:1fr;
    }

    .qr-form-actions .btn,
    .qr-form-actions button{
        width:100%;
    }
}
/* QUICK ACTION COLORS */

.qa-color-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:10px;
    margin-top:10px;
}

.qa-color-option{
    display:flex;
    align-items:center;
    gap:10px;
    padding:12px;
    border:1px solid var(--border);
    border-radius:14px;
    cursor:pointer;
    background:#fff;
}

.qa-color-option input{
    width:auto;
    margin:0;
}

.qa-color-preview{
    width:22px;
    height:22px;
    border-radius:8px;
    display:inline-block;
    border:2px solid rgba(0,0,0,.08);
}
/* QUICK ACTION FORM PREMIUM */
.qa-icon-grid,
.qa-color-grid-compact{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(130px,1fr));
    gap:8px;
    margin-top:10px;
}

.qa-icon-option,
.qa-color-option{
    display:flex;
    align-items:center;
    gap:8px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:14px;
    background:#fff;
    cursor:pointer;
    font-size:14px;
}

.qa-icon-option input,
.qa-color-option input,
.qa-active-check input{
    width:auto;
    margin:0;
}

.qa-icon-option.selected,
.qa-color-option.selected{
    border-color:var(--primary);
    background:#eef4ff;
}

.qa-icon-preview{
    font-size:20px;
}

.qa-color-preview{
    width:20px;
    height:20px;
    border-radius:7px;
    border:1px solid rgba(0,0,0,.12);
    display:inline-block;
}

.qa-active-check{
    display:flex;
    gap:10px;
    align-items:center;
    margin-top:18px;
}

.qa-preview-card{
    margin-top:18px;
    padding:14px;
    border-left:6px solid var(--primary);
    border-radius:16px;
    background:#f8fafc;
}
/* HOTEL MODULES GRID */

.modules-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:18px;
    align-items:start;
}

.modules-grid .card{
    height:100%;
}
/* LOCATION ACTIONS FIX */
.location-actions{
    display:grid;
    grid-template-columns:repeat(2, minmax(90px, 1fr));
    gap:6px;
    align-items:stretch;
}

.location-actions .btn,
.location-actions button,
.location-actions form{
    width:100%;
    margin:0;
}

.location-actions .btn,
.location-actions button{
    padding:8px 10px;
    font-size:12px;
    line-height:1.2;
    text-align:center;
    white-space:normal;
}

@media(max-width:768px){
    .location-actions{
        grid-template-columns:1fr;
    }
}


/* ADMIN DROPDOWN MENU */
.admin-nav-dropdowns{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
}

.nav-dropdown{
    position:relative;
}

.nav-dropdown summary{
    list-style:none;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:12px 18px;
    border-radius:12px;
    background:#eef3ff;
    color:#0f172a;
    font-weight:700;
    user-select:none;
}

.nav-dropdown summary::-webkit-details-marker{
    display:none;
}

.nav-dropdown summary::after{
    content:"▾";
    font-size:12px;
    opacity:.7;
}

.nav-dropdown.active summary,
.nav-dropdown[open] summary{
    background:#2563eb;
    color:#fff;
}

.nav-dropdown-menu{
    position:absolute;
    top:calc(100% + 8px);
    left:0;
    min-width:230px;
    background:#fff;
    border-radius:16px;
    padding:10px;
    box-shadow:0 18px 40px rgba(15,23,42,.18);
    z-index:999;
    display:grid;
    gap:6px;
}

.nav-dropdown-menu a{
    display:block;
    padding:10px 12px;
    border-radius:10px;
    background:#f8fafc;
    color:#0f172a;
    text-decoration:none;
    font-weight:700;
    white-space:nowrap;
}

.nav-dropdown-menu a:hover,
.nav-dropdown-menu a.active{
    background:#2563eb;
    color:#fff;
}

@media(max-width:768px){
    .admin-nav-dropdowns{
        align-items:stretch;
    }

    .nav-dropdown{
        width:100%;
    }

    .nav-dropdown summary{
        width:100%;
        justify-content:space-between;
    }

    .nav-dropdown-menu{
        position:static;
        box-shadow:none;
        margin-top:8px;
        min-width:0;
        width:100%;
    }
	
	
}
.app-logo-row{
    display:flex;
    align-items:center;
    gap:10px;
}

.kb-top-link{
    padding:4px 10px;
    border-radius:20px;
    background:#2563eb;
    color:#fff !important;
    text-decoration:none;
    font-size:12px;
    font-weight:700;
    white-space:nowrap;
    flex-shrink:0;
}