:root{--color-navy-900:#0b1b2b;--color-navy-800:#132032;--color-navy-700:#1d2f49;--color-navy-500:#344b6b;--color-navy-300:#6c809e;--color-canvas:#f7f1e6;--color-canvas-2:#ede2d2;--color-surface:#fff;--color-surface-2:#faf6f0;--color-text-strong:#0f1c2c;--color-text:#2a3a52;--color-text-muted:#5a6b85;--color-text-subtle:#8194ad;--color-border:#e2dccf;--color-border-strong:#cfc7b6;--color-border-subtle:#efe9dd;--color-border-focus:#3a5577;--color-success:#1f8a52;--color-success-bg:#e6f4ec;--color-info:#2a3a52;--color-info-bg:#e8edf4;--color-warning-bg:#fdf2dd;--color-warning:#95611c;--color-danger:#b3261e;--color-danger-bg:#fbe9e7;--color-danger-border:#f5c0bc;--badge-rtq:#b3823c;--badge-arf:#2a6b5b;--badge-cif:#3d4f7a;--font-sans:"Inter", "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-serif:"Source Serif Pro", "Georgia", "Times New Roman", serif;--font-mono:ui-monospace, "SF Mono", Consolas, "Liberation Mono", monospace;--radius-sm:8px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #0b1b2b0a, 0 1px 1px #0b1b2b0a;--shadow-md:0 4px 12px #0b1b2b0f, 0 1px 3px #0b1b2b0a;--shadow-lg:0 12px 28px #0b1b2b14, 0 2px 6px #0b1b2b0d;--ease:cubic-bezier(.2, .8, .2, 1);--t-fast:.12s;--t-med:.16s;--content-max:1400px;--header-h:64px;font-family:var(--font-sans);color:var(--color-text);background:var(--color-canvas);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}*{box-sizing:border-box}html,body,#root{height:100%}body{background:linear-gradient(180deg, var(--color-canvas) 0%, var(--color-canvas-2) 100%);min-height:100vh;color:var(--color-text);margin:0;font-size:15px;line-height:1.5}.layout{flex-direction:column;min-height:100vh;display:flex}.brand-strip{z-index:50;background:var(--color-navy-800);color:#f5f1e8;-webkit-backdrop-filter:saturate(140%)blur(6px);backdrop-filter:saturate(140%)blur(6px);border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;gap:16px;padding:14px 24px;display:flex;position:sticky;top:0}.brand-link{border-radius:var(--radius-md);outline:none;align-items:center;display:inline-flex}.brand-link:focus-visible{outline-offset:4px;outline:2px solid #f5f1e8}.brand-logo{width:200px;max-width:50vw;display:block}.brand-strip__right{align-items:center;gap:16px;display:flex}.brand-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:#f5f1e8b3;font-size:.72rem;font-weight:600}.breadcrumb{background:var(--color-surface-2);border-bottom:1px solid var(--color-border-subtle)}.breadcrumb__inner{max-width:var(--content-max);color:var(--color-text-muted);align-items:center;gap:6px;margin:0 auto;padding:10px 24px;font-size:.78rem;display:flex}.breadcrumb__crumb{letter-spacing:.02em}.breadcrumb__crumb--current{color:var(--color-text-strong);font-weight:600}.breadcrumb__sep{color:var(--color-text-subtle)}.content{width:100%;max-width:var(--content-max);margin:0 auto;padding:28px 24px 56px}.content__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:28px;display:flex}.content__eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted);font-size:.72rem;font-weight:600;display:inline-block}.content__title{font-family:var(--font-serif);color:var(--color-text-strong);letter-spacing:-.01em;margin:4px 0 6px;font-size:2.2rem;font-weight:600;line-height:1.1}.content__lede{max-width:60ch;color:var(--color-text-muted);margin:0}.auth-shell{flex:1;place-items:center;padding:48px 24px;display:grid}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:min(460px,100%);box-shadow:var(--shadow-md);text-align:left;padding:32px}.auth-card__icon{border-radius:var(--radius-lg);background:var(--color-info-bg);width:48px;height:48px;color:var(--color-navy-800);place-items:center;margin-bottom:16px;display:grid}.auth-card h1{font-family:var(--font-serif);color:var(--color-text-strong);margin:0 0 8px;font-size:1.6rem}.auth-card p{color:var(--color-text-muted);margin:0 0 20px}.auth-card__message{background:var(--color-warning-bg);border-radius:var(--radius-md);color:var(--color-warning);border:1px solid #f1d99b;margin:16px 0 0;padding:10px 12px;font-size:.9rem}.dash-grid{grid-template-columns:repeat(12,1fr);grid-auto-rows:1fr;gap:20px;display:grid}.dash-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease), border-color var(--t-med) var(--ease);flex-direction:column;gap:16px;min-height:100%;padding:22px;display:flex}.dash-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.dash-card--span-4{grid-column:span 4}.dash-card--span-6{grid-column:span 6}.dash-card--span-8{grid-column:span 8}.dash-card--span-12{grid-column:span 12}.dash-card__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.dash-card__heading{flex-direction:column;gap:2px;min-width:0;display:flex}.dash-card__eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);font-size:.7rem;font-weight:600}.dash-card__title{font-family:var(--font-serif);color:var(--color-text-strong);letter-spacing:-.005em;align-items:center;gap:10px;margin:4px 0 2px;font-size:1.18rem;font-weight:600;line-height:1.25;display:inline-flex}.dash-card__icon{border-radius:var(--radius-sm);background:var(--color-info-bg);width:28px;height:28px;color:var(--color-navy-800);place-items:center;display:inline-grid}.dash-card__description{color:var(--color-text-muted);margin:0;font-size:.88rem}.dash-card__actions{flex-shrink:0}.dash-card__body{flex-direction:column;flex:1;gap:14px;display:flex}.btn{letter-spacing:.01em;border-radius:var(--radius-md);cursor:pointer;transition:background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;font-family:inherit;font-weight:600;display:inline-flex}.btn--md{height:40px;padding:0 16px;font-size:.9rem}.btn--sm{border-radius:var(--radius-sm);height:32px;padding:0 12px;font-size:.82rem}.btn--full{width:100%}.btn:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.btn:disabled{cursor:not-allowed;opacity:.55}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn:not(:disabled):active{transform:translateY(0)}.btn--primary{background:var(--color-navy-800);color:#fff;border-color:var(--color-navy-800)}.btn--primary:not(:disabled):hover{background:var(--color-navy-700);border-color:var(--color-navy-700)}.btn--secondary{background:var(--color-surface);color:var(--color-navy-800);border-color:var(--color-navy-800)}.btn--secondary:not(:disabled):hover{background:var(--color-info-bg)}.btn--destructive{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-danger)}.btn--destructive:not(:disabled):hover{background:var(--color-danger-bg)}.btn--ghost{color:var(--color-navy-800);background:0 0;border-color:#0000}.btn--ghost:not(:disabled):hover{background:var(--color-info-bg)}.btn__icon{justify-content:center;align-items:center;display:inline-flex}.btn__label{align-items:center;display:inline-flex}.input-shell{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);min-width:200px;height:40px;transition:border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);flex:1;align-items:center;padding:0 12px;display:inline-flex;position:relative}.input-shell:focus-within{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #3a55772e}.input-shell--with-icon{padding-left:40px}.input-shell__icon{color:var(--color-text-subtle);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-shell input,.input-shell select{height:100%;color:var(--color-text-strong);font:inherit;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:0}.input-shell select{cursor:pointer}.input-shell input::placeholder{color:var(--color-text-subtle)}.field-row{flex-wrap:wrap;align-items:stretch;gap:10px;display:flex}.status-chip{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:6px 12px 6px 10px;font-size:.82rem;font-weight:500;display:inline-flex}.status-chip__dot{background:var(--color-text-subtle);border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 3px #0000}.status-chip__dot--success{background:var(--color-success);box-shadow:0 0 0 3px #1f8a5229}.status-chip__dot--info{background:var(--color-info)}.status-chip__dot--warning{background:var(--color-warning)}.status-chip--success{color:var(--color-success);background:var(--color-success-bg);border-color:#1f8a522e}.status-chip__icon{display:inline-flex}.metric-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.metric{border-radius:var(--radius-md);background:var(--color-surface-2);border:1px solid var(--color-border-subtle);flex-direction:column;gap:4px;padding:12px 14px;display:flex}.metric__label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted);font-size:.7rem;font-weight:600}.metric__value{font-family:var(--font-serif);color:var(--color-text-strong);font-size:1.6rem;font-weight:600;line-height:1.05}.metric-footnote{color:var(--color-text-muted);font-size:.85rem}.metric-footnote strong{color:var(--color-text-strong)}.daily-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.daily-list__row{border-radius:var(--radius-sm);justify-content:space-between;gap:12px;padding:8px 10px;font-size:.85rem;display:flex}.daily-list__row:nth-child(2n){background:var(--color-surface-2)}.daily-list__day{font-variant-numeric:tabular-nums;color:var(--color-text-strong);font-weight:500}.daily-list__counts{color:var(--color-text-muted);font-variant-numeric:tabular-nums;gap:12px;display:inline-flex}.contact-list{flex-direction:column;gap:6px;max-height:320px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.contact-list__item{background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);text-align:left;cursor:pointer;width:100%;transition:border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);font:inherit;flex-direction:column;gap:2px;padding:10px 12px;display:flex}.contact-list__item:hover:not(:disabled){border-color:var(--color-border-focus);background:var(--color-surface-2)}.contact-list__item:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.contact-list__item.is-selected{border-color:var(--color-navy-800);background:var(--color-info-bg)}.contact-list__item:disabled{cursor:default;opacity:.6}.contact-list__name{color:var(--color-text-strong);font-weight:600}.contact-list__email{color:var(--color-text-muted);font-size:.85rem}.selection-pill{background:var(--color-surface-2);border:1px dashed var(--color-border-strong);color:var(--color-text-strong);border-radius:999px;align-self:flex-start;align-items:center;gap:8px;padding:6px 12px;font-size:.82rem;display:inline-flex}.selection-pill__label{text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);font-size:.65rem;font-weight:700}.selection-pill__value{font-weight:600}.selection-pill__placeholder{color:var(--color-text-muted)}.url-box{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);flex-direction:column;gap:10px;padding:12px;display:flex}.url-box__value{font-family:var(--font-mono);color:var(--color-text);word-break:break-all;font-size:.8rem}.data-list{flex-direction:column;gap:4px;max-height:360px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.data-list__row{border-radius:var(--radius-sm);background:var(--color-surface-2);grid-template-columns:64px 1fr auto;align-items:center;gap:12px;padding:10px 12px;font-size:.88rem;display:grid}.data-list__primary{color:var(--color-text-strong);font-weight:500}.data-list__meta{color:var(--color-text-muted);font-size:.82rem}.data-list__meta--muted{font-variant-numeric:tabular-nums;color:var(--color-text-subtle)}.badge{letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-sm);color:#fff;background:var(--color-text-muted);justify-content:center;align-items:center;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.badge--rtq{background:var(--badge-rtq)}.badge--arf{background:var(--badge-arf)}.badge--cif{background:var(--badge-cif)}.empty-state{text-align:center;border-radius:var(--radius-md);background:var(--color-surface-2);border:1px dashed var(--color-border-strong);color:var(--color-text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;padding:28px 16px;display:flex}.empty-state__icon{background:var(--color-surface);border:1px solid var(--color-border-subtle);width:40px;height:40px;color:var(--color-text-subtle);border-radius:50%;place-items:center;margin-bottom:4px;display:grid}.empty-state__title{color:var(--color-text-strong);margin:0;font-weight:600}.empty-state__helper{max-width:36ch;margin:0;font-size:.85rem;line-height:1.5}.user-menu{position:relative}.user-menu__trigger{color:#f5f1e8;cursor:pointer;height:44px;font:inherit;transition:background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);background:#ffffff0f;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:10px;padding:4px 12px 4px 4px;display:inline-flex}.user-menu__trigger:hover{background:#ffffff1a;border-color:#ffffff29}.user-menu__trigger:focus-visible{outline-offset:2px;outline:2px solid #f5f1e8}.user-menu__avatar{color:#1a1208;letter-spacing:.04em;background:linear-gradient(140deg,#cbb27a,#8b6f3a);border-radius:50%;place-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:grid}.user-menu__avatar--lg{width:44px;height:44px;font-size:1rem}.user-menu__meta{flex-direction:column;align-items:flex-start;line-height:1.1;display:none}.user-menu__name{font-size:.82rem;font-weight:600}.user-menu__email{color:#f5f1e899;font-size:.72rem}.user-menu__panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:260px;box-shadow:var(--shadow-lg);z-index:60;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 8px);right:0}.user-menu__panel-header{border-bottom:1px solid var(--color-border-subtle);align-items:center;gap:12px;margin-bottom:4px;padding:10px 12px;display:flex}.user-menu__panel-meta{flex-direction:column;min-width:0;display:flex}.user-menu__panel-name{color:var(--color-text-strong);white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:600;overflow:hidden}.user-menu__panel-email{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.user-menu__item{width:100%;height:36px;font:inherit;text-align:left;border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;transition:background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);background:0 0;border:none;align-items:center;gap:10px;padding:0 12px;font-size:.88rem;display:flex}.user-menu__item:hover:not(:disabled){background:var(--color-info-bg)}.user-menu__item:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.user-menu__item--destructive{color:var(--color-danger)}.user-menu__item--destructive:hover:not(:disabled){background:var(--color-danger-bg)}.user-menu__item:disabled{opacity:.5;cursor:not-allowed}@media (width>=640px){.user-menu__meta{display:flex}}.toast-stack{top:calc(var(--header-h) + 16px);z-index:100;pointer-events:none;flex-direction:column;gap:10px;max-width:min(360px,100vw - 32px);display:flex;position:fixed;right:16px}.toast{pointer-events:auto;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);animation:toast-in .2s var(--ease);align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.toast--success{background:var(--color-success-bg);border-color:#1f8a5247}.toast--error{border-color:var(--color-danger-border);background:var(--color-danger-bg)}.toast--info{border-color:var(--color-border)}.toast__icon{color:var(--color-text);flex-shrink:0;margin-top:1px}.toast--success .toast__icon{color:var(--color-success)}.toast--error .toast__icon{color:var(--color-danger)}.toast__text{color:var(--color-text-strong);flex:1;margin:0;font-size:.88rem;line-height:1.4}.toast__close{width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;transition:background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);background:0 0;border:none;border-radius:4px;flex-shrink:0;place-items:center;display:grid}.toast__close:hover{color:var(--color-text-strong);background:#0000000d}.toast__close:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:1px}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (width<=1080px){.dash-card--span-4{grid-column:span 6}.dash-card--span-6{grid-column:span 12}}@media (width<=720px){.brand-strip{padding:12px 16px}.breadcrumb__inner{padding:8px 16px}.content{padding:20px 16px 40px}.content__title{font-size:1.7rem}.dash-grid{gap:14px}.dash-card,.dash-card--span-4,.dash-card--span-6,.dash-card--span-8,.dash-card--span-12{grid-column:span 12}.data-list__row{grid-template-columns:1fr;gap:4px}.toast-stack{max-width:none;left:8px;right:8px}.user-menu__meta{display:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}
