/* FisioBooking — Frontend Panel CSS */
:root {
    --fp-primary: #2563eb;
    --fp-success: #16a34a;
    --fp-danger:  #dc2626;
    --fp-gray-50: #f8fafc;
    --fp-gray-100:#f1f5f9;
    --fp-gray-200:#e2e8f0;
    --fp-gray-600:#475569;
    --fp-radius:  10px;
    --fp-shadow:  0 2px 12px rgba(0,0,0,.08);
}

.fisio-fp-wrap { max-width: 900px; margin: 0 auto; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

/* Nav */
.fisio-fp-nav { display: flex; flex-wrap: wrap; gap: 4px; background: #fff; border-radius: var(--fp-radius); box-shadow: var(--fp-shadow); padding: 8px; margin-bottom: 16px; }
.fisio-fp-nav-item { padding: 8px 14px; border-radius: 6px; text-decoration: none; color: var(--fp-gray-600); font-size: .9rem; font-weight: 500; transition: all .15s; }
.fisio-fp-nav-item:hover, .fisio-fp-nav-item.active { background: var(--fp-primary); color: #fff; }
.fisio-fp-logout { margin-left: auto; color: var(--fp-danger); }
.fisio-fp-logout:hover { background: var(--fp-danger); color: #fff; }

/* Sezione */
.fisio-fp-section { padding: 4px 0; }
.fisio-fp-section h2 { font-size: 1.1rem; margin: 0 0 16px; }

/* Card */
.fisio-fp-card { background: #fff; border-radius: var(--fp-radius); box-shadow: var(--fp-shadow); padding: 16px 20px; margin-bottom: 14px; }
.fisio-fp-card h3 { margin: 0 0 10px; font-size: .95rem; }

/* Login */
.fisio-fp-login { background: #fff; border-radius: var(--fp-radius); box-shadow: var(--fp-shadow); padding: 40px; text-align: center; }

/* Link row */
.fisio-fp-link-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.fisio-fp-link-row input { flex: 1; min-width: 160px; padding: 8px 10px; border: 1.5px solid var(--fp-gray-200); border-radius: 6px; font-size: .9rem; background: var(--fp-gray-50); }
.fisio-fp-link-row button { padding: 8px 14px; background: var(--fp-primary); color: #fff; border: none; border-radius: 6px; cursor: pointer; font-size: .85rem; }
.fisio-fp-wa-btn { padding: 8px 14px; background: #25d366; color: #fff; border-radius: 6px; text-decoration: none; font-size: .85rem; }

/* Form row */
.fisio-fp-form-row { display: flex; gap: 8px; flex-wrap: wrap; }
.fisio-fp-form-row input, .fisio-fp-form-row select { flex: 1; min-width: 120px; padding: 8px 10px; border: 1.5px solid var(--fp-gray-200); border-radius: 6px; font-size: .9rem; }
.fisio-fp-form-row button { padding: 8px 16px; background: var(--fp-primary); color: #fff; border: none; border-radius: 6px; cursor: pointer; font-size: .9rem; white-space: nowrap; }

/* Token list */
.fisio-fp-token-row { display: flex; gap: 8px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--fp-gray-100); flex-wrap: wrap; }
.fisio-fp-token-row:last-child { border-bottom: none; }
.fisio-fp-token-phone { font-size: .82rem; color: var(--fp-gray-600); min-width: 100px; }
.fisio-fp-token-row input { flex: 1; min-width: 140px; padding: 5px 8px; border: 1px solid var(--fp-gray-200); border-radius: 5px; font-size: .8rem; background: var(--fp-gray-50); }
.fisio-fp-token-row button { padding: 5px 10px; background: var(--fp-gray-100); border: 1px solid var(--fp-gray-200); border-radius: 5px; cursor: pointer; }

/* List rows */
.fisio-fp-list-row { display: flex; gap: 12px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--fp-gray-100); }
.fisio-fp-list-row:last-child { border-bottom: none; }
.fisio-fp-label { color: var(--fp-gray-600); font-size: .85rem; flex: 1; }

/* Log */
.fisio-fp-log-list { display: flex; flex-direction: column; gap: 8px; }
.fisio-fp-log-row { display: flex; gap: 10px; align-items: flex-start; background: #fff; padding: 10px 14px; border-radius: 8px; box-shadow: 0 1px 4px rgba(0,0,0,.06); }
.fisio-fp-log-icon { font-size: 1.2rem; flex-shrink: 0; }
.fisio-fp-log-info { flex: 1; font-size: .88rem; }
.fisio-fp-log-date { font-size: .78rem; color: var(--fp-gray-600); white-space: nowrap; }
.fisio-log-failed { border-left: 3px solid var(--fp-danger); }
.fisio-log-sent   { border-left: 3px solid var(--fp-success); }
.fisio-log-manual { border-left: 3px solid #94a3b8; }

/* Vuoto */
.fisio-fp-empty { color: #94a3b8; font-style: italic; font-size: .9rem; }

/* Vista calendario in frontend: aggiusta alcuni elementi WP */
.fisio-fp-wrap .wrap { background: none !important; padding: 0 !important; }
.fisio-fp-wrap .fisio-cal-toolbar { margin-bottom: 12px; }

/* Responsive */
@media (max-width: 600px) {
    .fisio-fp-nav-item { font-size: .8rem; padding: 7px 10px; }
    .fisio-fp-card { padding: 14px; }
    .fisio-fp-link-row { flex-direction: column; align-items: stretch; }
    .fisio-fp-link-row button, .fisio-fp-wa-btn { text-align: center; }
}

/* Token cards */
.fisio-fp-token-table { display: flex; flex-direction: column; gap: 10px; }
.fisio-fp-token-card { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; padding: 12px 14px; }
.fisio-fp-token-card-header { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

/* Notice */
.fisio-fp-notice { padding: 12px 16px; border-radius: 8px; margin-bottom: 14px; font-size:.9rem; }
.fisio-fp-notice-success { background: #f0fdf4; border: 1px solid #86efac; color: #166534; }
.fisio-fp-notice-warning { background: #fffbeb; border: 1px solid #fcd34d; color: #92400e; }
.fisio-fp-notice-error   { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b; }

/* Responsive grid token */
@media (max-width: 600px) {
    .fisio-fp-section > div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
}
