/* ════════════════════════════════════════════════════════════════════
 * TurboFattura — Shared CSS
 *
 * CSS estratto dagli inline <style> blocks duplicati in 18 pagine HTML.
 * Caricato come <link rel='stylesheet'> con cache long (30gg + immutable).
 * Risparmio: 13.4KB/pagina × 18 = 227KB su prima sessione utente.
 *
 * Generato da tools/extract_shared_css.py — 2026-05-10
 * ═══════════════════════════════════════════════════════════════════ */

/* ── tf-sidebar-stability-v911 ─────────────────────────────────────── */
/* Sidebar stability v9.1.2: isola repaint + lockdown bg + snap mode + orphan-class guard */
#ap-sidebar {
  isolation: isolate;
  contain: layout style paint;
  background-color: #0f172a !important;
  /* v9.1.3: GPU promote layer dedicato — repaint del rest viewport NON tocca sidebar */
  transform: translateZ(0);
  will-change: transform;
  backface-visibility: hidden;
}
/* Disable hover bg/text durante snap — anti hover-sticky post-click */
#ap-sidebar.tf-nav-snap .ap-nav-link:hover,
#ap-sidebar.tf-nav-snap .ap-nav-link:focus {
  background-color: transparent !important;
}
#ap-sidebar.tf-nav-snap .ap-nav-link:not(.active):hover,
#ap-sidebar.tf-nav-snap .ap-nav-link:not(.active):focus {
  color: rgb(148 163 184) !important;
}
/* During tf-nav-snap: kill TUTTE le transitions/animations ai figli */
#ap-sidebar.tf-nav-snap,
#ap-sidebar.tf-nav-snap *,
#ap-sidebar.tf-nav-snap *::before,
#ap-sidebar.tf-nav-snap *::after {
  transition: none !important;
  animation: none !important;
}
/* Transitions ridotte: solo transform per hover smooth */
.ap-nav-link {
  transition: transform 0.15s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
.ap-nav-link svg {
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
.ap-nav-link.active::before {
  animation: none !important;
}
/* v9.1.2 ORPHAN CLASS GUARD:
   bg-white/[0.08] e text-white valgono SOLO se accompagnate da .active.
   Se le classi restano orfane (edge case), forza bg trasparente -> no flash bianco. */
#ap-sidebar .ap-nav-link.bg-white\\/\\[0\\.08\\]:not(.active) {
  background-color: transparent !important;
}
#ap-sidebar .ap-nav-link.text-white:not(.active) {
  color: rgb(148 163 184) !important; /* slate-400 fallback */
}

/* ── tf-navlinks-premium-css ─────────────────────────────────────── */
.ap-nav-link {
  position: relative;
  transition: background 0.2s ease, color 0.2s ease, transform 0.15s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ap-nav-link svg {
  transition: color 0.2s ease, transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ap-nav-link:hover svg {
  transform: translateY(-1px) scale(1.06);
}
.ap-nav-link:active {
  transform: scale(0.98);
  transition-duration: 0.1s;
}
.ap-nav-link.active {
  border-left-width: 3px !important;
  position: relative;
}
.ap-nav-link.active::before {
  content: '';
  position: absolute;
  left: -3px; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #fbbf24, #f59e0b, #d97706);
  border-radius: 0 2px 2px 0;
  box-shadow: 0 0 8px rgba(245,158,11,0.5);
  animation: tf-active-slide-in 0.35s cubic-bezier(0.65, 0, 0.35, 1);
}
.ap-nav-link.active svg {
  filter: drop-shadow(0 0 4px rgba(245,158,11,0.4));
}
@keyframes tf-active-slide-in {
  from { transform: scaleY(0); opacity: 0; }
  to { transform: scaleY(1); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .ap-nav-link, .ap-nav-link svg, .ap-nav-link.active::before { transition: none !important; animation: none !important; }
}

/* ── tf-counter-premium-css ─────────────────────────────────────── */
#invoice-counter {
  transition: background 0.3s ease, box-shadow 0.3s ease, transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}
#invoice-counter:hover {
  background: rgba(255,255,255,0.08) !important;
  transform: translateY(-1px);
}
#invoice-count-text {
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  transition: color 0.3s ease;
}
#invoice-count-bar {
  transition: width 0.5s cubic-bezier(0.65, 0, 0.35, 1), background 0.3s ease;
  box-shadow: 0 0 8px rgba(245,158,11,0.3);
}
#invoice-counter.tf-counter-pulse {
  animation: tf-counter-pulse 2.4s ease-in-out infinite;
}
#invoice-counter.tf-counter-pulse #invoice-count-text {
  color: #fca5a5 !important;
}
#invoice-count-bar.tf-counter-critical {
  box-shadow: 0 0 12px rgba(239,68,68,0.55), 0 0 0 1px rgba(239,68,68,0.25);
  animation: tf-bar-shimmer 2s ease-in-out infinite;
}
#upgrade-link {
  transition: color 0.2s ease, transform 0.2s ease;
  letter-spacing: 0.02em;
}
#upgrade-link:hover {
  transform: scale(1.03);
}
@keyframes tf-counter-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,38,38,0); }
  50% { box-shadow: 0 0 0 4px rgba(220,38,38,0.15); }
}
@keyframes tf-bar-shimmer {
  0%, 100% { filter: brightness(1); }
  50% { filter: brightness(1.18); }
}
@media (prefers-reduced-motion: reduce) {
  #invoice-counter, #invoice-count-bar { animation: none !important; transition: none !important; }
}

/* ── tf-cmdk-pill-css ─────────────────────────────────────── */
.tf-cmdk-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:10px;border:1px solid rgba(226,232,240,0.95);background:rgba(255,255,255,0.55);color:rgba(100,116,139,0.85);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s,color .15s,box-shadow .15s,transform .15s;-webkit-tap-highlight-color:transparent;line-height:1}
.tf-cmdk-pill:hover{border-color:rgba(203,213,225,1);background:rgba(248,250,252,0.95);color:rgba(51,65,85,1);box-shadow:0 1px 3px rgba(15,23,42,0.07)}
.tf-cmdk-pill:active{transform:scale(0.98)}
.tf-cmdk-pill:focus-visible{outline:2px solid rgba(245,158,11,0.45);outline-offset:2px}
.tf-cmdk-pill svg{width:14px;height:14px;opacity:0.75;flex:none}
.tf-cmdk-pill:hover svg{opacity:1}
.tf-cmdk-pill-label{font-size:12px;letter-spacing:-0.005em;white-space:nowrap}
.tf-cmdk-pill-kbd{display:inline-flex;align-items:center;padding:1px 6px;border-radius:5px;border:1px solid rgba(226,232,240,1);background:rgba(241,245,249,0.6);font-size:10px;font-weight:600;color:rgba(100,116,139,0.7);font-family:ui-sans-serif,system-ui,sans-serif;line-height:1.4;letter-spacing:0.02em}
@media (max-width:640px){
  .tf-cmdk-pill{padding:7px;border-radius:9px}
  .tf-cmdk-pill-label,.tf-cmdk-pill-kbd{display:none}
  .tf-cmdk-pill svg{width:16px;height:16px;opacity:0.85}
}

/* ── tf-brand-logo-css ─────────────────────────────────────── */
.tf-brand-logo {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 11px;
  display: inline-block;
  filter: drop-shadow(0 6px 14px rgba(245,158,11,0.45));
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1), filter 0.3s ease;
  cursor: pointer;
  flex: none;
}
.tf-brand-logo-svg {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 11px;
  overflow: visible;
}
.tf-brand-halo {
  transform-origin: center;
  animation: tf-halo-pulse 3.2s ease-in-out infinite;
}
.tf-brand-bolt {
  stroke-dasharray: 90;
  stroke-dashoffset: 90;
  animation: tf-bolt-draw 1.4s cubic-bezier(0.65, 0, 0.35, 1) 0.15s forwards, tf-bolt-shimmer 5s ease-in-out 2s infinite;
  transform-origin: center;
}
.tf-brand-logo:hover {
  transform: scale(1.08) rotate(-4deg);
  filter: drop-shadow(0 8px 22px rgba(245,158,11,0.65)) drop-shadow(0 0 8px rgba(253,224,71,0.4));
}
.tf-brand-logo:hover .tf-brand-bolt {
  filter: brightness(1.15) saturate(1.1);
}
.tf-brand-logo:active {
  transform: scale(0.96) rotate(0deg);
  transition-duration: 0.1s;
}
@keyframes tf-halo-pulse {
  0%, 100% { opacity: 0.45; transform: scale(1); }
  50% { opacity: 0.85; transform: scale(1.12); }
}
@keyframes tf-bolt-draw {
  to { stroke-dashoffset: 0; }
}
@keyframes tf-bolt-shimmer {
  0%, 100% { filter: brightness(1) drop-shadow(0 0 0 rgba(253,230,138,0)); }
  50% { filter: brightness(1.18) drop-shadow(0 0 4px rgba(253,230,138,0.55)); }
}
@media (prefers-reduced-motion: reduce) {
  .tf-brand-halo, .tf-brand-bolt { animation: none; }
  .tf-brand-bolt { stroke-dashoffset: 0; }
  .tf-brand-logo { transition: none; }
}

/* ── sidebar-anti-flicker ─────────────────────────────────────── */
/* Sprint anti-flicker: sidebar visibile IMMEDIATAMENTE (no FOUC su connessione lenta) */
html { background-color: #f8fafc; }
@media (min-width: 1024px) {
  #ap-sidebar {
    display: flex !important;
    transform: translateX(0) !important;
    -webkit-transform: translateX(0) !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
}
@media (max-width: 1023px) {
  /* Mobile: sidebar resta nascosto fino click hamburger, ma evita flash transform durante navigation */
  #ap-sidebar { will-change: transform; }
}
/* fix-vt-conflict-2026-05-09: rimosse regole view-transition-name=sidebar
   per evitare flash su pagine HTML grandi dove inline CSS applica prima
   che tf-soft-nav.css (con override !important) sia scaricato. */
/* v8.5 — Anti-flicker rebuild menu (slow connection): CSS containment + atomic swap support */
#ap-sidebar nav {
  contain: layout style;
  min-height: 480px;
}
#ap-sidebar nav.tf-rebuilding {
  visibility: hidden;
}
#ap-sidebar nav.tf-rebuilding * {
  transition: none !important;
  animation: none !important;
}
#ap-sidebar nav .ap-nav-link {
  contain: layout style;
}
@media (prefers-reduced-motion: reduce) {
  #ap-sidebar nav.tf-rebuilding { visibility: visible; }
}

/* ── role-gate-css ─────────────────────────────────────── */
/* Viewer/Collaboratore: hide restricted menu items */
html.role-viewer li:has([data-page="prodotti"]),
html.role-viewer li:has([data-page="impostazioni"]),
html.role-viewer li:has([data-page="team"]),
html.role-viewer li:has([data-page="abbonamento"]),
html.role-viewer li:has([data-page="commercialista"]),
html.role-viewer li:has([data-page="note-credito"]),
html.role-viewer li:has([data-page="conservazione"]),
html.role-viewer a[href*="nuova-fattura"],
html.role-viewer #invoice-counter,
html.role-viewer #plan-card,
html.role-viewer #trial-banner,
html.role-viewer [data-require-role="operatore"] { display: none !important; }

/* Partner client: hide abbonamento + TurboFattura branding (show partner branding after API) */
html.role-partner-client li:has([data-page="abbonamento"]),
html.role-partner-client #plan-card { display: none !important; }
html.role-partner-client #sidebar-logo-default,
html.role-partner-client #sidebar-brand-text { display: none !important; }
html.role-partner-client #sidebar-plan { visibility: hidden; }

/* Feature gating: dim locked features */
html.gate-commercialista a[data-page="commercialista"],
html.gate-team a[data-page="team"],
html.gate-report a[data-page="report"],
html.gate-conservazione a[data-page="conservazione"] {
  opacity: 0.4 !important; pointer-events: none !important; cursor: not-allowed !important;
}

/* ── mobile-fixes ─────────────────────────────────────── */
@media (max-width: 640px) {
  /* Trust bar: compact on mobile */
  .border-y .text-xs { font-size: 0.6875rem !important; }
  .border-y .text-\[11px\] { font-size: 0.625rem !important; }
  .border-y img.size-8 { width: 24px !important; height: 24px !important; }
  /* Header: compact */
  header h1 { font-size: 0.9375rem !important; }
  /* Cards: tighter padding */
  .rounded-2xl.p-6 { padding: 1rem !important; }
}
@media (max-width: 375px) {
  header h1 { font-size: 0.875rem !important; }
}
/* iOS Safari: prevent zoom on input focus */
@supports (-webkit-touch-callout: none) {
  input, select, textarea { font-size: 16px !important; }
}

/* ── TF-TOPBAR-PREMIUM-2026-06-03: top bar Linear/Stripe + avatar coerente ── */
header.sticky.top-0.z-30{background:rgba(255,255,255,.82)!important;backdrop-filter:blur(18px) saturate(160%)!important;-webkit-backdrop-filter:blur(18px) saturate(160%)!important;border-bottom:1px solid #e9edf3!important}
header.sticky.top-0.z-30 h1{font-size:15.5px!important;letter-spacing:-.01em!important;font-weight:700!important}
/* search pill raffinata */
.tf-cmdk-pill{border-radius:10px!important;border-color:#e8edf3!important;background:#fff!important}
.tf-cmdk-pill:hover{border-color:#d8dee7!important;background:#f8fafc!important}
.tf-cmdk-pill-kbd{border-radius:6px!important;background:#f1f5f9!important;border-color:#e6eaf0!important}
/* avatar UNIFICATO: topbar (.tf-user-btn-avatar) + menu (.tf-um-avatar) allo stesso ambra→arancio del navbar-foot (#sidebar-initials = from-amber-400 to-orange-500), invece del colore per-utente indigo/rosa */
.tf-user-btn-avatar,.tf-um-avatar{background:linear-gradient(135deg,#fbbf24,#f97316)!important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.3),0 4px 10px -2px rgba(245,158,11,.4)!important}
.tf-user-btn{border-radius:12px!important;border-color:#e8edf3!important;background:#fff!important;transition:border-color .15s,background .15s!important}
.tf-user-btn:hover{border-color:#d8dee7!important;background:#f8fafc!important}
