/* ============================================================================
   Art Stone Dashboard — restauro design system v3 (PREFIX-SCOPED)
   Generato: 2026-04-26T15:17:54Z
   Versione: 20260426_1717
   Strategia: ogni selettore top-level prefissato con `body.as-scope ` (no nesting).
   Compatibile 100% browser. @keyframes/@font-face stanno fuori dal scope.
   File originali: src/**/*.css (22 file).
   Non impatta luna.ilbordellodelleombre.com (le regole non matchano fuori scope).
   ============================================================================ */


/* === top-level @-rules from src\components\button.css === */
@keyframes btn-spin {
  to { transform: rotate(360deg); }
}

/* === top-level @-rules from src\components\modal.css === */
@keyframes modal-grow-in {
  from {
    opacity: 0;
    transform: scale(0.96);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes modal-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* === top-level @-rules from src\components\dropdown.css === */
@keyframes dropdown-in {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* === top-level @-rules from src\components\toast.css === */
@keyframes toast-slide-in {
  from {
    opacity: 0;
    transform: translateX(110%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes toast-slide-out {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(110%);
  }
}
@keyframes toast-countdown {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

/* === top-level @-rules from src\components\skeleton.css === */
@keyframes skel-shimmer {
  100% { transform: translateX(100%); }
}

/* === top-level @-rules from src\pages\dashboard.css === */
@keyframes as-bot-dot-pulse {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 1; }
}

/* === top-level @-rules from src\pages\xml-orders.css === */
@keyframes as-bulk-slide-in {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/* === src\00-tokens.css === */
/* ==========================================================================
   Art Stone Dashboard — Design Tokens v3
   Stile: big-tech minimal (Linear / Vercel / Stripe)
   Author: Lana — 2026-04-26
   ========================================================================== */

body.as-scope {
  /* ──────────────────────────────────────────────────────────────────────
     Color — Neutral scale (slate-like, dark-first)
     Mai usare hex hardcoded fuori da qui. Sempre var(--*).
     ────────────────────────────────────────────────────────────────────── */
  --bg:            #0a0b0d;
  --bg-elevated:   #101216;
  --surface:       #14161a;
  --surface-2:     #1c1f24;
  --surface-3:     #262a31;
  --border:        #262a31;
  --border-strong: #363b44;
  --border-focus:  #4f8cff;

  --text:          #e6e8eb;
  --text-2:        #9ba1ab;
  --text-3:        #6b7280;
  --text-disabled: #4b5159;
  --text-inverse:  #0a0b0d;

  /* ──────────────────────────────────────────────────────────────────────
     Accent — Un solo brand. Linear-blue.
     ────────────────────────────────────────────────────────────────────── */
  --accent:         #4f8cff;
  --accent-hover:   #3b78ec;
  --accent-active:  #2e66d6;
  --accent-bg:      rgba(79, 140, 255, 0.10);
  --accent-bg-hover: rgba(79, 140, 255, 0.16);
  --accent-border:  rgba(79, 140, 255, 0.32);
  --accent-text:    #a8c4ff;

  /* ──────────────────────────────────────────────────────────────────────
     Semantic — Stati. Uno per stato.
     ────────────────────────────────────────────────────────────────────── */
  --success:        #10b981;
  --success-bg:     rgba(16, 185, 129, 0.10);
  --success-border: rgba(16, 185, 129, 0.32);
  --success-text:   #6ee7b7;

  --warning:        #f59e0b;
  --warning-bg:     rgba(245, 158, 11, 0.10);
  --warning-border: rgba(245, 158, 11, 0.32);
  --warning-text:   #fcd34d;

  --danger:         #ef4444;
  --danger-bg:      rgba(239, 68, 68, 0.10);
  --danger-border:  rgba(239, 68, 68, 0.32);
  --danger-text:    #fca5a5;

  --info:           var(--accent);
  --info-bg:        var(--accent-bg);
  --info-border:    var(--accent-border);
  --info-text:      var(--accent-text);

  /* ──────────────────────────────────────────────────────────────────────
     Spacing scale — base 4px
     ────────────────────────────────────────────────────────────────────── */
  --s-0:  0;
  --s-1:  4px;
  --s-2:  8px;
  --s-3:  12px;
  --s-4:  16px;
  --s-5:  20px;
  --s-6:  24px;
  --s-7:  32px;
  --s-8:  40px;
  --s-9:  48px;
  --s-10: 64px;
  --s-11: 80px;

  /* ──────────────────────────────────────────────────────────────────────
     Border radius — scala minima
     ────────────────────────────────────────────────────────────────────── */
  --r-sm:   4px;
  --r-md:   6px;
  --r-lg:   10px;
  --r-xl:   14px;
  --r-pill: 999px;

  /* ──────────────────────────────────────────────────────────────────────
     Typography
     ────────────────────────────────────────────────────────────────────── */
  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", "Fira Code", Menlo, Consolas, monospace;

  --t-2xs:  10px;
  --t-xs:   11px;
  --t-sm:   12px;
  --t-base: 13px;
  --t-md:   14px;
  --t-lg:   16px;
  --t-xl:   18px;
  --t-2xl:  20px;
  --t-3xl:  24px;
  --t-4xl:  32px;

  --fw-normal:    400;
  --fw-medium:    500;
  --fw-semibold:  600;
  --fw-bold:      700;

  --lh-tight:  1.2;
  --lh-snug:   1.35;
  --lh-normal: 1.5;
  --lh-loose:  1.65;

  --tracking-tight:  -0.011em;
  --tracking-tighter: -0.022em;

  /* ──────────────────────────────────────────────────────────────────────
     Shadows — solo neutre, scala 4 step
     ────────────────────────────────────────────────────────────────────── */
  --shadow-xs: 0 1px 1px rgba(0, 0, 0, 0.20);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.28), 0 1px 2px rgba(0, 0, 0, 0.18);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.32), 0 2px 4px rgba(0, 0, 0, 0.20);
  --shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.42), 0 4px 12px rgba(0, 0, 0, 0.24);
  --shadow-xl: 0 24px 60px rgba(0, 0, 0, 0.50), 0 8px 20px rgba(0, 0, 0, 0.28);

  --ring-focus:    0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
  --ring-focus-thin: 0 0 0 2px var(--accent);

  /* ──────────────────────────────────────────────────────────────────────
     Motion
     ────────────────────────────────────────────────────────────────────── */
  --ease:        cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:    cubic-bezier(0, 0, 0.2, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
  --ease-spring: cubic-bezier(0.5, 1.4, 0.3, 1);

  --t-instant: 80ms;
  --t-fast:    140ms;
  --t-base:    200ms;
  --t-slow:    320ms;

  /* ──────────────────────────────────────────────────────────────────────
     Z-index scale
     ────────────────────────────────────────────────────────────────────── */
  --z-base:      1;
  --z-dropdown:  100;
  --z-sticky:    200;
  --z-overlay:   250;
  --z-modal:     300;
  --z-popover:   350;
  --z-toast:     400;
  --z-tooltip:   500;

  /* ──────────────────────────────────────────────────────────────────────
     Layout containers
     ────────────────────────────────────────────────────────────────────── */
  --container-sm:  640px;
  --container-md:  840px;
  --container-lg:  1080px;
  --container-xl:  1280px;
  --container-2xl: 1440px;

  --header-h:  56px;
  --tabs-h:    44px;
}

/* ──────────────────────────────────────────────────────────────────────────
   Reduced motion override
   ────────────────────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  body.as-scope {
    --t-instant: 0ms;
    --t-fast:    0ms;
    --t-base:    0ms;
    --t-slow:    0ms;
  }
}


/* === src\01-reset.css === */
/* ==========================================================================
   Art Stone Dashboard — Reset v3
   Modern reset, big-tech minimal
   ========================================================================== */

body.as-scope *, body.as-scope *::before, body.as-scope *::after { box-sizing: border-box; }

body.as-scope * { margin: 0; padding: 0; }

body.as-scope {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  text-size-adjust: 100%;
  font-feature-settings: "cv11", "ss01", "cv02";
}

body.as-scope {
  min-height: 100vh;
  min-height: 100dvh;
  font: var(--fw-normal) var(--t-md)/var(--lh-normal) var(--font);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body.as-scope img, body.as-scope picture, body.as-scope video, body.as-scope canvas, body.as-scope svg { display: block; max-width: 100%; }

body.as-scope input, body.as-scope button, body.as-scope textarea, body.as-scope select {
  font: inherit;
  color: inherit;
}

body.as-scope button {
  background: none;
  border: 0;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

body.as-scope a { color: var(--accent); text-decoration: none; }
body.as-scope a:hover { color: var(--accent-hover); text-decoration: underline; text-underline-offset: 2px; }

body.as-scope p, body.as-scope h1, body.as-scope h2, body.as-scope h3, body.as-scope h4, body.as-scope h5, body.as-scope h6 { overflow-wrap: break-word; }

body.as-scope h1, body.as-scope h2, body.as-scope h3, body.as-scope h4, body.as-scope h5, body.as-scope h6 {
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-snug);
  color: var(--text);
}

body.as-scope h1 { font-size: var(--t-3xl); letter-spacing: var(--tracking-tighter); }
body.as-scope h2 { font-size: var(--t-2xl); }
body.as-scope h3 { font-size: var(--t-xl); }
body.as-scope h4 { font-size: var(--t-lg); }
body.as-scope h5 { font-size: var(--t-md); }
body.as-scope h6 { font-size: var(--t-sm); }

body.as-scope ul, body.as-scope ol { list-style: none; }

body.as-scope table { border-collapse: collapse; border-spacing: 0; }

body.as-scope ::selection { background: var(--accent-bg); color: var(--text); }

body.as-scope :focus { outline: none; }
body.as-scope :focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}

/* Scrollbar custom — neutra, sottile */
body.as-scope * {
  scrollbar-width: thin;
  scrollbar-color: var(--surface-3) transparent;
}
body.as-scope *::-webkit-scrollbar { width: 8px; height: 8px; }
body.as-scope *::-webkit-scrollbar-track { background: transparent; }
body.as-scope *::-webkit-scrollbar-thumb {
  background: var(--surface-3);
  border-radius: var(--r-pill);
}
body.as-scope *::-webkit-scrollbar-thumb:hover { background: var(--border-strong); }

/* Utility class universal */
body.as-scope .sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

body.as-scope .is-hidden { display: none !important; }


/* === src\02-layout.css === */
/* ==========================================================================
   Art Stone Dashboard — Layout primitives v3
   ========================================================================== */

body.as-scope .container { max-width: var(--container-xl); margin: 0 auto; padding: 0 var(--s-6); }
body.as-scope .container--sm { max-width: var(--container-sm); }
body.as-scope .container--md { max-width: var(--container-md); }
body.as-scope .container--lg { max-width: var(--container-lg); }
body.as-scope .container--2xl { max-width: var(--container-2xl); }

@media (max-width: 760px) {
  body.as-scope .container, body.as-scope .container--sm, body.as-scope .container--md, body.as-scope .container--lg, body.as-scope .container--xl, body.as-scope .container--2xl {
    padding: 0 var(--s-4);
  }
}

/* Stack — vertical flow with gap */
body.as-scope .stack { display: flex; flex-direction: column; gap: var(--s-4); }
body.as-scope .stack--xs { gap: var(--s-1); }
body.as-scope .stack--sm { gap: var(--s-2); }
body.as-scope .stack--md { gap: var(--s-4); }
body.as-scope .stack--lg { gap: var(--s-6); }
body.as-scope .stack--xl { gap: var(--s-8); }

/* Cluster — horizontal flow, wrap */
body.as-scope .cluster { display: flex; flex-wrap: wrap; gap: var(--s-2); align-items: center; }
body.as-scope .cluster--sm { gap: var(--s-1); }
body.as-scope .cluster--md { gap: var(--s-3); }
body.as-scope .cluster--lg { gap: var(--s-5); }

/* Row — non-wrapping flex */
body.as-scope .row { display: flex; gap: var(--s-3); align-items: center; }
body.as-scope .row--between { justify-content: space-between; }
body.as-scope .row--end { justify-content: flex-end; }
body.as-scope .row--start { align-items: flex-start; }
body.as-scope .row--baseline { align-items: baseline; }

/* Spacer */
body.as-scope .spacer { flex: 1 1 auto; }

/* Grid */
body.as-scope .grid { display: grid; gap: var(--s-4); }
body.as-scope .grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
body.as-scope .grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
body.as-scope .grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
body.as-scope .grid--auto { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
body.as-scope .grid--auto-sm { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }

@media (max-width: 760px) {
  body.as-scope .grid--2, body.as-scope .grid--3, body.as-scope .grid--4 { grid-template-columns: 1fr; }
}

/* Divider */
body.as-scope .divider { height: 1px; background: var(--border); border: 0; margin: var(--s-4) 0; }
body.as-scope .divider--vertical { width: 1px; height: auto; align-self: stretch; margin: 0 var(--s-2); }

/* Page shell */
body.as-scope .page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--bg);
}

body.as-scope .page__header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  height: var(--header-h);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border);
}

body.as-scope .page__main {
  flex: 1 1 auto;
  padding: var(--s-6) 0;
}

body.as-scope .page__main--flush { padding: 0; }

/* Section */
body.as-scope .section { padding: var(--s-6) 0; }
body.as-scope .section--sm { padding: var(--s-4) 0; }
body.as-scope .section--lg { padding: var(--s-8) 0; }

/* Text helpers */
body.as-scope .t-2 { color: var(--text-2); }
body.as-scope .t-3 { color: var(--text-3); }
body.as-scope .t-success { color: var(--success-text); }
body.as-scope .t-warning { color: var(--warning-text); }
body.as-scope .t-danger { color: var(--danger-text); }
body.as-scope .t-mono { font-family: var(--font-mono); }
body.as-scope .t-num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }

body.as-scope .t-xs { font-size: var(--t-xs); }
body.as-scope .t-sm { font-size: var(--t-sm); }
body.as-scope .t-base { font-size: var(--t-base); }
body.as-scope .t-md { font-size: var(--t-md); }
body.as-scope .t-lg { font-size: var(--t-lg); }
body.as-scope .t-xl { font-size: var(--t-xl); }

body.as-scope .fw-normal { font-weight: var(--fw-normal); }
body.as-scope .fw-medium { font-weight: var(--fw-medium); }
body.as-scope .fw-semibold { font-weight: var(--fw-semibold); }

body.as-scope .truncate {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}


/* === src\components\button.css === */
/* Button */

body.as-scope .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  height: 36px;
  padding: 0 var(--s-4);
  border: 1px solid transparent;
  border-radius: var(--r-md);
  background: transparent;
  color: var(--text);
  font-family: var(--font);
  font-size: var(--t-base);
  font-weight: var(--fw-medium);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-instant) var(--ease);
}

body.as-scope .btn:focus { outline: none; }
body.as-scope .btn:focus-visible { box-shadow: var(--ring-focus); }
body.as-scope .btn:disabled, body.as-scope .btn[aria-disabled="true"] {
  cursor: not-allowed;
  color: var(--text-disabled);
  background: var(--surface);
  border-color: var(--border);
}

body.as-scope .btn--primary {
  background: var(--accent);
  color: var(--text);
  border-color: var(--accent);
}
body.as-scope .btn--primary:hover:not(:disabled) { background: var(--accent-hover); border-color: var(--accent-hover); }
body.as-scope .btn--primary:active:not(:disabled) { background: var(--accent-active); border-color: var(--accent-active); transform: translateY(1px); }

body.as-scope .btn--ghost {
  background: transparent;
  color: var(--text);
  border-color: var(--border);
}
body.as-scope .btn--ghost:hover:not(:disabled) { background: var(--surface-2); border-color: var(--border-strong); }
body.as-scope .btn--ghost:active:not(:disabled) { background: var(--surface-3); }

body.as-scope .btn--secondary {
  background: var(--surface-2);
  color: var(--text);
  border-color: var(--border);
}
body.as-scope .btn--secondary:hover:not(:disabled) { background: var(--surface-3); border-color: var(--border-strong); }
body.as-scope .btn--secondary:active:not(:disabled) { background: var(--surface-3); transform: translateY(1px); }

body.as-scope .btn--danger {
  background: var(--danger);
  color: var(--text);
  border-color: var(--danger);
}
body.as-scope .btn--danger:hover:not(:disabled) { background: var(--danger-text); border-color: var(--danger-text); color: var(--text-inverse); }
body.as-scope .btn--danger:active:not(:disabled) { transform: translateY(1px); }

body.as-scope .btn--icon {
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--r-md);
}

body.as-scope .btn--sm {
  height: 28px;
  padding: 0 var(--s-3);
  font-size: var(--t-sm);
  gap: var(--s-1);
}
body.as-scope .btn--sm.btn--icon { width: 28px; padding: 0; }

body.as-scope .btn--lg {
  height: 44px;
  padding: 0 var(--s-5);
  font-size: var(--t-md);
  gap: var(--s-3);
}
body.as-scope .btn--lg.btn--icon { width: 44px; padding: 0; }

body.as-scope .btn--block {
  display: flex;
  width: 100%;
}

body.as-scope .btn--loading {
  position: relative;
  color: transparent;
  pointer-events: none;
}
body.as-scope .btn--loading::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: var(--r-pill);
  color: var(--text);
  animation: btn-spin 600ms linear infinite;
}
body.as-scope .btn--primary.btn--loading::after, body.as-scope .btn--danger.btn--loading::after { color: var(--text); }
body.as-scope .btn--ghost.btn--loading::after, body.as-scope .btn--secondary.btn--loading::after { color: var(--text-2); }




/* === src\components\badge.css === */
/* Badge */

body.as-scope .badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  height: 22px;
  padding: 0 var(--s-2);
  background: var(--surface-2);
  color: var(--text-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: var(--t-xs);
  font-weight: var(--fw-medium);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  white-space: nowrap;
}

body.as-scope .badge--sm { height: 18px; padding: 0 var(--s-2); font-size: var(--t-2xs); }
body.as-scope .badge--md { height: 24px; padding: 0 var(--s-3); font-size: var(--t-sm); }

body.as-scope .badge--pill { border-radius: var(--r-pill); }

body.as-scope .badge--neutral { background: var(--surface-2); color: var(--text-2); border-color: var(--border); }
body.as-scope .badge--success { background: var(--success-bg); color: var(--success-text); border-color: var(--success-border); }
body.as-scope .badge--warning { background: var(--warning-bg); color: var(--warning-text); border-color: var(--warning-border); }
body.as-scope .badge--danger { background: var(--danger-bg);  color: var(--danger-text);  border-color: var(--danger-border); }
body.as-scope .badge--info { background: var(--info-bg);    color: var(--info-text);    border-color: var(--info-border); }

body.as-scope .badge--solid.badge--success { background: var(--success); color: var(--text-inverse); border-color: var(--success); }
body.as-scope .badge--solid.badge--warning { background: var(--warning); color: var(--text-inverse); border-color: var(--warning); }
body.as-scope .badge--solid.badge--danger { background: var(--danger);  color: var(--text);         border-color: var(--danger); }
body.as-scope .badge--solid.badge--info { background: var(--accent);  color: var(--text);         border-color: var(--accent); }
body.as-scope .badge--solid.badge--neutral { background: var(--surface-3); color: var(--text);       border-color: var(--surface-3); }

body.as-scope .badge--outline { background: transparent; }
body.as-scope .badge--outline.badge--success { border-color: var(--success-border); color: var(--success-text); }
body.as-scope .badge--outline.badge--warning { border-color: var(--warning-border); color: var(--warning-text); }
body.as-scope .badge--outline.badge--danger { border-color: var(--danger-border);  color: var(--danger-text); }
body.as-scope .badge--outline.badge--info { border-color: var(--info-border);    color: var(--info-text); }
body.as-scope .badge--outline.badge--neutral { border-color: var(--border-strong);  color: var(--text-2); }

body.as-scope .badge--dot {
  position: relative;
  padding-left: var(--s-5);
}
body.as-scope .badge--dot::before {
  content: "";
  position: absolute;
  left: var(--s-2);
  top: 50%;
  width: 6px;
  height: 6px;
  margin-top: -3px;
  border-radius: var(--r-pill);
  background: currentColor;
}


/* === src\components\card.css === */
/* Card */

body.as-scope .card {
  display: block;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  color: var(--text);
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}

body.as-scope .card--padded {
  padding: var(--s-5);
}

body.as-scope .card--flat {
  background: transparent;
  border-color: var(--border);
}

body.as-scope .card--interactive {
  cursor: pointer;
  text-decoration: none;
}
body.as-scope .card--interactive:hover {
  border-color: var(--border-strong);
  background: var(--bg-elevated);
  transform: translateY(-1px);
}
body.as-scope .card--interactive:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
}
body.as-scope .card--interactive:active {
  transform: translateY(0);
  background: var(--surface-2);
}

body.as-scope .card--hover:hover {
  border-color: var(--border-strong);
}

body.as-scope .card__header {
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}

body.as-scope .card__title {
  font-size: var(--t-md);
  font-weight: var(--fw-semibold);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}

body.as-scope .card__subtitle {
  font-size: var(--t-sm);
  color: var(--text-2);
  margin: 0;
}

body.as-scope .card__body {
  padding: var(--s-5);
}

body.as-scope .card__footer {
  padding: var(--s-4) var(--s-5);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: var(--s-3);
}


/* === src\components\input.css === */
/* Input */

body.as-scope .input, body.as-scope .select, body.as-scope .textarea {
  display: block;
  width: 100%;
  height: 36px;
  padding: var(--s-2) var(--s-3);
  background: var(--bg-elevated);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-family: var(--font);
  font-size: var(--t-base);
  font-weight: var(--fw-normal);
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight);
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}

body.as-scope .input::placeholder, body.as-scope .textarea::placeholder {
  color: var(--text-3);
}

body.as-scope .input:hover:not(:disabled), body.as-scope .select:hover:not(:disabled), body.as-scope .textarea:hover:not(:disabled) {
  border-color: var(--border-strong);
}

body.as-scope .input:focus, body.as-scope .select:focus, body.as-scope .textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-bg);
}

body.as-scope .input:disabled, body.as-scope .select:disabled, body.as-scope .textarea:disabled {
  background: var(--surface);
  color: var(--text-disabled);
  cursor: not-allowed;
  border-color: var(--border);
}

body.as-scope .input--sm, body.as-scope .select--sm { height: 32px; padding: var(--s-1) var(--s-3); font-size: var(--t-sm); }
body.as-scope .input--lg, body.as-scope .select--lg { height: 44px; padding: var(--s-3) var(--s-4); font-size: var(--t-md); }

body.as-scope .textarea {
  height: auto;
  min-height: 80px;
  padding: var(--s-3);
  line-height: var(--lh-normal);
  resize: vertical;
}

body.as-scope .select {
  appearance: none;
  padding-right: var(--s-7);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ba1ab' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right var(--s-3) center;
  background-size: 12px 12px;
  cursor: pointer;
}

body.as-scope .input--error, body.as-scope .select--error, body.as-scope .textarea--error {
  border-color: var(--danger);
}
body.as-scope .input--error:focus, body.as-scope .select--error:focus, body.as-scope .textarea--error:focus {
  border-color: var(--danger);
  box-shadow: 0 0 0 2px var(--danger-bg);
}

body.as-scope .checkbox, body.as-scope .radio {
  appearance: none;
  width: 16px;
  height: 16px;
  margin: 0;
  background: var(--bg-elevated);
  border: 1px solid var(--border-strong);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  position: relative;
  flex-shrink: 0;
}

body.as-scope .checkbox { border-radius: var(--r-sm); }
body.as-scope .radio { border-radius: var(--r-pill); }

body.as-scope .checkbox:hover:not(:disabled), body.as-scope .radio:hover:not(:disabled) { border-color: var(--accent); }

body.as-scope .checkbox:focus-visible, body.as-scope .radio:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
}

body.as-scope .checkbox:checked, body.as-scope .radio:checked {
  background: var(--accent);
  border-color: var(--accent);
}

body.as-scope .checkbox:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px 12px;
}

body.as-scope .radio:checked::after {
  content: "";
  position: absolute;
  inset: 3px;
  background: var(--text);
  border-radius: var(--r-pill);
}

body.as-scope .checkbox:disabled, body.as-scope .radio:disabled { opacity: 0.5; cursor: not-allowed; }

body.as-scope .switch {
  appearance: none;
  width: 32px;
  height: 18px;
  border-radius: var(--r-pill);
  background: var(--surface-3);
  border: 1px solid var(--border);
  position: relative;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  flex-shrink: 0;
}

body.as-scope .switch::after {
  content: "";
  position: absolute;
  top: 1px;
  left: 1px;
  width: 14px;
  height: 14px;
  background: var(--text);
  border-radius: var(--r-pill);
  transition: transform var(--t-fast) var(--ease);
}

body.as-scope .switch:checked {
  background: var(--accent);
  border-color: var(--accent);
}
body.as-scope .switch:checked::after { transform: translateX(14px); }

body.as-scope .switch:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
}

body.as-scope .switch:disabled { opacity: 0.5; cursor: not-allowed; }


/* === src\components\form.css === */
/* Form */

body.as-scope .field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-bottom: var(--s-4);
}

body.as-scope .field:last-child { margin-bottom: 0; }

body.as-scope .label {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-sm);
  font-weight: var(--fw-medium);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-snug);
}

body.as-scope .label--required::after {
  content: "*";
  color: var(--danger);
  margin-left: var(--s-1);
}

body.as-scope .help {
  font-size: var(--t-sm);
  color: var(--text-2);
  line-height: var(--lh-snug);
}

body.as-scope .error {
  font-size: var(--t-sm);
  color: var(--danger-text);
  line-height: var(--lh-snug);
  display: flex;
  align-items: center;
  gap: var(--s-1);
}

body.as-scope .field-row {
  display: flex;
  gap: var(--s-3);
  align-items: flex-start;
}

body.as-scope .field-row > .field {
  flex: 1;
  margin-bottom: 0;
}

body.as-scope .fieldset {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-5);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  margin: 0 0 var(--s-4) 0;
  background: var(--surface);
}

body.as-scope .legend {
  padding: 0 var(--s-2);
  font-size: var(--t-sm);
  font-weight: var(--fw-semibold);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
}

body.as-scope .field--inline {
  flex-direction: row;
  align-items: center;
  gap: var(--s-2);
}


/* === src\components\tabs.css === */
/* ==========================================================================
   Tabs — underline minimal, sticky
   ========================================================================== */

body.as-scope .tabs {
  position: relative;
  width: 100%;
}

body.as-scope .tabs__list {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: var(--s-1);
  min-height: var(--tabs-h);
  padding: 0 var(--s-4);
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

body.as-scope .tabs__list::-webkit-scrollbar {
  display: none;
}

body.as-scope .tabs__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  min-height: 44px;
  padding: 0 var(--s-3);
  background: transparent;
  border: 0;
  color: var(--text-2);
  font-family: var(--font);
  font-size: var(--t-md);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-tight);
  cursor: pointer;
  scroll-snap-align: start;
  white-space: nowrap;
  transition: color var(--t-fast) var(--ease);
}

body.as-scope .tabs__btn::after {
  content: "";
  position: absolute;
  left: var(--s-3);
  right: var(--s-3);
  bottom: -1px;
  height: 2px;
  background: var(--accent);
  border-radius: var(--r-sm);
  opacity: 0;
  transform: scaleX(0.6);
  transform-origin: center;
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}

body.as-scope .tabs__btn:hover {
  color: var(--text);
}

body.as-scope .tabs__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -4px;
  border-radius: var(--r-sm);
}

body.as-scope .tabs__btn--active {
  color: var(--text);
}

body.as-scope .tabs__btn--active::after {
  opacity: 1;
  transform: scaleX(1);
}

body.as-scope .tabs__btn[disabled], body.as-scope .tabs__btn[aria-disabled="true"] {
  color: var(--text-disabled);
  cursor: not-allowed;
  pointer-events: none;
}

body.as-scope .tabs__icon {
  display: inline-flex;
  width: var(--s-4);
  height: var(--s-4);
  flex-shrink: 0;
}

body.as-scope .tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--s-5);
  height: var(--s-5);
  padding: 0 var(--s-2);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: var(--t-2xs);
  font-weight: var(--fw-medium);
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
}

body.as-scope .tabs__btn--active .tabs__count {
  background: var(--accent-bg);
  color: var(--accent-text);
  border-color: var(--accent-border);
}

body.as-scope .tabs__panel {
  padding: var(--s-5) var(--s-4);
}

body.as-scope .tabs__panel[hidden] {
  display: none;
}


/* === src\components\table.css === */
/* ==========================================================================
   Table — big-tech minimal (Linear / Vercel / Stripe)
   ========================================================================== */

body.as-scope .table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
}

body.as-scope .table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-family: var(--font);
  font-size: var(--t-base);
  color: var(--text);
  text-align: left;
}

body.as-scope .table thead th {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: var(--surface);
  padding: var(--s-2) var(--s-3);
  font-size: var(--t-xs);
  font-weight: var(--fw-medium);
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  user-select: none;
}

body.as-scope .table tbody td {
  padding: var(--s-3);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}

body.as-scope .table tbody tr:last-child td {
  border-bottom: 0;
}

body.as-scope .table tbody tr {
  transition: background var(--t-fast) var(--ease);
}

body.as-scope .table tbody tr:hover {
  background: var(--surface-2);
}

body.as-scope .table tbody tr[aria-selected="true"] {
  background: var(--accent-bg);
}

body.as-scope .table th[aria-sort] {
  cursor: pointer;
}

body.as-scope .table th[aria-sort]:hover {
  color: var(--text);
}

body.as-scope .table th[aria-sort]::after {
  content: "";
  display: inline-block;
  width: var(--s-2);
  height: var(--s-2);
  margin-left: var(--s-2);
  vertical-align: middle;
  opacity: 0.4;
  background: currentColor;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transition: transform var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease);
}

body.as-scope .table th[aria-sort="ascending"]::after {
  opacity: 1;
}

body.as-scope .table th[aria-sort="descending"]::after {
  opacity: 1;
  transform: rotate(180deg);
}

/* Action column — right aligned, no text */
body.as-scope .table .table__col-actions {
  width: 1%;
  text-align: right;
  white-space: nowrap;
}

body.as-scope .table .table__col-actions > * + * {
  margin-left: var(--s-1);
}

/* Checkbox column — fixed narrow */
body.as-scope .table .table__col-check {
  width: 1%;
  padding-left: var(--s-4);
  padding-right: var(--s-2);
}

body.as-scope .table .table__col-check input[type="checkbox"] {
  width: var(--s-4);
  height: var(--s-4);
  margin: 0;
  cursor: pointer;
  accent-color: var(--accent);
}

/* Numeric cell — tabular */
body.as-scope .table .table__num {
  font-variant-numeric: tabular-nums;
  text-align: right;
  font-family: var(--font-mono);
  font-size: var(--t-sm);
}

/* Muted cell */
body.as-scope .table .table__muted {
  color: var(--text-2);
}

/* Empty row */
body.as-scope .table tbody tr.table__empty td {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  color: var(--text-3);
}

/* ─── Variant: --compact ──────────────────────────────────────────────── */
body.as-scope .table--compact thead th {
  padding: var(--s-1) var(--s-3);
}

body.as-scope .table--compact tbody td {
  padding: var(--s-2) var(--s-3);
}

/* ─── Variant: --bordered ─────────────────────────────────────────────── */
body.as-scope .table--bordered tbody td {
  border-right: 1px solid var(--border);
}

body.as-scope .table--bordered tbody td:last-child {
  border-right: 0;
}

body.as-scope .table--bordered thead th {
  border-right: 1px solid var(--border);
}

body.as-scope .table--bordered thead th:last-child {
  border-right: 0;
}

/* ─── Variant: --hover (forza hover anche se default) ─────────────────── */
body.as-scope .table--hover tbody tr {
  cursor: pointer;
}

body.as-scope .table--hover tbody tr:hover {
  background: var(--surface-2);
}

/* ─── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  body.as-scope .table {
    font-size: var(--t-sm);
  }

  body.as-scope .table thead th, body.as-scope .table tbody td {
    padding: var(--s-2) var(--s-3);
  }
}

/* ─── Focus row a11y ──────────────────────────────────────────────────── */
body.as-scope .table tbody tr:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}


/* === src\components\modal.css === */
/* ==========================================================================
   Modal — <dialog> nativo HTML5
   ========================================================================== */

body.as-scope .modal {
  padding: 0;
  margin: auto;
  border: 0;
  background: transparent;
  color: var(--text);
  max-width: 92vw;
  max-height: 92vh;
  z-index: var(--z-modal);
  overflow: visible;
}

body.as-scope dialog::backdrop {
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
}

body.as-scope .modal[open] {
  display: flex;
  flex-direction: column;
  animation: modal-grow-in var(--t-fast) var(--ease-out);
}

body.as-scope dialog::backdrop {
  animation: modal-fade-in var(--t-fast) var(--ease-out);
}





body.as-scope .modal__panel {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-height: 92vh;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

body.as-scope .modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

body.as-scope .modal__title {
  margin: 0;
  font-family: var(--font);
  font-size: var(--t-lg);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
}

body.as-scope .modal__sub {
  margin: var(--s-1) 0 0;
  font-size: var(--t-sm);
  color: var(--text-2);
}

body.as-scope .modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--s-7);
  height: var(--s-7);
  background: transparent;
  border: 0;
  border-radius: var(--r-md);
  color: var(--text-2);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

body.as-scope .modal__close:hover {
  background: var(--surface-2);
  color: var(--text);
}

body.as-scope .modal__close:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

body.as-scope .modal__body {
  padding: var(--s-5);
  overflow-y: auto;
  flex: 1 1 auto;
  color: var(--text);
  font-size: var(--t-base);
  line-height: var(--lh-normal);
}

body.as-scope .modal__foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-5);
  border-top: 1px solid var(--border);
  background: var(--surface);
  flex-shrink: 0;
}

body.as-scope .modal__foot--between {
  justify-content: space-between;
}

/* ─── Variants ────────────────────────────────────────────────────────── */
body.as-scope .modal--sm { width: 360px; }
body.as-scope .modal--md { width: 520px; }
body.as-scope .modal--lg { width: 720px; }
body.as-scope .modal--xl { width: 960px; }

body.as-scope .modal--full {
  width: 96vw;
  height: 92vh;
  max-width: none;
}

body.as-scope .modal--full .modal__panel {
  height: 100%;
}

@media (max-width: 640px) {
  body.as-scope .modal--sm, body.as-scope .modal--md, body.as-scope .modal--lg, body.as-scope .modal--xl {
    width: 96vw;
  }

  body.as-scope .modal__head, body.as-scope .modal__foot {
    padding: var(--s-3) var(--s-4);
  }

  body.as-scope .modal__body {
    padding: var(--s-4);
  }
}


/* === src\components\dropdown.css === */
/* ==========================================================================
   Dropdown — trigger relative, menu absolute
   ========================================================================== */

body.as-scope .dropdown {
  position: relative;
  display: inline-flex;
}

body.as-scope .dropdown__menu {
  position: absolute;
  top: calc(100% + var(--s-1));
  left: 0;
  z-index: var(--z-dropdown);
  min-width: 180px;
  max-height: 320px;
  padding: var(--s-1);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  overflow-y: auto;
  overflow-x: hidden;
  animation: dropdown-in var(--t-fast) var(--ease-out);
  transform-origin: top left;
}

body.as-scope .dropdown__menu--right {
  left: auto;
  right: 0;
  transform-origin: top right;
}

body.as-scope .dropdown__menu[hidden], body.as-scope .dropdown__menu[aria-hidden="true"] {
  display: none;
}



body.as-scope .dropdown__item {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  width: 100%;
  padding: var(--s-2) var(--s-3);
  background: transparent;
  border: 0;
  border-radius: var(--r-md);
  color: var(--text);
  font-family: var(--font);
  font-size: var(--t-base);
  font-weight: var(--fw-normal);
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

body.as-scope .dropdown__item:hover, body.as-scope .dropdown__item:focus-visible {
  background: var(--surface-2);
  outline: none;
}

body.as-scope .dropdown__item[aria-selected="true"] {
  background: var(--accent-bg);
  color: var(--accent-text);
}

body.as-scope .dropdown__item[disabled], body.as-scope .dropdown__item[aria-disabled="true"] {
  color: var(--text-disabled);
  cursor: not-allowed;
  pointer-events: none;
}

body.as-scope .dropdown__item--danger {
  color: var(--danger-text);
}

body.as-scope .dropdown__item--danger:hover, body.as-scope .dropdown__item--danger:focus-visible {
  background: var(--danger-bg);
}

body.as-scope .dropdown__item-icon {
  display: inline-flex;
  width: var(--s-4);
  height: var(--s-4);
  flex-shrink: 0;
  color: var(--text-2);
}

body.as-scope .dropdown__item-shortcut {
  margin-left: auto;
  padding-left: var(--s-4);
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
}

body.as-scope .dropdown__divider {
  height: 1px;
  margin: var(--s-1) 0;
  background: var(--border);
  border: 0;
}

body.as-scope .dropdown__header {
  padding: var(--s-2) var(--s-3) var(--s-1);
  font-size: var(--t-xs);
  font-weight: var(--fw-medium);
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}


/* === src\components\toast.css === */
/* ==========================================================================
   Toast — bottom-right stack, slide-in dx, status border-left
   ========================================================================== */

body.as-scope .toast-container {
  position: fixed;
  right: var(--s-4);
  bottom: var(--s-4);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column-reverse;
  gap: var(--s-2);
  pointer-events: none;
  width: min(360px, calc(100vw - var(--s-7)));
}

body.as-scope .toast-container > .toast:nth-child(n + 5) {
  display: none;
}

body.as-scope .toast {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--text-3);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  color: var(--text);
  font-family: var(--font);
  font-size: var(--t-base);
  line-height: var(--lh-snug);
  pointer-events: auto;
  overflow: hidden;
  animation: toast-slide-in var(--t-base) var(--ease-out);
}

body.as-scope .toast--leaving {
  animation: toast-slide-out var(--t-fast) var(--ease-in) forwards;
}





body.as-scope .toast__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: var(--s-5);
  height: var(--s-5);
  margin-top: 1px;
  color: var(--text-2);
}

body.as-scope .toast__body {
  flex: 1 1 auto;
  min-width: 0;
}

body.as-scope .toast__title {
  display: block;
  font-weight: var(--fw-semibold);
  font-size: var(--t-md);
  margin-bottom: var(--s-1);
}

body.as-scope .toast__msg {
  display: block;
  color: var(--text-2);
  font-size: var(--t-sm);
}

body.as-scope .toast__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: var(--s-5);
  height: var(--s-5);
  background: transparent;
  border: 0;
  color: var(--text-3);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}

body.as-scope .toast__close:hover {
  color: var(--text);
  background: var(--surface-2);
}

/* Auto-dismiss visual countdown bar */
body.as-scope .toast__progress {
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  background: currentColor;
  opacity: 0.4;
  transform-origin: left;
  animation: toast-countdown var(--toast-duration, 5s) linear forwards;
}



/* ─── Variants ────────────────────────────────────────────────────────── */
body.as-scope .toast--success {
  border-left-color: var(--success);
}
body.as-scope .toast--success .toast__icon { color: var(--success); }
body.as-scope .toast--success .toast__progress { color: var(--success); }

body.as-scope .toast--error {
  border-left-color: var(--danger);
}
body.as-scope .toast--error .toast__icon { color: var(--danger); }
body.as-scope .toast--error .toast__progress { color: var(--danger); }

body.as-scope .toast--warning {
  border-left-color: var(--warning);
}
body.as-scope .toast--warning .toast__icon { color: var(--warning); }
body.as-scope .toast--warning .toast__progress { color: var(--warning); }

body.as-scope .toast--info {
  border-left-color: var(--info);
}
body.as-scope .toast--info .toast__icon { color: var(--info); }
body.as-scope .toast--info .toast__progress { color: var(--info); }

@media (max-width: 480px) {
  body.as-scope .toast-container {
    left: var(--s-3);
    right: var(--s-3);
    bottom: var(--s-3);
    width: auto;
  }
}


/* === src\components\skeleton.css === */
/* ==========================================================================
   Skeleton — shimmer è l'unica animation infinite consentita
   ========================================================================== */

body.as-scope .skel {
  position: relative;
  display: block;
  background: var(--surface-2);
  border-radius: var(--r-md);
  overflow: hidden;
  user-select: none;
  pointer-events: none;
}

body.as-scope .skel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0,
    var(--surface-3) 50%,
    transparent 100%
  );
  transform: translateX(-100%);
  animation: skel-shimmer 1.5s var(--ease) infinite;
}



@media (prefers-reduced-motion: reduce) {
  body.as-scope .skel::after {
    animation: none;
  }
}

/* ─── Variants ────────────────────────────────────────────────────────── */
body.as-scope .skel--text {
  height: var(--s-3);
  width: 100%;
  border-radius: var(--r-sm);
}

body.as-scope .skel--text + .skel--text {
  margin-top: var(--s-2);
}

body.as-scope .skel--text:last-child {
  width: 70%;
}

body.as-scope .skel--block {
  width: 100%;
  height: var(--s-10);
  border-radius: var(--r-lg);
}

body.as-scope .skel--circle {
  width: var(--s-7);
  height: var(--s-7);
  border-radius: var(--r-pill);
}

/* List = avatar + 2 lines stacked */
body.as-scope .skel--list {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3);
  background: transparent;
}

body.as-scope .skel--list::after { content: none; }

body.as-scope .skel--list .skel__avatar {
  width: var(--s-7);
  height: var(--s-7);
  border-radius: var(--r-pill);
  flex-shrink: 0;
}

body.as-scope .skel--list .skel__lines {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}

/* Table skeleton — N rows of bars */
body.as-scope .skel--table {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-3);
  background: transparent;
}

body.as-scope .skel--table::after { content: none; }

body.as-scope .skel--table .skel__row {
  height: var(--s-5);
  width: 100%;
  border-radius: var(--r-sm);
}

/* Stat skeleton — KPI card placeholder */
body.as-scope .skel--stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-4);
  background: transparent;
}

body.as-scope .skel--stat::after { content: none; }

body.as-scope .skel--stat .skel__label {
  width: 40%;
  height: var(--s-3);
  border-radius: var(--r-sm);
}

body.as-scope .skel--stat .skel__value {
  width: 60%;
  height: var(--s-7);
  border-radius: var(--r-md);
}


/* === src\components\empty.css === */
/* ==========================================================================
   Empty state — centered, icon + title + sub + cta
   ========================================================================== */

body.as-scope .empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--s-8) var(--s-6);
  color: var(--text-2);
  font-family: var(--font);
}

body.as-scope .empty__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--s-8);
  height: var(--s-8);
  margin-bottom: var(--s-4);
  color: var(--text-3);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

body.as-scope .empty__icon > svg {
  width: var(--s-5);
  height: var(--s-5);
}

body.as-scope .empty__title {
  margin: 0 0 var(--s-1);
  font-size: var(--t-md);
  font-weight: var(--fw-semibold);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
}

body.as-scope .empty__sub {
  margin: 0;
  max-width: 42ch;
  font-size: var(--t-sm);
  color: var(--text-2);
  line-height: var(--lh-normal);
}

body.as-scope .empty__cta {
  margin-top: var(--s-4);
  display: inline-flex;
  gap: var(--s-2);
}


/* === src\pages\dashboard.css === */
/* ==========================================================================
   Art Stone Dashboard — page styles
   ========================================================================== */

body.as-scope .as-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: var(--t-base);
  line-height: var(--lh-normal);
  overflow-y: auto;
  overscroll-behavior: contain;
}

body.as-scope .as-overlay--solo {
  position: static;
  inset: auto;
  z-index: auto;
  min-height: 100vh;
}

body.as-scope .as-shell {
  max-width: var(--container-2xl);
  margin: 0 auto;
  padding: 0 var(--s-6);
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

/* Header ──────────────────────────────────────────────────────────────── */
body.as-scope .as-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-5);
  height: var(--header-h);
  padding: 0 var(--s-2);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border);
}

body.as-scope .as-header__brand {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  min-width: 0;
}

body.as-scope .as-header__logo {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: var(--r-md);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: var(--t-md);
}

body.as-scope .as-header__title {
  font-size: var(--t-md);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  white-space: nowrap;
}

body.as-scope .as-header__subtitle {
  font-size: var(--t-xs);
  color: var(--text-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

body.as-scope .as-header__center {
  display: flex;
  justify-content: center;
  min-width: 0;
}

body.as-scope .as-header__actions {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  justify-self: end;
}

body.as-scope .as-header__btn {
  composes: btn;
}

/* Bot status (admin) ──────────────────────────────────────────────────── */
body.as-scope .as-bot-status {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-md);
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: var(--t-xs);
  color: var(--text-2);
  white-space: nowrap;
}

body.as-scope .as-bot-status__meta {
  display: flex;
  flex-direction: column;
  line-height: var(--lh-tight);
}

body.as-scope .as-bot-status__line {
  color: var(--text);
  font-weight: var(--fw-medium);
}

body.as-scope .as-bot-status__sub {
  color: var(--text-3);
  font-size: var(--t-2xs);
}

body.as-scope .as-bot-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: var(--r-pill);
  background: var(--text-disabled);
  flex-shrink: 0;
}

body.as-scope .as-bot-dot--ok { background: var(--success); }
body.as-scope .as-bot-dot--err { background: var(--danger); }
body.as-scope .as-bot-dot--off { background: var(--text-disabled); }
body.as-scope .as-bot-dot--run {
  background: var(--accent);
  animation: as-bot-dot-pulse 1.5s var(--ease) infinite;
}



/* Stats grid ──────────────────────────────────────────────────────────── */
body.as-scope .as-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  padding: var(--s-5) 0;
}

body.as-scope .as-stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  padding: var(--s-4) var(--s-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color var(--t-fast) var(--ease);
}

body.as-scope .as-stat:hover {
  border-color: var(--border-strong);
}

body.as-scope .as-stat__label {
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-2);
  font-weight: var(--fw-medium);
}

body.as-scope .as-stat__value {
  font-size: var(--t-3xl);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-tighter);
  color: var(--text);
  line-height: var(--lh-tight);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-stat__sub {
  font-size: var(--t-xs);
  color: var(--text-3);
  margin-top: var(--s-1);
}

body.as-scope .as-stat__sub--up { color: var(--success-text); }
body.as-scope .as-stat__sub--down { color: var(--danger-text); }

/* Banner ──────────────────────────────────────────────────────────────── */
body.as-scope .as-banner {
  position: sticky;
  top: var(--header-h);
  z-index: calc(var(--z-sticky) - 1);
  padding: var(--s-3) var(--s-5);
  background: var(--info-bg);
  border-bottom: 1px solid var(--info-border);
  color: var(--info-text);
  font-size: var(--t-sm);
}

body.as-scope .as-banner--success { background: var(--success-bg); border-color: var(--success-border); color: var(--success-text); }
body.as-scope .as-banner--warning { background: var(--warning-bg); border-color: var(--warning-border); color: var(--warning-text); }
body.as-scope .as-banner--danger { background: var(--danger-bg);  border-color: var(--danger-border);  color: var(--danger-text); }

/* Tabs row ────────────────────────────────────────────────────────────── */
body.as-scope .as-tabs {
  position: sticky;
  top: var(--header-h);
  z-index: calc(var(--z-sticky) - 2);
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  padding: 0 var(--s-2);
  transition: box-shadow var(--t-fast) var(--ease);
}

body.as-scope .as-tabs--scrolled {
  box-shadow: var(--shadow-xs);
}

body.as-scope .as-tabs--with-banner {
  top: calc(var(--header-h) + var(--tabs-h));
}

/* Content ─────────────────────────────────────────────────────────────── */
body.as-scope .as-content {
  flex: 1;
  max-width: var(--container-2xl);
  margin: 0 auto;
  width: 100%;
  padding: var(--s-6) 0 var(--s-10);
}

body.as-scope .as-content--loading {
  opacity: 0.6;
  pointer-events: none;
}

/* Mobile ──────────────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  body.as-scope .as-shell {
    padding: 0 var(--s-3);
  }

  body.as-scope .as-header {
    grid-template-columns: auto 1fr auto;
    gap: var(--s-2);
    height: auto;
    min-height: var(--header-h);
    padding: var(--s-2);
  }

  body.as-scope .as-header__subtitle {
    display: none;
  }

  body.as-scope .as-bot-status__meta {
    display: none;
  }

  body.as-scope .as-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s-2);
    padding: var(--s-3) 0;
  }

  body.as-scope .as-stat {
    padding: var(--s-3) var(--s-4);
  }

  body.as-scope .as-stat__value {
    font-size: var(--t-2xl);
  }

  body.as-scope .as-content {
    padding: var(--s-4) 0 var(--s-9);
  }
}


/* === src\pages\xml-orders.css === */
/* ==========================================================================
   Art Stone XML Orders — page styles
   ========================================================================== */

body.as-scope .as-xml-tab {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}

/* Analytics collapsible ──────────────────────────────────────────────── */
body.as-scope .as-xml-analytics {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

body.as-scope .as-xml-analytics__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: transparent;
  border: 0;
  width: 100%;
  text-align: left;
  color: var(--text);
  font-family: inherit;
  font-size: var(--t-sm);
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: background-color var(--t-fast) var(--ease);
}

body.as-scope .as-xml-analytics__head:hover {
  background: var(--surface-2);
}

body.as-scope .as-xml-analytics__chevron {
  color: var(--text-3);
  font-size: var(--t-xs);
  transition: transform var(--t-fast) var(--ease);
}

body.as-scope .as-xml-analytics--open .as-xml-analytics__chevron {
  transform: rotate(90deg);
}

body.as-scope .as-xml-analytics__meta {
  font-size: var(--t-xs);
  color: var(--text-3);
  font-weight: var(--fw-normal);
}

body.as-scope .as-xml-analytics__body {
  padding: var(--s-4);
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4);
}

body.as-scope .as-xml-analytics__card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-3);
}

body.as-scope .as-xml-analytics__card-title {
  font-size: var(--t-2xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-2);
  margin-bottom: var(--s-2);
}

/* Toolbar ─────────────────────────────────────────────────────────────── */
body.as-scope .as-xml-toolbar {
  position: sticky;
  top: calc(var(--header-h) + var(--tabs-h));
  z-index: calc(var(--z-sticky) - 3);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-3);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}

body.as-scope .as-xml-toolbar__search {
  flex: 1 1 240px;
  min-width: 200px;
}

body.as-scope .as-xml-toolbar__select {
  flex: 0 0 auto;
  min-width: 160px;
}

body.as-scope .as-xml-toolbar__check {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: var(--t-sm);
  color: var(--text-2);
  cursor: pointer;
  transition: background-color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}

body.as-scope .as-xml-toolbar__check:hover {
  background: var(--surface-2);
  border-color: var(--border-strong);
}

body.as-scope .as-xml-toolbar__check input {
  accent-color: var(--accent);
  cursor: pointer;
}

body.as-scope .as-xml-toolbar__spacer {
  flex: 1;
}

body.as-scope .as-xml-toolbar__info {
  font-size: var(--t-xs);
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* Bulk action bar ────────────────────────────────────────────────────── */
body.as-scope .as-xml-bulk-bar {
  position: sticky;
  top: calc(var(--header-h) + var(--tabs-h) + 56px);
  z-index: calc(var(--z-sticky) - 4);
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  border-radius: var(--r-md);
  animation: as-bulk-slide-in var(--t-base) var(--ease-out);
}



body.as-scope .as-xml-bulk-bar__count {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: var(--r-pill);
  font-size: var(--t-xs);
  font-weight: var(--fw-semibold);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-xml-bulk-bar__label {
  font-size: var(--t-sm);
  color: var(--accent-text);
}

body.as-scope .as-xml-bulk-bar__actions {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin-left: auto;
  flex-wrap: wrap;
}

/* Table ───────────────────────────────────────────────────────────────── */
body.as-scope .as-xml-table-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

body.as-scope .as-xml-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--t-sm);
}

body.as-scope .as-xml-table thead th {
  position: sticky;
  top: calc(var(--header-h) + var(--tabs-h) + 56px);
  z-index: 1;
  padding: var(--s-3) var(--s-4);
  text-align: left;
  font-size: var(--t-2xs);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-2);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

body.as-scope .as-xml-table tbody td {
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}

body.as-scope .as-xml-table tbody tr:last-child td {
  border-bottom: 0;
}

body.as-scope .as-xml-row {
  transition: background-color var(--t-fast) var(--ease);
}

body.as-scope .as-xml-row:hover {
  background: var(--surface-2);
}

body.as-scope .as-xml-row--selected {
  background: var(--accent-bg);
}

body.as-scope .as-xml-row--selected:hover {
  background: var(--accent-bg-hover);
}

body.as-scope .as-xml-row--trashed {
  opacity: 0.5;
}

body.as-scope .as-xml-row--trashed:hover {
  background: transparent;
}

body.as-scope .as-xml-row__checkbox {
  width: 40px;
  text-align: center;
  padding: var(--s-1);
}

body.as-scope .as-xml-row__checkbox input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
  cursor: pointer;
}

body.as-scope .as-xml-row__num {
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-medium);
  white-space: nowrap;
}

body.as-scope .as-xml-row__cliente {
  min-width: 180px;
  max-width: 280px;
}

body.as-scope .as-xml-row__cliente-name {
  color: var(--text);
  font-weight: var(--fw-medium);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.as-scope .as-xml-row__cliente-cod {
  font-size: var(--t-xs);
  color: var(--text-3);
}

body.as-scope .as-xml-row__rif {
  color: var(--text-2);
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.as-scope .as-xml-row__date, body.as-scope .as-xml-row__size {
  color: var(--text-3);
  font-size: var(--t-xs);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

body.as-scope .as-xml-ver-badge {
  display: inline-flex;
  align-items: center;
  margin-left: var(--s-2);
  padding: 0 var(--s-2);
  height: 18px;
  font-size: var(--t-2xs);
  font-weight: var(--fw-semibold);
  color: var(--accent-text);
  background: var(--accent-bg);
  border: 1px solid var(--accent-border);
  border-radius: var(--r-pill);
  font-variant-numeric: tabular-nums;
}

/* Status chip ─────────────────────────────────────────────────────────── */
body.as-scope .as-xml-status {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-pill);
  font-size: var(--t-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
  white-space: nowrap;
}

body.as-scope .as-xml-status--no { background: var(--warning-bg); color: var(--warning-text); border-color: var(--warning-border); }
body.as-scope .as-xml-status--mod { background: var(--info-bg);    color: var(--info-text);    border-color: var(--info-border); }
body.as-scope .as-xml-status--gok { background: var(--info-bg);    color: var(--info-text);    border-color: var(--info-border); }
body.as-scope .as-xml-status--lav { background: var(--accent-bg);  color: var(--accent-text);  border-color: var(--accent-border); }
body.as-scope .as-xml-status--prod { background: var(--success-bg); color: var(--success-text); border-color: var(--success-border); }
body.as-scope .as-xml-status--err { background: var(--danger-bg);  color: var(--danger-text);  border-color: var(--danger-border); }
body.as-scope .as-xml-status--cestino {
  background: var(--surface-2);
  color: var(--text-3);
  border-color: var(--border);
}

/* Status select (in-row edit) ────────────────────────────────────────── */
body.as-scope .as-xml-status-select {
  appearance: none;
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-7) var(--s-1) var(--s-3);
  height: 26px;
  font-family: inherit;
  font-size: var(--t-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background-color: var(--surface-2);
  color: var(--text);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%239ba1ab' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--s-3) center;
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}

body.as-scope .as-xml-status-select:hover {
  border-color: var(--border-strong);
}

body.as-scope .as-xml-status-select:focus-visible {
  outline: 0;
  box-shadow: var(--ring-focus-thin);
  border-color: var(--accent);
}

body.as-scope .as-xml-status-select--manual {
  border-style: dashed;
  border-color: var(--accent-border);
}

/* Row actions ─────────────────────────────────────────────────────────── */
body.as-scope .as-xml-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  white-space: nowrap;
}

body.as-scope .as-xml-actions__btn {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--r-md);
  background: transparent;
  border: 1px solid transparent;
  color: var(--text-2);
  cursor: pointer;
  transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}

body.as-scope .as-xml-actions__btn:hover {
  background: var(--surface-3);
  color: var(--text);
  border-color: var(--border);
}

body.as-scope .as-xml-actions__btn:focus-visible {
  outline: 0;
  box-shadow: var(--ring-focus-thin);
}

body.as-scope .as-xml-actions__btn--active {
  color: var(--accent-text);
  background: var(--accent-bg);
}

body.as-scope .as-xml-actions__btn--danger:hover {
  color: var(--danger-text);
  background: var(--danger-bg);
  border-color: var(--danger-border);
}

/* Note indicator (filled vs outline) ─────────────────────────────────── */
body.as-scope .as-xml-note-indicator {
  display: inline-grid;
  place-items: center;
  width: 16px;
  height: 16px;
  color: var(--text-3);
}

body.as-scope .as-xml-note-indicator--filled {
  color: var(--accent-text);
}

/* Empty state ─────────────────────────────────────────────────────────── */
body.as-scope .as-xml-empty {
  padding: var(--s-10) var(--s-4);
  text-align: center;
  color: var(--text-3);
  font-size: var(--t-sm);
}

body.as-scope .as-xml-empty__title {
  color: var(--text-2);
  font-size: var(--t-md);
  font-weight: var(--fw-medium);
  margin-bottom: var(--s-2);
}

/* Mobile ──────────────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  body.as-scope .as-xml-toolbar {
    position: static;
    padding: var(--s-2);
    gap: var(--s-2);
  }

  body.as-scope .as-xml-toolbar__search, body.as-scope .as-xml-toolbar__select {
    flex: 1 1 100%;
    min-width: 0;
  }

  body.as-scope .as-xml-toolbar__info {
    width: 100%;
    text-align: right;
  }

  body.as-scope .as-xml-bulk-bar {
    position: sticky;
    top: auto;
    bottom: var(--s-3);
    flex-wrap: wrap;
    gap: var(--s-2);
    padding: var(--s-2) var(--s-3);
    box-shadow: var(--shadow-md);
  }

  body.as-scope .as-xml-bulk-bar__actions {
    width: 100%;
    margin-left: 0;
  }

  body.as-scope .as-xml-table-wrap {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  body.as-scope .as-xml-table {
    min-width: 720px;
  }

  body.as-scope .as-xml-table thead th:first-child, body.as-scope .as-xml-table tbody td:first-child {
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--bg-elevated);
  }

  body.as-scope .as-xml-row:hover td:first-child {
    background: var(--surface-2);
  }

  body.as-scope .as-xml-row--selected td:first-child {
    background: var(--accent-bg);
  }

  body.as-scope .as-xml-table thead th, body.as-scope .as-xml-table tbody td {
    scroll-snap-align: start;
  }

  body.as-scope .as-xml-row__checkbox input {
    width: 22px;
    height: 22px;
  }

  body.as-scope .as-xml-actions__btn {
    width: 44px;
    height: 44px;
  }

  body.as-scope .as-xml-analytics__body {
    grid-template-columns: 1fr;
    gap: var(--s-3);
  }
}


/* === src\pages\db-crud.css === */
/* ==========================================================================
   Page — DB CRUD (clienti / prodotti / ceramiche / ricordini)
   Estende: .table --compact, .input, .btn, .modal --md, .field, .badge
   ========================================================================== */

/* === wrapper === */
body.as-scope .as-db-tab {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-4);
  min-height: 100%;
}

/* === toolbar === */
body.as-scope .as-db-toolbar {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

body.as-scope .as-db-toolbar__search {
  flex: 1 1 240px;
  min-width: 200px;
  max-width: 480px;
}

body.as-scope .as-db-toolbar__cta {
  flex-shrink: 0;
}

body.as-scope .as-db-toolbar__menu {
  position: relative;
  flex-shrink: 0;
}

body.as-scope .as-db-toolbar__menu-trigger {
  height: 36px;
  padding: 0 var(--s-3);
}

body.as-scope .as-db-toolbar__menu-list {
  position: absolute;
  top: calc(100% + var(--s-1));
  right: 0;
  z-index: var(--z-dropdown);
  min-width: 200px;
  padding: var(--s-1);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-md);
  display: none;
}

body.as-scope .as-db-toolbar__menu[aria-expanded="true"] .as-db-toolbar__menu-list {
  display: block;
}

body.as-scope .as-db-toolbar__menu-item {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  width: 100%;
  height: 32px;
  padding: 0 var(--s-3);
  background: transparent;
  border: 0;
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: var(--t-sm);
  text-align: left;
  cursor: pointer;
}

body.as-scope .as-db-toolbar__menu-item:hover { background: var(--surface-2); }

body.as-scope .as-db-toolbar__count {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-sm);
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-db-toolbar__count strong {
  color: var(--text);
  font-weight: var(--fw-semibold);
}

/* === table === */
body.as-scope .as-db-table {
  flex: 1 1 auto;
  min-height: 0;
}

body.as-scope .as-db-table .table thead th {
  background: var(--bg-elevated);
}

body.as-scope .as-db-cell {
  position: relative;
  min-height: 32px;
  padding: var(--s-2) var(--s-3);
  cursor: text;
  border-radius: var(--r-sm);
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  outline: 1px solid transparent;
  outline-offset: -1px;
}

body.as-scope .as-db-cell:hover {
  background: var(--surface-2);
}

body.as-scope .as-db-cell:focus, body.as-scope .as-db-cell[contenteditable="true"]:focus {
  outline-color: var(--accent);
  background: var(--bg-elevated);
}

body.as-scope .as-db-cell--readonly {
  opacity: 0.7;
  cursor: default;
  color: var(--text-2);
}

body.as-scope .as-db-cell--readonly:hover {
  background: transparent;
}

body.as-scope .as-db-table__editing {
  background: var(--surface-2);
  outline: 1px solid var(--accent);
  outline-offset: -1px;
}

body.as-scope .as-db-table__editing input {
  width: 100%;
  height: 28px;
  padding: 0 var(--s-2);
  background: var(--bg-elevated);
  color: var(--text);
  border: 1px solid var(--accent);
  border-radius: var(--r-sm);
  font: inherit;
}

body.as-scope .as-db-table__editing input:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--accent-bg);
}

/* === actions column === */
body.as-scope .as-db-actions-col {
  width: 1%;
  white-space: nowrap;
  text-align: right;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-1);
}

@media (max-width: 768px) {
  body.as-scope .as-db-actions-col {
    position: sticky;
    right: 0;
    background: var(--surface);
    box-shadow: var(--shadow-xs);
  }
}

/* === footer / pagination === */
body.as-scope .as-db-footer {
  position: sticky;
  bottom: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--bg-elevated);
  border-top: 1px solid var(--border);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
}

body.as-scope .as-db-footer__info {
  font-size: var(--t-sm);
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-db-pagination {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}

body.as-scope .as-db-pagination__page {
  font-size: var(--t-sm);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  min-width: var(--s-9);
  text-align: center;
}

body.as-scope .as-db-pagination__size {
  height: 28px;
  padding: 0 var(--s-2);
  font-size: var(--t-sm);
}

/* === record editor (modal) === */
body.as-scope .as-record-editor .modal__body {
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}

body.as-scope .as-record-editor__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--s-3) var(--s-4);
}

body.as-scope .as-record-editor__photos {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding-top: var(--s-3);
  border-top: 1px solid var(--border);
}

body.as-scope .as-record-editor__photos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-2);
}

body.as-scope .as-record-editor__photo {
  position: relative;
  aspect-ratio: 1 / 1;
  width: 80px;
  height: 80px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}

body.as-scope .as-record-editor__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.as-scope .as-record-editor__photo-remove {
  position: absolute;
  top: var(--s-1);
  right: var(--s-1);
  width: var(--s-5);
  height: var(--s-5);
  border: 0;
  border-radius: var(--r-sm);
  background: var(--bg);
  color: var(--text);
  font-size: var(--t-xs);
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--t-fast) var(--ease);
}

body.as-scope .as-record-editor__photo:hover .as-record-editor__photo-remove {
  opacity: 1;
}

body.as-scope .as-record-editor__delete {
  margin-top: var(--s-3);
  padding-top: var(--s-4);
  border-top: 1px solid var(--danger-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}

body.as-scope .as-record-editor__delete-label {
  font-size: var(--t-sm);
  color: var(--text-2);
}

@media (max-width: 640px) {
  body.as-scope .as-db-toolbar { padding: var(--s-2) var(--s-3); }
  body.as-scope .as-db-toolbar__count { width: 100%; justify-content: flex-end; }
  body.as-scope .as-record-editor__grid { grid-template-columns: 1fr; }
  body.as-scope .as-record-editor__photos-grid { grid-template-columns: repeat(3, 1fr); }
}


/* === src\pages\ingest.css === */
/* ==========================================================================
   Page — Ingest (drag&drop nuovi dati)
   Estende: .btn --primary --lg, .card, .table --compact, .badge
   ========================================================================== */

/* === wrapper === */
body.as-scope .as-ingest-tab {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  padding: var(--s-4);
}

/* === status banner === */
body.as-scope .as-ingest-status {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--surface);
  font-size: var(--t-sm);
  color: var(--text);
}

body.as-scope .as-ingest-status--success {
  background: var(--success-bg);
  border-color: var(--success-border);
  color: var(--success-text);
}

body.as-scope .as-ingest-status--error {
  background: var(--danger-bg);
  border-color: var(--danger-border);
  color: var(--danger-text);
}

/* === dropzone === */
body.as-scope .as-ingest-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--s-3);
  min-height: 240px;
  padding: var(--s-9);
  background: var(--surface);
  border: 2px dashed var(--border);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}

body.as-scope .as-ingest-dropzone:hover, body.as-scope .as-ingest-dropzone--dragover {
  border-color: var(--accent);
  background: var(--accent-bg);
}

body.as-scope .as-ingest-dropzone--busy {
  pointer-events: none;
  opacity: 0.7;
}

body.as-scope .as-ingest-dropzone__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--s-9);
  height: var(--s-9);
  color: var(--text-2);
  background: var(--surface-2);
  border-radius: var(--r-lg);
}

body.as-scope .as-ingest-dropzone__icon svg {
  width: var(--s-7);
  height: var(--s-7);
}

body.as-scope .as-ingest-dropzone__title {
  margin: 0;
  font-size: var(--t-lg);
  font-weight: var(--fw-medium);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
}

body.as-scope .as-ingest-dropzone__sub {
  margin: 0;
  max-width: 48ch;
  font-size: var(--t-sm);
  color: var(--text-2);
  line-height: var(--lh-normal);
}

body.as-scope .as-ingest-dropzone__cta {
  margin-top: var(--s-2);
}

body.as-scope .as-ingest-dropzone__cta input[type="file"] {
  display: none;
}

body.as-scope .as-ingest-formats {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-xs);
  color: var(--text-3);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* === preview after upload === */
body.as-scope .as-ingest-preview {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

body.as-scope .as-ingest-preview__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--border);
}

body.as-scope .as-ingest-preview__file {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-sm);
  font-weight: var(--fw-medium);
  color: var(--text);
}

body.as-scope .as-ingest-preview__meta {
  font-size: var(--t-xs);
  color: var(--text-3);
}

body.as-scope .as-ingest-preview__body {
  padding: var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

body.as-scope .as-ingest-preview__count {
  font-size: var(--t-sm);
  color: var(--text-2);
}

body.as-scope .as-ingest-preview__count strong {
  color: var(--text);
  font-weight: var(--fw-semibold);
}

body.as-scope .as-ingest-preview__table {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--bg-elevated);
}

body.as-scope .as-ingest-preview__table .table tbody td {
  font-size: var(--t-sm);
  padding: var(--s-1) var(--s-3);
}

/* === column mapping === */
body.as-scope .as-ingest-preview__map {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--s-2) var(--s-3);
  align-items: center;
  padding: var(--s-3);
  background: var(--surface-2);
  border-radius: var(--r-md);
}

body.as-scope .as-ingest-preview__map-label {
  font-size: var(--t-sm);
  color: var(--text-2);
  font-family: var(--font-mono);
}

body.as-scope .as-ingest-preview__map-arrow {
  color: var(--text-3);
  font-size: var(--t-sm);
  text-align: center;
}

body.as-scope .as-ingest-preview__map select {
  height: 32px;
  font-size: var(--t-sm);
}

body.as-scope .as-ingest-preview__foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  border-top: 1px solid var(--border);
  background: var(--surface);
}

@media (max-width: 640px) {
  body.as-scope .as-ingest-dropzone { padding: var(--s-6); min-height: 200px; }
  body.as-scope .as-ingest-preview__map { grid-template-columns: 1fr; }
  body.as-scope .as-ingest-preview__map-arrow { display: none; }
}


/* === src\pages\reports.css === */
/* ==========================================================================
   Page — Reports (segnalazioni con auto-analisi Luna)
   Estende: .card --interactive, .badge, .btn
   ========================================================================== */

/* === wrapper === */
body.as-scope .as-reports-tab {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-4);
}

/* === toolbar === */
body.as-scope .as-reports-toolbar {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

body.as-scope .as-reports-toolbar__filter {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  padding: var(--s-1);
  background: var(--surface-2);
  border-radius: var(--r-md);
}

body.as-scope .as-reports-toolbar__filter button {
  height: 28px;
  padding: 0 var(--s-3);
  background: transparent;
  border: 0;
  border-radius: var(--r-sm);
  color: var(--text-2);
  font-size: var(--t-sm);
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

body.as-scope .as-reports-toolbar__filter button:hover { color: var(--text); }

body.as-scope .as-reports-toolbar__filter button[aria-pressed="true"] {
  background: var(--bg-elevated);
  color: var(--text);
  box-shadow: var(--shadow-xs);
}

body.as-scope .as-reports-toolbar__count {
  margin-left: auto;
  font-size: var(--t-sm);
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}

/* === list === */
body.as-scope .as-reports-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

/* === card === */
body.as-scope .as-report-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--t-fast) var(--ease);
}

body.as-scope .as-report-card:hover {
  border-color: var(--border-strong);
}

body.as-scope .as-report-card--open {
  border-color: var(--warning-border);
}

body.as-scope .as-report-card--working {
  border-color: var(--accent-border);
}

body.as-scope .as-report-card--done {
  opacity: 0.7;
}

body.as-scope .as-report-card--error {
  border-color: var(--danger-border);
}

/* === card head === */
body.as-scope .as-report-card__head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  cursor: pointer;
  user-select: none;
}

body.as-scope .as-report-card__head:hover { background: var(--surface-2); }

body.as-scope .as-report-card__status {
  flex-shrink: 0;
}

body.as-scope .as-report-card__title {
  flex: 1 1 auto;
  min-width: 0;
  font-size: var(--t-md);
  font-weight: var(--fw-medium);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.as-scope .as-report-card__time {
  flex-shrink: 0;
  font-size: var(--t-sm);
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-report-card__chevron {
  flex-shrink: 0;
  width: var(--s-5);
  height: var(--s-5);
  color: var(--text-3);
  transition: transform var(--t-fast) var(--ease);
}

body.as-scope .as-report-card[aria-expanded="true"] .as-report-card__chevron {
  transform: rotate(180deg);
}

/* === card body (collassato by default) === */
body.as-scope .as-report-card__body {
  display: none;
  padding: var(--s-4);
  border-top: 1px solid var(--border);
  background: var(--bg-elevated);
}

body.as-scope .as-report-card[aria-expanded="true"] .as-report-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

body.as-scope .as-report-card__issue {
  font-size: var(--t-sm);
  color: var(--text);
  line-height: var(--lh-normal);
}

/* === callout interno (analisi / learning) === */
body.as-scope .as-report-card__callout {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-3);
  border-radius: var(--r-md);
  border-left: 3px solid var(--border);
  background: var(--surface);
}

body.as-scope .as-report-card__callout-head {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-2);
}

body.as-scope .as-report-card__callout-icon {
  width: var(--s-4);
  height: var(--s-4);
}

body.as-scope .as-report-card__callout-body {
  font-size: var(--t-sm);
  color: var(--text);
  line-height: var(--lh-normal);
  white-space: pre-wrap;
}

body.as-scope .as-report-card__callout--analysis {
  background: var(--surface-2);
  border-left-color: var(--text-2);
}

body.as-scope .as-report-card__callout--learning {
  background: var(--accent-bg);
  border-left-color: var(--accent);
}

body.as-scope .as-report-card__callout--learning .as-report-card__callout-head {
  color: var(--accent-text);
}

/* === actions === */
body.as-scope .as-report-card__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-2);
  padding-top: var(--s-3);
  border-top: 1px solid var(--border);
}

/* === polling state === */
body.as-scope .as-report-card--polling .as-report-card__body::after {
  content: "";
  display: block;
  height: 2px;
  background: var(--accent-bg);
  border-radius: var(--r-pill);
  position: relative;
  overflow: hidden;
}

body.as-scope .as-report-card--polling .as-report-card__title {
  color: var(--text-2);
}

/* === empty === */
body.as-scope .as-reports-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--s-9) var(--s-6);
  color: var(--text-2);
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: var(--r-lg);
}

body.as-scope .as-reports-empty__title {
  font-size: var(--t-md);
  font-weight: var(--fw-semibold);
  color: var(--text);
  margin: 0 0 var(--s-1);
}

body.as-scope .as-reports-empty__sub {
  font-size: var(--t-sm);
  color: var(--text-2);
  max-width: 42ch;
  margin: 0;
}


/* === src\pages\bot-log.css === */
/* ==========================================================================
   Page — Bot Log (admin only — runs Art Stone)
   Estende: .card, .btn, .input, .badge
   ========================================================================== */

/* === wrapper === */
body.as-scope .as-bot-tab {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-4);
}

/* === toolbar === */
body.as-scope .as-bot-toolbar {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

body.as-scope .as-bot-toolbar__search {
  flex: 1 1 200px;
  min-width: 180px;
  max-width: 360px;
}

body.as-scope .as-bot-toolbar__filter {
  height: 36px;
  min-width: 140px;
}

body.as-scope .as-bot-toolbar__refresh {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-sm);
  color: var(--text-2);
}

body.as-scope .as-bot-toolbar__refresh label {
  cursor: pointer;
}

body.as-scope .as-bot-toolbar__cta {
  margin-left: auto;
}

/* === runs list === */
body.as-scope .as-bot-runs {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

body.as-scope .as-bot-run {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--t-fast) var(--ease);
}

body.as-scope .as-bot-run:hover { border-color: var(--border-strong); }

/* === run head === */
body.as-scope .as-bot-run__head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  cursor: pointer;
  user-select: none;
}

body.as-scope .as-bot-run__head:hover { background: var(--surface-2); }

body.as-scope .as-bot-run__status {
  flex-shrink: 0;
  width: var(--s-2);
  height: var(--s-2);
  border-radius: var(--r-pill);
  background: var(--text-3);
}

body.as-scope .as-bot-run__status--success { background: var(--success); }
body.as-scope .as-bot-run__status--error { background: var(--danger); }
body.as-scope .as-bot-run__status--running { background: var(--accent); }
body.as-scope .as-bot-run__status--warning { background: var(--warning); }

body.as-scope .as-bot-run__time {
  flex-shrink: 0;
  font-size: var(--t-sm);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  font-family: var(--font-mono);
}

body.as-scope .as-bot-run__summary {
  flex: 1 1 auto;
  min-width: 0;
  font-size: var(--t-sm);
  color: var(--text-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.as-scope .as-bot-run__meta {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-size: var(--t-xs);
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}

body.as-scope .as-bot-run__meta-item {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
}

body.as-scope .as-bot-run__chevron {
  flex-shrink: 0;
  width: var(--s-5);
  height: var(--s-5);
  color: var(--text-3);
  transition: transform var(--t-fast) var(--ease);
}

body.as-scope .as-bot-run[aria-expanded="true"] .as-bot-run__chevron {
  transform: rotate(180deg);
}

/* === run body === */
body.as-scope .as-bot-run__body {
  display: none;
  padding: var(--s-3) var(--s-4);
  border-top: 1px solid var(--border);
  background: var(--bg-elevated);
}

body.as-scope .as-bot-run[aria-expanded="true"] .as-bot-run__body {
  display: block;
}

/* === pre output (parsed markdown bold/italic/code) === */
body.as-scope .as-bot-run__output {
  margin: 0;
  padding: var(--s-3);
  max-height: 400px;
  overflow-y: auto;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  line-height: var(--lh-snug);
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-word;
}

body.as-scope .as-bot-run__output strong {
  font-weight: var(--fw-semibold);
  color: var(--text);
}

body.as-scope .as-bot-run__output em {
  font-style: italic;
  color: var(--text);
}

body.as-scope .as-bot-run__output code {
  padding: 1px var(--s-1);
  background: var(--surface-2);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--text);
}

body.as-scope .as-bot-run__output a {
  color: var(--accent-text);
  text-decoration: underline;
  text-underline-offset: 2px;
}


/* === src\99-overrides.css === */
/* ==========================================================================
   Art Stone Dashboard — anti-puttanate overrides v3
   Sovrascrive i pattern visivi residui del live style.css (484KB) sui selettori
   esistenti `.as-*`, `.artstone-only-shell`, `.as-panel`, `.as-editor-fullpanel`.
   Specificita': `body.as-scope SELECTOR` (1+1+0) > `SELECTOR` (1+0).
   ========================================================================== */

/* ========================================================================== */
/* 1. ACCENT — sostituisce oro con Linear-blue                                */
/* ========================================================================== */
body.as-scope .artstone-only-shell, body.as-scope .as-panel, body.as-scope .as-editor-fullpanel, body.as-scope .as-overlay, body.as-scope .as-modal, body.as-scope .as-editor-overlay, body.as-scope .as-welcome-overlay {
  --as-ac:     #4f8cff;
  --as-ac-hi:  #7aa9ff;
  --as-ac-lo:  #2e66d6;
  --as-ac-ink: #ffffff;
  --as-ac-t06: rgba(79,140,255,0.06);
  --as-ac-t10: rgba(79,140,255,0.10);
  --as-ac-t16: rgba(79,140,255,0.16);
  --as-ac-t24: rgba(79,140,255,0.24);
  --as-ac-t40: rgba(79,140,255,0.40);
}

/* Background neutro slate (override del default oro-tinto) */
body.as-scope .artstone-only-shell, body.as-scope .as-panel, body.as-scope .as-overlay {
  --as-bg-0: #0a0b0d;
  --as-bg-1: #101216;
  --as-bg-2: #14161a;
  --as-bg-3: #1c1f24;
  --as-bg-4: #262a31;
  --as-tx-1: #e6e8eb;
  --as-tx-2: rgba(230,232,235,0.72);
  --as-tx-3: rgba(230,232,235,0.48);
  --as-tx-4: rgba(230,232,235,0.28);
  --as-bd-0: rgba(255,255,255,0.04);
  --as-bd-1: rgba(255,255,255,0.07);
  --as-bd-2: rgba(255,255,255,0.11);
  --as-bd-3: rgba(255,255,255,0.18);
}

/* ========================================================================== */
/* 2. ANIMAZIONI INFINITE — disabilita pulse/glow/shimmer                    */
/* ========================================================================== */
body.as-scope .as-bot-dot-run, body.as-scope .as-report-badge-working, body.as-scope .as-manual-dot-run, body.as-scope .as-tm-sync-dot, body.as-scope .as-pulse, body.as-scope [class*="-pulse"], body.as-scope [class*="-shimmer"], body.as-scope [class*="-glow"] {
  animation: none !important;
}

/* Eccezione: skeleton shimmer (loading) puo' restare se serve */
body.as-scope .skel, body.as-scope .skel::after {
  animation-duration: 1.5s;
}

/* ========================================================================== */
/* 3. BACKDROP-FILTER — rimuovi blur ovunque (chrome elements + modal)       */
/*    61 occorrenze nel live; teniamo blur soft solo su modal backdrop full  */
/* ========================================================================== */
body.as-scope .as-modal, body.as-scope .as-editor-overlay, body.as-scope .as-welcome-overlay, body.as-scope .as-overlay, body.as-scope .as-panel, body.as-scope .as-editor-fullpanel, body.as-scope .as-toast, body.as-scope .as-banner, body.as-scope .as-header, body.as-scope .as-tabs, body.as-scope .as-toolbar {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Modal full-screen overlay: solo blur leggero (8px max) per separare visivamente */
body.as-scope .as-editor-overlay, body.as-scope .as-welcome-overlay {
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  background: rgba(0,0,0,0.55) !important;
}

/* ========================================================================== */
/* 4. GRADIENT TEXT — kill background-clip: text (effetto oro shiny)         */
/* ========================================================================== */
body.as-scope * {
  background-clip: initial;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: initial;
}

/* Restore solo dove serve REALMENTE (es. bg solido + text color esplicito) */

/* ========================================================================== */
/* 5. NOISE TEXTURE body::before — disabilita                                */
/* ========================================================================== */
body.as-scope::before, body.as-scope::after {
  background-image: none !important;
  background: transparent !important;
  display: none !important;
}

/* ========================================================================== */
/* 6. BOX-SHADOW glow oro — sostituisci con neutre                           */
/* ========================================================================== */
body.as-scope .as-bot-dot-run, body.as-scope .as-bot-dot-ok, body.as-scope .as-bot-dot-err, body.as-scope .as-bot-dot-off, body.as-scope .as-bot-dot, body.as-scope .as-manual-dot-run {
  box-shadow: none !important;
}

body.as-scope .as-toast, body.as-scope .as-modal-panel, body.as-scope .as-editor-panel, body.as-scope .as-editor-fullpanel, body.as-scope .as-panel {
  box-shadow: 0 16px 40px rgba(0,0,0,0.42), 0 4px 12px rgba(0,0,0,0.24) !important;
}

/* ========================================================================== */
/* 7. FONT-WEIGHT 800 — riduci a 700 max                                     */
/* ========================================================================== */
body.as-scope .as-ov-sum-tot, body.as-scope [style*="font-weight: 800"], body.as-scope [style*="font-weight:800"] {
  font-weight: 700 !important;
}

/* ========================================================================== */
/* 8. BORDER-RADIUS >14px — riduci                                            */
/* ========================================================================== */
body.as-scope .as-welcome-panel, body.as-scope .as-modal-panel, body.as-scope .as-editor-panel, body.as-scope .as-editor-fullpanel, body.as-scope .as-card, body.as-scope [class*="rounded-xl"] {
  border-radius: 12px !important;
}

/* ========================================================================== */
/* 9. LINEAR-GRADIENT su elementi non-CTA (chart/bar/badge)                  */
/* ========================================================================== */
body.as-scope .as-bar-fill {
  background: var(--as-ac, #4f8cff) !important;
}

body.as-scope .as-stato-consp, body.as-scope [class*="as-stato-"] {
  background-image: none !important;
}

/* ========================================================================== */
/* 10. LANDING PANEL artstone-only — riduci pomposita'                       */
/* ========================================================================== */
body.as-scope .artstone-only-hero-icon {
  display: none !important; /* iconone hero giganti -> via */
}

body.as-scope .artstone-only-hero-title {
  font-size: 22px !important;
  font-weight: 600 !important;
  letter-spacing: -0.011em !important;
  background: none !important;
  -webkit-text-fill-color: var(--as-tx-1, #e6e8eb) !important;
  color: var(--as-tx-1, #e6e8eb) !important;
}

body.as-scope .artstone-only-hero-sub {
  color: var(--as-tx-2, rgba(230,232,235,0.72)) !important;
  font-size: 13px !important;
}

body.as-scope .artstone-only-cta {
  background: var(--as-ac, #4f8cff) !important;
  color: #ffffff !important;
  border: 1px solid var(--as-ac, #4f8cff) !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
  padding: 10px 18px !important;
  box-shadow: none !important;
}

body.as-scope .artstone-only-logo {
  /* Tempio greco emoji nascosto, sostituito da monogramma testuale via JS o nulla */
  font-size: 0 !important;
  width: 28px !important;
  height: 28px !important;
  background: var(--as-ac, #4f8cff) !important;
  border-radius: 6px !important;
  display: inline-block !important;
  position: relative !important;
}
body.as-scope .artstone-only-logo::before {
  content: "AS" !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
}

/* ============================================================================
   ACTIVATION (in app.js, dentro ArtstoneOnlyView):
     componentDidMount() {
       document.body.classList.add('as-scope');
       // inietta <link rel="stylesheet" href="/static/artstone-restore.css?v=...">
     }
     componentWillUnmount() {
       document.body.classList.remove('as-scope');
     }
   ============================================================================ */
