/* ================================================================
   AKTI CRM — Design System v5 (Aniq-inspired, AKTI brand)
   Modern paper-toned palette, softer shadows, tighter radii,
   Lama Sans typography. All existing class names preserved so
   every page auto-inherits the upgrade.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap');

/* Lama Sans — served from /fonts so printers, PDF exports and machines
   without the font installed locally still render with correct metrics.
   local() is kept as a fast path when the user has the typeface installed,
   url() is the fallback everyone else uses. font-display:block so capture
   tools (html2canvas, print-to-PDF) wait for the font instead of snapshot-
   ting a fallback and reflowing — which was cutting text in exports. */
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Light"), local("LamaSans-Light"),
       url("fonts/LamaSans-Light.ttf") format("truetype");
  font-weight: 300; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Regular"), local("LamaSans-Regular"), local("Lama Sans"),
       url("fonts/LamaSans-Regular.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Regular Italic"), local("LamaSans-RegularItalic"),
       url("fonts/LamaSans-RegularItalic.ttf") format("truetype");
  font-weight: 400; font-style: italic; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Medium"), local("LamaSans-Medium"),
       url("fonts/LamaSans-Medium.ttf") format("truetype");
  font-weight: 500; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans SemiBold"), local("LamaSans-SemiBold"),
       url("fonts/LamaSans-SemiBold.ttf") format("truetype");
  font-weight: 600; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Bold"), local("LamaSans-Bold"),
       url("fonts/LamaSans-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Bold Italic"), local("LamaSans-BoldItalic"),
       url("fonts/LamaSans-BoldItalic.ttf") format("truetype");
  font-weight: 700; font-style: italic; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans ExtraBold"), local("LamaSans-ExtraBold"),
       url("fonts/LamaSans-ExtraBold.ttf") format("truetype");
  font-weight: 800; font-style: normal; font-display: block;
}
@font-face {
  font-family: "Lama Sans";
  src: local("Lama Sans Black"), local("LamaSans-Black"),
       url("fonts/LamaSans-Black.ttf") format("truetype");
  font-weight: 900; font-style: normal; font-display: block;
}

/* ── Tokens (Aniq-inspired + AKTI brand overlay) ────── */
:root {
  --font: "Lama Sans", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  /* Paper-toned palette — warmer, softer than pure white/grey */
  --bg: #FAF7F4;             /* soft paper */
  --bg-card: #FFFFFF;        /* raised surface */
  --bg-muted: #F4EFEA;       /* sunken surface */
  --bg-accent: #FDF4EF;      /* brand-tinted accent */
  --bg-popover: #FFFFFF;
  --bg-overlay: rgba(43, 26, 31, 0.48);

  /* Ink scale — warmer than pure black */
  --fg: #2B1A1F;             /* primary text */
  --fg-muted: #735E64;       /* secondary text */
  --fg-subtle: #A89198;      /* tertiary hint text */
  --fg-inverse: #FAF7F4;
  --fg-accent: #740832;

  /* Borders — brand-tinted hairlines, not neutral grey */
  --border: #EDE4DE;
  --border-hover: #E1D4CC;
  --ring: rgba(116, 8, 50, 0.12);

  /* Brand */
  --brand: #740832;
  --brand-light: #941845;
  --brand-dark: #590B25;
  --copper: #B76D5B;
  --copper-light: #EDB5A7;
  --copper-mid: #CE8B82;
  --gold: #D4AF37;
  --sand: #F2C8B6;
  --sky: #CDDEF4;
  --sage: #AFC8BE;

  /* Semantic */
  --success: #1E7A45;
  --success-bg: #E6F2EB;
  --warning: #C87A00;
  --warning-bg: #FFF2DB;
  --danger: #DF2A2C;
  --danger-bg: #FBE2E2;
  --info: #2563EB;
  --info-bg: #DBEAFE;

  /* Radii — slightly bigger on cards, tighter on inputs */
  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;
  --radius-full: 9999px;

  /* Shadows — warm paper tones, layered ambient + key */
  --shadow-xs: 0 1px 1px rgba(43, 26, 31, 0.03);
  --shadow-sm: 0 1px 2px rgba(43, 26, 31, 0.04), 0 1px 3px rgba(43, 26, 31, 0.03);
  --shadow:    0 2px 4px rgba(43, 26, 31, 0.04), 0 4px 12px rgba(43, 26, 31, 0.05);
  --shadow-md: 0 4px 8px rgba(43, 26, 31, 0.05), 0 8px 20px rgba(43, 26, 31, 0.07);
  --shadow-lg: 0 8px 16px rgba(43, 26, 31, 0.06), 0 20px 40px rgba(43, 26, 31, 0.09);
  --shadow-brand: 0 4px 16px rgba(116, 8, 50, 0.12), 0 2px 6px rgba(116, 8, 50, 0.08);
}

/* ── Dark ─────────────────────────────────────── */
.dark,.dark-theme,[data-theme="dark"] {
  --bg: #1A1013;
  --bg-card: #261A1F;
  --bg-muted: #30222A;
  --bg-accent: #3A2830;
  --bg-popover: #261A1F;
  --bg-overlay: rgba(0,0,0,.72);
  --fg: #FAF7F4;
  --fg-muted: #A89198;
  --fg-subtle: #735E64;
  --fg-inverse: #2B1A1F;
  --border: #3A2830;
  --border-hover: #4A3540;
  --ring: rgba(183,109,91,.25);
  --shadow-xs:0 1px 2px rgba(0,0,0,.4);
  --shadow-sm:0 1px 3px rgba(0,0,0,.5);
  --shadow:0 4px 8px rgba(0,0,0,.5);
  --shadow-md:0 10px 20px rgba(0,0,0,.55);
  --shadow-lg:0 20px 40px rgba(0,0,0,.6);
  --shadow-brand:0 4px 16px rgba(183,109,91,.25),0 2px 6px rgba(183,109,91,.15);
}

/* Legacy aliases */
:root,.dark,.dark-theme {
  --bg-root:var(--bg);--bg-surface:var(--bg-card);--bg-sunken:var(--bg-muted);--bg-raised:var(--bg-card);
  --glass-bg:color-mix(in srgb,var(--bg-card) 80%,transparent);--glass-border:var(--border);--glass-blur:12px;
  --text-primary:var(--fg);--text-secondary:var(--fg-muted);--text-tertiary:var(--fg-subtle);--text-inverse:var(--fg-inverse);
  --border-subtle:var(--border);--border-default:var(--border);--border-strong:var(--border-hover);
  --akti-burgundy:var(--brand);--akti-burgundy-light:var(--brand-light);--akti-burgundy-dark:var(--brand-dark);
  --akti-copper:var(--copper);--akti-copper-dark:#8B5A47;--akti-copper-light:#D9A98E;--akti-gold:var(--gold);
  --akti-cream:#FDF6F0;--akti-sand:#E8D5C4;--akti-sand-light:#F3E8DD;
  --akti-dark-gray:var(--fg);--akti-medium-gray:var(--fg-muted);--akti-light-gray:var(--bg-muted);
  --font-primary:var(--font);--font-mono:var(--mono);--radius-md:var(--radius);--radius-full:9999px;
  --ease-out:cubic-bezier(.16,1,.3,1);--shadow-xl:var(--shadow-lg);
  --status-success:var(--success);--status-warning:var(--warning);--status-error:var(--danger);--status-info:var(--info);
  --color-success:var(--success);--color-warning:var(--warning);--color-error:var(--danger);--color-info:var(--info);
}

/* ── Reset ────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
body{font-family:var(--font);font-size:.875rem;line-height:1.55;color:var(--fg);background:var(--bg);transition:background .25s,color .25s;-webkit-text-size-adjust:100%}
a{color:var(--brand);text-decoration:none;transition:color .15s}
a:hover{color:var(--brand-light)}
::selection{background:rgba(116,8,50,.15);color:var(--fg)}
/* Cleaner scrollbars across the whole app */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--border);border:2px solid transparent;background-clip:padding-box;border-radius:8px}
*::-webkit-scrollbar-thumb:hover{background:var(--border-hover);background-clip:padding-box}

/* ================================================================
   COMPONENTS — shadcn/ui
   ================================================================ */

/* ── Button ─────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;height:38px;padding:0 1.1rem;border-radius:var(--radius);font:600 .8125rem/1 var(--font);cursor:pointer;transition:all .18s cubic-bezier(.22,1,.36,1);border:1px solid transparent;white-space:nowrap;text-decoration:none;outline:none;letter-spacing:.005em}
.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--ring)}
.btn:disabled{opacity:.5;pointer-events:none}
.btn:active:not(:disabled){transform:translateY(1px)}

.btn-primary,.btn-brand{background:linear-gradient(180deg,var(--brand-light),var(--brand));color:#fff;border-color:var(--brand);box-shadow:var(--shadow-brand)}
.btn-primary:hover{background:linear-gradient(180deg,var(--brand),var(--brand-dark));box-shadow:0 6px 18px rgba(116,8,50,.2),0 2px 8px rgba(116,8,50,.12);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-brand)}

.btn-secondary{background:var(--bg-card);color:var(--fg);border-color:var(--border);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{background:var(--bg-accent);border-color:var(--border-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}

.btn-outline{background:var(--bg-card);color:var(--brand);border-color:var(--brand);box-shadow:var(--shadow-xs)}
.btn-outline:hover{background:var(--bg-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}

.btn-ghost{background:transparent;color:var(--fg-muted);border:none;box-shadow:none}
.btn-ghost:hover{background:var(--bg-muted);color:var(--fg)}

.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 4px 14px rgba(223,42,44,.18),0 1px 3px rgba(223,42,44,.1)}
.btn-danger:hover{background:#C71B1E;transform:translateY(-1px)}

.btn-sm{height:32px;padding:0 .85rem;font-size:.7375rem;border-radius:8px}
.btn-xs{height:26px;padding:0 .6rem;font-size:.675rem;border-radius:6px;gap:.3rem}
.btn-lg{height:44px;padding:0 1.4rem;font-size:.875rem;border-radius:12px}
.btn-icon{width:38px;height:38px;padding:0;border-radius:var(--radius)}
.btn-icon.sm{width:32px;height:32px;border-radius:8px}
.btn-pill{border-radius:var(--radius-full);padding:0 1.3rem}

/* ── Card ─────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s,transform .2s}
.card:hover{box-shadow:var(--shadow);border-color:var(--border-hover)}
.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,var(--bg-card),var(--bg))}
.card-header h3{font:700 .875rem/1.2 var(--font);color:var(--fg);letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}
.card-body{padding:1.25rem}
.card-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem;background:var(--bg)}

/* ── Badge / Pill ─────────────────────────── */
.badge,.pill{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .625rem;border-radius:var(--radius-full);font:700 .6875rem/1.3 var(--font);border:none;white-space:nowrap;letter-spacing:.01em}

/* Status pills — AKTI brand tints, no borders (cleaner) */
.pill.paid       {background:var(--success-bg);color:var(--success)}
.pill.followup   {background:#FDE8EE;color:var(--brand)}
.pill.pending    {background:var(--warning-bg);color:var(--warning)}
.pill.noanswer   {background:#F3E8DD;color:#8B5A47}
.pill.rejected   {background:var(--danger-bg);color:var(--danger)}
.pill.installment{background:#D1FAE5;color:#065F46}
.pill.canceled   {background:var(--bg-muted);color:var(--fg-muted)}
.badge-brand  {background:var(--success-bg);color:var(--success)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}
.badge-danger {background:var(--danger-bg);color:var(--danger)}
.badge-info   {background:var(--info-bg);color:var(--info)}
.badge-default{background:var(--bg-muted);color:var(--fg-muted)}
.pill:hover{opacity:.92}

/* ── Input / Select ───────────────────────── */
.input,.form-input{width:100%;height:38px;padding:0 .85rem;border:1px solid var(--border);border-radius:var(--radius);font:500 .8125rem/1 var(--font);color:var(--fg);background:var(--bg-card);transition:border-color .18s,box-shadow .18s,background .18s;outline:none}
textarea.input,textarea.form-input{height:auto;padding:.6rem .85rem;line-height:1.5}
.input:hover,.form-input:hover{border-color:var(--border-hover);background:var(--bg-card)}
.input:focus,.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--ring);background:var(--bg-card)}
.input::placeholder,.form-input::placeholder{color:var(--fg-subtle);font-weight:400}

select.input,select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23735E64' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.1rem}

.label,.form-label{display:block;font:700 .75rem/1 var(--font);color:var(--fg-muted);margin-bottom:.45rem;text-transform:uppercase;letter-spacing:.04em}
.form-group{margin-bottom:.85rem}

/* ── Table ────────────────────────────────── */
.table-responsive{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);box-shadow:var(--shadow-xs)}
table.tbl{width:100%;border-collapse:collapse}
.tbl th{padding:.75rem .85rem;font:700 .6875rem/1 var(--font);color:var(--fg-muted);background:var(--bg);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em}
.tbl th:first-child{border-radius:var(--radius-lg) 0 0 0}
.tbl th:last-child{border-radius:0 var(--radius-lg) 0 0}
.table-header{background:var(--bg);color:var(--fg-muted)}
.tbl td{padding:.7rem .85rem;font-size:.8125rem;font-weight:500;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover td,.table-row:hover{background:var(--bg-accent)}
.tbl tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--bg-muted) 50%,transparent)}
.tbl tbody tr:nth-child(even):hover td{background:var(--bg-accent)}
.tbl .mono{font-family:var(--mono);font-size:.7375rem;color:var(--fg-muted);font-weight:500}

/* ── KPI Card ─────────────────────────────── */
.kpi-card,.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.15rem 1.3rem;position:relative;overflow:hidden;transition:all .25s cubic-bezier(.22,1,.36,1);box-shadow:var(--shadow-xs)}
.kpi-card::before,.kpi::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--brand),var(--copper));border-radius:0 3px 3px 0}
.kpi-card:nth-child(1)::before,.kpi:nth-child(1)::before{background:linear-gradient(180deg,var(--brand),var(--brand-dark))}
.kpi-card:nth-child(2)::before,.kpi:nth-child(2)::before{background:linear-gradient(180deg,var(--success),#065F46)}
.kpi-card:nth-child(3)::before,.kpi:nth-child(3)::before{background:linear-gradient(180deg,var(--copper),#8B5A47)}
.kpi-card:nth-child(4)::before,.kpi:nth-child(4)::before{background:linear-gradient(180deg,var(--copper-mid),var(--copper))}
.kpi-card:hover,.kpi:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-2px)}
.kpi-label,.kpi-lbl{font:700 .6875rem/1 var(--font);color:var(--fg-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}
.kpi-value,.kpi-val{font:800 1.65rem/1.1 var(--font);color:var(--fg);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.kpi-trend{position:absolute;top:.7rem;right:.9rem;font:700 .65rem/1 var(--font);padding:.22rem .5rem;border-radius:var(--radius-full);letter-spacing:.02em}
.kpi-trend.up{color:var(--success);background:var(--success-bg)}
.kpi-trend.down{color:var(--danger);background:var(--danger-bg)}

/* ── Modal (Aniq-style dialog) ────────────── */
.modal,.modal-bg,.modal-overlay{position:fixed;inset:0;z-index:50;background:var(--bg-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease}
.modal.hidden,.modal-bg.hidden,.modal-overlay.hidden{display:none!important}
.modal>div,.modal-box,.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px rgba(116,8,50,.04);max-height:92vh;overflow-y:auto;animation:dialogIn .24s cubic-bezier(.22,1,.36,1);width:100%}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes dialogIn{from{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-head,.modal-header,.modal-top{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.4rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--bg-card),var(--bg))}
.modal-head h3,.modal-top h3{font:800 1rem/1.2 var(--font);color:var(--fg);display:flex;align-items:center;gap:.5rem;letter-spacing:-.01em}
.modal-body,.modal-inner{padding:1.4rem}
.modal-foot,.modal-footer,.modal-actions{padding:1rem 1.4rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.55rem;background:var(--bg)}

/* ── Status text colors ───────────────────── */
.status-follow-up{color:var(--brand);font-weight:600}
.status-paid{color:var(--success);font-weight:600}
.status-paid-installment{color:#059669;font-weight:600}
.status-rejected{color:var(--danger);font-weight:600}
.status-no-answer{color:var(--copper);font-weight:600}

/* ── Loading / Skeleton ───────────────────── */
.loading{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:var(--bg-muted);border-radius:var(--radius);position:relative;overflow:hidden}
.skeleton::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ── Animations ───────────────────────────── */
.hidden{display:none!important}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes bellShake{0%,100%{transform:rotate(0)}15%,45%,75%{transform:rotate(-8deg)}30%,60%,90%{transform:rotate(8deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.bell-shake{animation:bellShake .5s ease}

/* ── Navigation (shadcn) ──────────────────── */
.nav-tab{height:32px;padding:0 .625rem;border:none;border-radius:var(--radius-sm);font:500 .75rem/1 var(--font);color:var(--fg-muted);cursor:pointer;transition:all .1s;display:inline-flex;align-items:center;gap:.25rem;background:transparent;white-space:nowrap}
.nav-tab:hover{color:var(--fg);background:var(--bg-muted)}
.nav-tab.active{color:var(--brand);font-weight:600}
.nav-dropdown{position:relative;display:inline-block}
.nav-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg-popover);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-width:180px;z-index:50;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .1s;padding:.25rem}
.nav-dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-item{display:flex;align-items:center;gap:.5rem;height:32px;padding:0 .625rem;font:400 .8125rem/1 var(--font);color:var(--fg);border-radius:var(--radius-sm);transition:background .1s;text-decoration:none;cursor:pointer}
.nav-dropdown-item:hover{background:var(--bg-muted);color:var(--fg)}
.nav-dropdown-item i{width:14px;text-align:center;font-size:.75rem;color:var(--brand)}

/* Global icon branding — all FontAwesome icons use brand colors */
.fas,.far,.fab,.fa{color:inherit}
.section-title i,.kpi i,.card-header i,.form-section-header i,.modal-top i{color:var(--brand)!important}
.btn i,.btn-primary i,.btn-outline i{color:inherit!important}
.pill i,.badge i,.status-tab i,.nav-tab i{color:inherit!important}
.nav-dropdown-section{padding:.125rem 0}
.nav-dropdown-section-title{padding:.5rem .625rem .25rem;font:500 .6875rem/1 var(--font);color:var(--fg-subtle)}
.nav-dropdown-divider{height:1px;background:var(--border);margin:.25rem .5rem}
.dropdown-trigger{white-space:nowrap;cursor:pointer}

/* ── Period tabs ──────────────────────────── */
.period-tab{background:var(--bg-card);border:1px solid var(--border);height:32px;padding:0 .75rem;border-radius:var(--radius);cursor:pointer;font:500 .75rem/1 var(--font);color:var(--fg-muted);transition:all .1s;display:inline-flex;align-items:center;gap:.375rem}
.period-tab:hover{border-color:var(--brand);color:var(--brand)}
.period-tab.active{background:var(--brand);border-color:var(--brand);color:#fff}

/* ── Upload area ──────────────────────────── */
.upload-area{border:1px dashed var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg-muted)}
.upload-area:hover{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 4%,transparent)}

/* ── Notification ─────────────────────────── */
.notification-tab{background:transparent;color:var(--fg-muted);border:none;border-bottom:2px solid transparent;cursor:pointer;font:500 .75rem/1 var(--font);padding:.375rem .5rem;transition:all .1s}
.notification-tab:hover{color:var(--brand);background:var(--bg-muted)}
.notification-tab.active{color:var(--brand);border-bottom-color:var(--brand)}

/* ── Calendar ─────────────────────────────── */
#dateFilterToggle{background:var(--brand);color:#fff;border:none;font:500 .75rem/1 var(--font);height:32px;padding:0 .75rem;border-radius:var(--radius);cursor:pointer;transition:background .1s}
#dateFilterToggle:hover{background:var(--brand-light)}
#datePickerPopup{z-index:50;position:fixed}
#datePickerPopup.hidden{display:none!important}
.datePreset{font:400 .75rem/1 var(--font);height:32px;padding:0 .625rem;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--fg);text-align:left;width:100%;display:flex;align-items:center;gap:.5rem;transition:background .1s}
.datePreset:hover{background:var(--bg-muted)}
#calendarGrid button{height:28px;border:1px solid transparent;background:transparent;cursor:pointer;border-radius:var(--radius-sm);font:500 .75rem/1 var(--font);display:flex;align-items:center;justify-content:center;color:var(--fg);transition:all .1s}
#calendarGrid button:disabled{opacity:.3;cursor:not-allowed}
#calendarGrid button:not(:disabled):hover{background:var(--bg-muted)}
#calendarGrid button.selected{background:var(--brand)!important;color:#fff!important}
#calendarGrid button.in-range{background:color-mix(in srgb,var(--brand) 8%,transparent);color:var(--brand)}
#calendarGrid div{font:500 .6875rem/1 var(--font);text-transform:uppercase;color:var(--fg-subtle);display:flex;align-items:center;justify-content:center;height:28px}

/* ── Branch card ──────────────────────────── */
.branch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;transition:all .15s}
.branch-card:hover{box-shadow:var(--shadow);border-color:var(--border-hover)}

/* ── Kanban ────────────────────────────────── */
.kanban-column{transition:background .1s;border-radius:var(--radius-lg)}
.kanban-column.drag-over{background:var(--bg-accent);outline:2px dashed var(--brand);outline-offset:-2px}
.kanban-task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;cursor:grab;transition:all .1s;border-left:3px solid transparent}
.kanban-task-card:hover{box-shadow:var(--shadow-sm)}
.kanban-task-card.priority-high{border-left-color:var(--danger)}
.kanban-task-card.priority-medium{border-left-color:var(--warning)}
.kanban-task-card.priority-low{border-left-color:var(--success)}

/* ── Misc utilities ───────────────────────── */
.text-primary{color:var(--brand)}
.text-muted{color:var(--fg-muted)}
.gradient-text{background:linear-gradient(135deg,var(--brand),var(--copper));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.required{color:var(--danger)}

/* ── Modal fixes ──────────────────────────── */
body.modal-open{overflow:hidden!important}
main,header,nav{position:relative;z-index:auto}
#notificationDropdown{z-index:100!important;position:fixed!important}

/* Transaction key section */
#editUnifiedTransactionKeySection{background:color-mix(in srgb,var(--brand) 4%,transparent);border:1px solid color-mix(in srgb,var(--brand) 15%,transparent);border-radius:var(--radius-lg);padding:.75rem;margin-top:.5rem}
#editUnifiedTransactionKeySection .form-label{color:var(--brand)}

/* ── Responsive ───────────────────────────── */
@media(max-width:768px){
  .card-body{padding:.75rem}
  .kpi-card,.kpi{padding:.75rem}
  .kpi-value,.kpi-val{font-size:1.25rem}
  .nav-tab{height:28px;padding:0 .5rem;font-size:.6875rem}
  .nav-dropdown-menu{min-width:160px}
}
@media print{
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #ddd}
  .hidden,.nav-dropdown-menu{display:none!important}
}

/* ================================================================
   v5 POLISH — Aniq-style chrome, navigation, hero strips, sections
   ================================================================ */

/* Page shells — wider + more breathing room */
.dashboard,.page-wrap,.main-wrap{max-width:1480px;margin:0 auto;padding:1.25rem 1.75rem 3rem}

/* Nav tab refresh — pill hover, stronger active state */
.nav-tab{height:34px;padding:0 .85rem;border-radius:8px;font:600 .75rem/1 var(--font);letter-spacing:-.005em;transition:all .18s}
.nav-tab:hover{background:var(--bg-accent);color:var(--brand)}
.nav-tab.active{color:var(--brand);background:var(--bg-accent);font-weight:700}

/* Glass top bar softer tint */
.top-bar,header.top-bar{background:rgba(255,255,255,0.85)!important;backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);border-bottom:1px solid var(--border)!important}

/* Hero strips (brand gradient) */
.hero,.hero-strip{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;padding:1.5rem 1.75rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-brand);position:relative;overflow:hidden}
.hero::before,.hero-strip::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse at center,rgba(237,181,167,.15),transparent 60%);pointer-events:none}
.hero h1,.hero-strip h1,.hero-title{font:800 1.5rem/1.2 var(--font);color:#fff;letter-spacing:-.01em;margin:0 0 .3rem;position:relative;z-index:1}
.hero p,.hero-strip p,.hero-sub{font:400 .82rem/1.5 var(--font);color:var(--copper-light);margin:0;position:relative;z-index:1}

/* Section headers (numbered style) */
.section-header{display:flex;align-items:center;gap:.75rem;margin:0 0 1rem;padding:0}
.section-num{width:30px;height:30px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--copper));color:#fff;font:800 .8rem/1 var(--font);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-brand)}
.section-title{font:800 .85rem/1.2 var(--font);color:var(--fg);text-transform:uppercase;letter-spacing:.05em;margin:0;display:flex;align-items:center;gap:.55rem}
.section-title i{color:var(--brand)}
.section-sub{font:600 .68rem/1 var(--font);color:var(--fg-subtle);margin-left:auto;letter-spacing:.01em}

/* Stat cards with ambient tints */
.stat-card-accent{background:linear-gradient(135deg,var(--bg-accent),var(--bg-card));border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.15rem 1.3rem;box-shadow:var(--shadow-sm);transition:all .22s}
.stat-card-accent:hover{box-shadow:var(--shadow);transform:translateY(-2px)}

/* Chip — small pill-style tag often used in filter bars */
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);font:600 .72rem/1 var(--font);color:var(--fg-muted);cursor:pointer;transition:all .15s}
.chip:hover{border-color:var(--brand);color:var(--brand);background:var(--bg-accent)}
.chip.active,.chip.selected{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:var(--shadow-brand)}

/* Soft divider */
.divider{height:1px;background:var(--border);margin:1rem 0;border:none}
.divider-dashed{border-top:1px dashed var(--border)}

/* Layout utilities */
.stack{display:flex;flex-direction:column}
.stack>*+*{margin-top:var(--stack-gap,1rem)}
.cluster{display:flex;flex-wrap:wrap;gap:var(--cluster-gap,.6rem);align-items:center}

/* Text weights + sizes */
.h1{font:800 1.875rem/1.2 var(--font);letter-spacing:-.02em}
.h2{font:800 1.5rem/1.2 var(--font);letter-spacing:-.015em}
.h3{font:700 1.15rem/1.3 var(--font);letter-spacing:-.01em}
.text-sm{font-size:.8125rem}
.text-xs{font-size:.6875rem}

/* Tabular numerics for money/stats everywhere */
.kpi-value,.kpi-val,.tbl td,.stat-value{font-variant-numeric:tabular-nums}

/* Responsive tweaks */
@media(max-width:768px){
  .dashboard,.page-wrap,.main-wrap{padding:.85rem 1rem 2rem}
  .hero,.hero-strip{padding:1.15rem 1.25rem}
  .hero h1,.hero-strip h1,.hero-title{font-size:1.2rem}
  .section-header{margin-bottom:.75rem}
  .section-num{width:26px;height:26px;font-size:.72rem}
  .section-title{font-size:.76rem}
}

/* ================================================================
   DESIGN SYSTEM v6 — SHADCN FULL COMPONENT LIBRARY
   Extends v5 with the complete shadcn primitive set, zero-config.
   Classes are additive; all existing pages inherit the upgrade.
   ================================================================ */

/* ── Tuning overrides — shadcn v4 defaults ─────────────── */
:root{
  --radius-sm:6px;
  --radius:8px;
  --radius-lg:12px;
  --radius-xl:16px;
  --ring-offset:2px;
  --ring-color:var(--brand);
  --muted:var(--bg-muted);
  --muted-fg:var(--fg-muted);
  --popover:var(--bg-popover);
  --popover-fg:var(--fg);
  --accent:var(--bg-accent);
  --accent-fg:var(--fg-accent);
  --destructive:var(--danger);
  --destructive-fg:#fff;
  --card-fg:var(--fg);
  --primary:var(--brand);
  --primary-fg:#fff;
  --secondary:var(--bg-muted);
  --secondary-fg:var(--fg);
  --input:var(--border);
}

/* Refined focus ring (shadcn default) */
*:focus-visible{outline:2px solid transparent;outline-offset:2px}
.btn:focus-visible,.input:focus-visible,.form-input:focus-visible,
.sh-checkbox:focus-visible,.sh-radio:focus-visible,.sh-switch:focus-visible,
.sh-tab:focus-visible,.sh-dropdown-item:focus-visible{
  box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--ring);
}

/* ── Alert ──────────────────────────────────────────────── */
.sh-alert{position:relative;display:flex;gap:.75rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);box-shadow:var(--shadow-xs);font:500 .8125rem/1.5 var(--font);color:var(--fg)}
.sh-alert>i:first-child,.sh-alert>svg:first-child{flex-shrink:0;width:16px;height:16px;margin-top:.15rem;color:var(--fg-muted)}
.sh-alert-title{font:700 .8125rem/1.3 var(--font);color:var(--fg);margin-bottom:.2rem;letter-spacing:-.005em}
.sh-alert-desc{color:var(--fg-muted);font:400 .78rem/1.5 var(--font)}
.sh-alert-info{background:var(--info-bg);border-color:color-mix(in srgb,var(--info) 25%,transparent)}
.sh-alert-info>i:first-child{color:var(--info)}
.sh-alert-success{background:var(--success-bg);border-color:color-mix(in srgb,var(--success) 25%,transparent)}
.sh-alert-success>i:first-child{color:var(--success)}
.sh-alert-warning{background:var(--warning-bg);border-color:color-mix(in srgb,var(--warning) 25%,transparent)}
.sh-alert-warning>i:first-child{color:var(--warning)}
.sh-alert-danger,.sh-alert-destructive{background:var(--danger-bg);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}
.sh-alert-danger>i:first-child,.sh-alert-destructive>i:first-child{color:var(--danger)}
.sh-alert-brand{background:var(--bg-accent);border-color:color-mix(in srgb,var(--brand) 20%,transparent)}
.sh-alert-brand>i:first-child{color:var(--brand)}

/* ── Toast (Sonner-style) ───────────────────────────────── */
.sh-toast-viewport{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:22rem;pointer-events:none}
.sh-toast-viewport.bottom-right{top:auto;bottom:1rem}
.sh-toast-viewport.bottom-left{top:auto;bottom:1rem;right:auto;left:1rem}
.sh-toast{pointer-events:auto;display:flex;gap:.75rem;align-items:flex-start;padding:.85rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);font:500 .8125rem/1.4 var(--font);color:var(--fg);animation:shToastIn .26s cubic-bezier(.22,1,.36,1);min-width:18rem}
.sh-toast.leaving{animation:shToastOut .2s ease forwards}
.sh-toast-icon{flex-shrink:0;width:16px;height:16px;margin-top:.1rem}
.sh-toast-body{flex:1;min-width:0}
.sh-toast-title{font-weight:700;color:var(--fg);margin-bottom:.15rem;letter-spacing:-.005em}
.sh-toast-desc{color:var(--fg-muted);font:400 .76rem/1.45 var(--font)}
.sh-toast-close{flex-shrink:0;background:transparent;border:none;color:var(--fg-subtle);cursor:pointer;width:20px;height:20px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .1s}
.sh-toast-close:hover{color:var(--fg);background:var(--bg-muted)}
.sh-toast-success .sh-toast-icon{color:var(--success)}
.sh-toast-error .sh-toast-icon,.sh-toast-destructive .sh-toast-icon{color:var(--danger)}
.sh-toast-warning .sh-toast-icon{color:var(--warning)}
.sh-toast-info .sh-toast-icon{color:var(--info)}
.sh-toast-brand .sh-toast-icon{color:var(--brand)}
@keyframes shToastIn{from{opacity:0;transform:translateX(calc(100% + 1rem))}to{opacity:1;transform:translateX(0)}}
@keyframes shToastOut{to{opacity:0;transform:translateX(calc(100% + 1rem))}}

/* ── Tooltip (JS-driven floating element) ──────────────── */
.sh-tooltip{
  position:fixed;z-index:9999;pointer-events:none;
  background:var(--fg);color:var(--bg-card);
  font:600 .7rem/1.35 var(--font);
  padding:.4rem .6rem;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-md);
  max-width:18rem;text-align:center;
  opacity:0;transform:translateY(4px);
  transition:opacity .14s,transform .14s;
  white-space:normal;word-wrap:break-word;
}
.sh-tooltip.show{opacity:1;transform:translateY(0)}
.sh-tooltip::after{
  content:'';position:absolute;left:50%;
  transform:translateX(-50%);border:5px solid transparent;
}
.sh-tooltip[data-side="top"]::after{top:100%;border-top-color:var(--fg)}
.sh-tooltip[data-side="bottom"]::after{bottom:100%;border-bottom-color:var(--fg)}
.sh-tooltip[data-side="left"]::after{left:100%;top:50%;transform:translateY(-50%);border-left-color:var(--fg)}
.sh-tooltip[data-side="right"]::after{right:100%;left:auto;top:50%;transform:translateY(-50%);border-right-color:var(--fg)}

/* ── Popover / Dropdown menu ───────────────────────────── */
.sh-popover,.sh-dropdown-content{background:var(--bg-popover);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:.35rem;min-width:12rem;animation:shPopIn .16s cubic-bezier(.22,1,.36,1);z-index:60}
@keyframes shPopIn{from{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}
.sh-dropdown-label{padding:.45rem .55rem .3rem;font:700 .65rem/1 var(--font);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.06em}
.sh-dropdown-item{display:flex;align-items:center;gap:.55rem;padding:.5rem .55rem;font:500 .8125rem/1 var(--font);color:var(--fg);border-radius:var(--radius-sm);cursor:pointer;transition:background .1s;outline:none;border:none;background:transparent;width:100%;text-align:left;text-decoration:none}
.sh-dropdown-item:hover,.sh-dropdown-item:focus-visible{background:var(--bg-muted);color:var(--fg)}
.sh-dropdown-item[data-destructive],.sh-dropdown-item.destructive{color:var(--danger)}
.sh-dropdown-item[data-destructive]:hover,.sh-dropdown-item.destructive:hover{background:var(--danger-bg);color:var(--danger)}
.sh-dropdown-item i,.sh-dropdown-item svg{width:14px;flex-shrink:0;color:var(--fg-muted)}
.sh-dropdown-item[data-destructive] i{color:var(--danger)}
.sh-dropdown-shortcut{margin-left:auto;font:500 .65rem/1 var(--mono);color:var(--fg-subtle);letter-spacing:.02em}
.sh-dropdown-separator{height:1px;background:var(--border);margin:.3rem -.35rem}

/* ── Tabs (shadcn) ──────────────────────────────────────── */
.sh-tabs{display:flex;flex-direction:column;gap:1rem}
.sh-tabs-list{display:inline-flex;gap:.2rem;background:var(--bg-muted);padding:.25rem;border-radius:var(--radius-lg);width:fit-content}
.sh-tab{height:30px;padding:0 .85rem;border:none;background:transparent;border-radius:calc(var(--radius-lg) - .2rem);font:600 .76rem/1 var(--font);color:var(--fg-muted);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:.4rem;outline:none}
.sh-tab:hover{color:var(--fg)}
.sh-tab[aria-selected="true"],.sh-tab.active{background:var(--bg-card);color:var(--fg);box-shadow:var(--shadow-xs)}
.sh-tab-content[hidden]{display:none}
.sh-tabs-underline{border-bottom:1px solid var(--border);display:flex;gap:.2rem}
.sh-tabs-underline .sh-tab{border-radius:0;border-bottom:2px solid transparent;background:transparent!important;box-shadow:none!important;padding:0 .75rem;height:36px}
.sh-tabs-underline .sh-tab[aria-selected="true"],.sh-tabs-underline .sh-tab.active{border-bottom-color:var(--brand);color:var(--brand)}

/* ── Switch ─────────────────────────────────────────────── */
.sh-switch{appearance:none;-webkit-appearance:none;cursor:pointer;width:38px;height:22px;background:var(--border);border-radius:11px;position:relative;transition:background .18s cubic-bezier(.22,1,.36,1);border:none;outline:none;flex-shrink:0}
.sh-switch::before{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.18);transition:transform .2s cubic-bezier(.22,1,.36,1)}
.sh-switch:checked{background:var(--brand)}
.sh-switch:checked::before{transform:translateX(16px)}
.sh-switch:disabled{opacity:.5;cursor:not-allowed}

/* ── Checkbox ───────────────────────────────────────────── */
.sh-checkbox{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1.5px solid var(--border-hover);border-radius:4px;background:var(--bg-card);cursor:pointer;position:relative;transition:all .12s;flex-shrink:0;vertical-align:middle}
.sh-checkbox:hover{border-color:var(--brand)}
.sh-checkbox:checked{background:var(--brand);border-color:var(--brand)}
.sh-checkbox:checked::after{content:'';position:absolute;left:4px;top:0;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.sh-checkbox:disabled{opacity:.5;cursor:not-allowed}
.sh-checkbox-label{display:inline-flex;align-items:center;gap:.5rem;font:500 .8125rem/1.4 var(--font);color:var(--fg);cursor:pointer}

/* ── Radio ──────────────────────────────────────────────── */
.sh-radio{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1.5px solid var(--border-hover);border-radius:50%;background:var(--bg-card);cursor:pointer;position:relative;transition:all .12s;flex-shrink:0;vertical-align:middle}
.sh-radio:hover{border-color:var(--brand)}
.sh-radio:checked{border-color:var(--brand);border-width:4px}
.sh-radio:disabled{opacity:.5;cursor:not-allowed}

/* ── Progress ───────────────────────────────────────────── */
.sh-progress{width:100%;height:8px;background:var(--bg-muted);border-radius:var(--radius-full);overflow:hidden;position:relative}
.sh-progress-bar{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-light));border-radius:inherit;transition:width .4s cubic-bezier(.22,1,.36,1)}
.sh-progress-indeterminate .sh-progress-bar{width:40%;animation:shProgressSlide 1.4s ease-in-out infinite}
@keyframes shProgressSlide{0%{margin-left:-40%}100%{margin-left:100%}}

/* ── Avatar ─────────────────────────────────────────────── */
.sh-avatar{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--bg-muted);color:var(--fg);font:700 .78rem/1 var(--font);overflow:hidden;border:1px solid var(--border);flex-shrink:0;position:relative}
.sh-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.sh-avatar-sm{width:28px;height:28px;font-size:.68rem}
.sh-avatar-lg{width:48px;height:48px;font-size:.95rem}
.sh-avatar-xl{width:64px;height:64px;font-size:1.25rem}
.sh-avatar-brand{background:linear-gradient(135deg,var(--brand),var(--copper));color:#fff;border-color:transparent}
.sh-avatar-group{display:inline-flex}
.sh-avatar-group .sh-avatar+.sh-avatar{margin-left:-.55rem;border:2px solid var(--bg-card)}

/* ── Separator ──────────────────────────────────────────── */
.sh-separator{display:block;flex-shrink:0;background:var(--border);height:1px;width:100%;border:none}
.sh-separator[data-orientation="vertical"],.sh-separator.vertical{height:auto;width:1px;align-self:stretch}

/* ── Breadcrumb ─────────────────────────────────────────── */
.sh-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;font:500 .78rem/1.3 var(--font);color:var(--fg-muted)}
.sh-breadcrumb a,.sh-breadcrumb-link{color:var(--fg-muted);text-decoration:none;transition:color .1s;border-radius:var(--radius-sm);padding:.1rem .25rem}
.sh-breadcrumb a:hover,.sh-breadcrumb-link:hover{color:var(--fg)}
.sh-breadcrumb-separator{color:var(--fg-subtle);font-size:.7rem;user-select:none}
.sh-breadcrumb-page{color:var(--fg);font-weight:600}

/* ── Pagination ─────────────────────────────────────────── */
.sh-pagination{display:inline-flex;align-items:center;gap:.25rem}
.sh-pagination-item{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 .6rem;border:1px solid var(--border);background:var(--bg-card);border-radius:var(--radius);font:600 .78rem/1 var(--font);color:var(--fg);cursor:pointer;transition:all .12s;text-decoration:none;gap:.35rem}
.sh-pagination-item:hover{border-color:var(--brand);color:var(--brand);background:var(--bg-accent)}
.sh-pagination-item[aria-current="page"],.sh-pagination-item.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.sh-pagination-item[disabled]{opacity:.4;pointer-events:none}
.sh-pagination-ellipsis{padding:0 .3rem;color:var(--fg-subtle)}

/* ── Accordion ──────────────────────────────────────────── */
.sh-accordion{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);overflow:hidden}
.sh-accordion-item{border-bottom:1px solid var(--border)}
.sh-accordion-item:last-child{border-bottom:none}
.sh-accordion-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.95rem 1.15rem;background:transparent;border:none;font:600 .83rem/1.3 var(--font);color:var(--fg);cursor:pointer;text-align:left;transition:background .1s}
.sh-accordion-trigger:hover{background:var(--bg-muted)}
.sh-accordion-trigger::after{content:'';width:10px;height:10px;border-right:2px solid var(--fg-muted);border-bottom:2px solid var(--fg-muted);transform:rotate(45deg);transition:transform .2s;margin-right:.25rem;flex-shrink:0}
.sh-accordion-item[open] .sh-accordion-trigger::after,.sh-accordion-item.open .sh-accordion-trigger::after{transform:rotate(-135deg)}
.sh-accordion-content{padding:0 1.15rem 1rem;font:400 .8rem/1.55 var(--font);color:var(--fg-muted)}
.sh-accordion-item:not([open]):not(.open) .sh-accordion-content{display:none}

/* ── Sheet / Drawer ─────────────────────────────────────── */
.sh-sheet-overlay{position:fixed;inset:0;z-index:70;background:var(--bg-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:fadeIn .22s}
.sh-sheet{position:fixed;z-index:71;background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:shSheetInRight .28s cubic-bezier(.22,1,.36,1)}
.sh-sheet-right{right:0;top:0;bottom:0;width:min(28rem,92vw);border-right:none;border-top:none;border-bottom:none}
.sh-sheet-left{left:0;top:0;bottom:0;width:min(28rem,92vw);border-left:none;border-top:none;border-bottom:none;animation:shSheetInLeft .28s cubic-bezier(.22,1,.36,1)}
.sh-sheet-top{top:0;left:0;right:0;max-height:85vh;border-top:none;border-left:none;border-right:none;animation:shSheetInTop .28s cubic-bezier(.22,1,.36,1)}
.sh-sheet-bottom{bottom:0;left:0;right:0;max-height:85vh;border-bottom:none;border-left:none;border-right:none;border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);animation:shSheetInBottom .28s cubic-bezier(.22,1,.36,1)}
.sh-sheet-header{padding:1.2rem 1.4rem 1rem;border-bottom:1px solid var(--border)}
.sh-sheet-title{font:800 1rem/1.2 var(--font);color:var(--fg);letter-spacing:-.01em}
.sh-sheet-desc{font:400 .78rem/1.5 var(--font);color:var(--fg-muted);margin-top:.25rem}
.sh-sheet-body{flex:1;overflow-y:auto;padding:1.2rem 1.4rem}
.sh-sheet-footer{padding:1rem 1.4rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem;background:var(--bg)}
@keyframes shSheetInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes shSheetInLeft{from{transform:translateX(-100%)}to{transform:translateX(0)}}
@keyframes shSheetInTop{from{transform:translateY(-100%)}to{transform:translateY(0)}}
@keyframes shSheetInBottom{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* ── Command / Command palette primitives ──────────────── */
.sh-command{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;max-height:min(28rem,80vh);width:min(34rem,92vw)}
.sh-command-input-wrap{display:flex;align-items:center;gap:.6rem;padding:.9rem 1rem;border-bottom:1px solid var(--border)}
.sh-command-input-wrap>i:first-child{color:var(--fg-muted);font-size:.85rem}
.sh-command-input{flex:1;border:none;outline:none;background:transparent;font:500 .88rem/1.2 var(--font);color:var(--fg);padding:0}
.sh-command-input::placeholder{color:var(--fg-subtle)}
.sh-command-list{overflow-y:auto;padding:.4rem}
.sh-command-group{padding:.25rem 0}
.sh-command-group-heading{padding:.5rem .55rem .35rem;font:700 .65rem/1 var(--font);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.06em}
.sh-command-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .6rem;border-radius:var(--radius-sm);font:500 .82rem/1.2 var(--font);color:var(--fg);cursor:pointer;transition:background .08s}
.sh-command-item:hover,.sh-command-item[data-selected="true"]{background:var(--bg-muted)}
.sh-command-item i{width:14px;color:var(--fg-muted);flex-shrink:0}
.sh-command-shortcut{margin-left:auto;font:500 .66rem/1 var(--mono);color:var(--fg-subtle)}
.sh-command-empty{padding:2rem 1rem;text-align:center;font:500 .8rem/1.4 var(--font);color:var(--fg-subtle)}
.sh-command-separator{height:1px;background:var(--border);margin:.35rem 0}

/* ── Skeleton variants ──────────────────────────────────── */
.sh-skeleton{background:var(--bg-muted);border-radius:var(--radius);position:relative;overflow:hidden;display:block}
.sh-skeleton::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,color-mix(in srgb,#fff 35%,transparent),transparent);animation:shimmer 1.6s infinite}
.sh-skeleton-text{height:.85rem;width:100%}
.sh-skeleton-circle{border-radius:50%;width:36px;height:36px}

/* ── Scroll area ────────────────────────────────────────── */
.sh-scroll{overflow:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.sh-scroll::-webkit-scrollbar{width:8px;height:8px}
.sh-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
.sh-scroll::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}

/* ── Hover card ─────────────────────────────────────────── */
.sh-hover-card{position:relative;display:inline-block}
.sh-hover-card-content{position:absolute;top:calc(100% + 6px);left:0;min-width:15rem;background:var(--bg-popover);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1rem;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .18s;z-index:60}
.sh-hover-card:hover .sh-hover-card-content,.sh-hover-card:focus-within .sh-hover-card-content{opacity:1;visibility:visible;transform:translateY(0)}

/* ── Empty state ────────────────────────────────────────── */
.sh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1.5rem;text-align:center;border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--bg-card)}
.sh-empty-icon{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--bg-muted);display:flex;align-items:center;justify-content:center;color:var(--fg-muted);font-size:1.15rem}
.sh-empty-title{font:700 .95rem/1.2 var(--font);color:var(--fg);letter-spacing:-.01em}
.sh-empty-desc{font:400 .8rem/1.5 var(--font);color:var(--fg-muted);max-width:24rem}

/* ── Stat / metric mini-card ────────────────────────────── */
.sh-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;box-shadow:var(--shadow-xs);transition:all .2s}
.sh-stat:hover{box-shadow:var(--shadow);border-color:var(--border-hover);transform:translateY(-1px)}
.sh-stat-label{font:600 .68rem/1 var(--font);color:var(--fg-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.sh-stat-value{font:800 1.55rem/1.1 var(--font);color:var(--fg);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.sh-stat-delta{font:600 .7rem/1 var(--font);margin-top:.5rem;display:inline-flex;align-items:center;gap:.3rem}
.sh-stat-delta.up{color:var(--success)}
.sh-stat-delta.down{color:var(--danger)}

/* ── Input group + addon ────────────────────────────────── */
.sh-input-group{position:relative;display:flex;align-items:center}
.sh-input-group>.input,.sh-input-group>.form-input{width:100%}
.sh-input-group .sh-input-prefix,.sh-input-group .sh-input-suffix{position:absolute;top:50%;transform:translateY(-50%);color:var(--fg-subtle);pointer-events:none;font-size:.8rem;display:flex;align-items:center;gap:.3rem}
.sh-input-group .sh-input-prefix{left:.75rem}
.sh-input-group .sh-input-suffix{right:.75rem;pointer-events:auto}
.sh-input-group.has-prefix>.input,.sh-input-group.has-prefix>.form-input{padding-left:2.15rem}
.sh-input-group.has-suffix>.input,.sh-input-group.has-suffix>.form-input{padding-right:2.15rem}

/* ── Kbd ────────────────────────────────────────────────── */
.sh-kbd,kbd.sh-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 .3rem;background:var(--bg-muted);border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;font:600 .65rem/1 var(--mono);color:var(--fg-muted)}

/* ── Calendar mini ──────────────────────────────────────── */
.sh-calendar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.85rem;box-shadow:var(--shadow-sm);display:inline-block}
.sh-calendar-header{display:flex;align-items:center;justify-content:space-between;padding:.1rem .35rem .6rem;font:700 .78rem/1 var(--font);color:var(--fg)}
.sh-calendar-nav{background:transparent;border:none;width:26px;height:26px;border-radius:var(--radius-sm);cursor:pointer;color:var(--fg-muted);transition:all .1s;display:flex;align-items:center;justify-content:center}
.sh-calendar-nav:hover{background:var(--bg-muted);color:var(--fg)}
.sh-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.sh-calendar-dow{font:600 .65rem/1 var(--font);color:var(--fg-subtle);text-align:center;padding:.35rem 0;text-transform:uppercase;letter-spacing:.04em}
.sh-calendar-day{height:30px;border:none;background:transparent;border-radius:var(--radius-sm);font:500 .75rem/1 var(--font);color:var(--fg);cursor:pointer;transition:all .1s}
.sh-calendar-day:hover:not([disabled]){background:var(--bg-muted)}
.sh-calendar-day[aria-selected="true"],.sh-calendar-day.selected{background:var(--brand);color:#fff;font-weight:700}
.sh-calendar-day[aria-disabled="true"],.sh-calendar-day:disabled{opacity:.3;cursor:not-allowed}
.sh-calendar-day.today{font-weight:800;color:var(--brand)}
.sh-calendar-day[aria-selected="true"].today{color:#fff}

/* ── Slider ─────────────────────────────────────────────── */
.sh-slider{appearance:none;-webkit-appearance:none;width:100%;height:4px;background:var(--bg-muted);border-radius:var(--radius-full);outline:none;cursor:pointer}
.sh-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--bg-card);border:2px solid var(--brand);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s}
.sh-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}
.sh-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--bg-card);border:2px solid var(--brand);box-shadow:var(--shadow-sm);cursor:pointer}

/* ── Menubar (horizontal) ───────────────────────────────── */
.sh-menubar{display:inline-flex;align-items:center;gap:.2rem;padding:.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs)}
.sh-menubar-trigger{background:transparent;border:none;padding:.35rem .65rem;font:600 .75rem/1 var(--font);color:var(--fg);border-radius:var(--radius-sm);cursor:pointer;transition:background .1s}
.sh-menubar-trigger:hover{background:var(--bg-muted)}
.sh-menubar-trigger[data-state="open"]{background:var(--bg-accent);color:var(--brand)}

/* ── Toggle group ───────────────────────────────────────── */
.sh-toggle-group{display:inline-flex;gap:.25rem;padding:.2rem;background:var(--bg-muted);border-radius:var(--radius)}
.sh-toggle{background:transparent;border:none;padding:.4rem .75rem;font:600 .74rem/1 var(--font);color:var(--fg-muted);border-radius:calc(var(--radius) - .2rem);cursor:pointer;transition:all .12s;display:inline-flex;align-items:center;gap:.35rem}
.sh-toggle:hover{color:var(--fg)}
.sh-toggle[aria-pressed="true"],.sh-toggle.active{background:var(--bg-card);color:var(--fg);box-shadow:var(--shadow-xs)}

/* ── Responsive polish ──────────────────────────────────── */
@media(max-width:640px){
  .sh-toast-viewport{left:.75rem;right:.75rem;max-width:none}
  .sh-toast{min-width:0}
  .sh-command{width:96vw}
  .sh-sheet-right,.sh-sheet-left{width:92vw}
}
