@import"https://fonts.googleapis.com/css2?family=Inter+Tight:wght@600;700;800&family=Inter:wght@400;500;600;700&display=swap";:root{--fc-cyan: #00AEEF;--fc-red: #ED1C24;--fc-lime: #C8D400;--accent: var(--fc-cyan);--accent-dark: #0090c8;--muted: #6b7280;--border: #e5e7eb;--surface: #ffffff;--bg: #f3f4f6;--text: #111827;--text-secondary: #374151;--display-font: "Inter Tight", "Inter", system-ui, sans-serif;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100vh}html{scroll-behavior:smooth}body{margin:0}a,button,label{-webkit-tap-highlight-color:transparent}.marketing-shell{min-height:100vh;background:radial-gradient(circle at top left,rgba(0,174,239,.12),transparent 36%),linear-gradient(180deg,#f6f7f3,#eef2f6 52%,#fbfbf8);color:#102031}.landing-hero{position:relative;min-height:100svh;padding:0 0 5.5rem;overflow:hidden;background:linear-gradient(135deg,#ffffffb8,#ffffff2e),linear-gradient(180deg,#f4f7fb,#edf2f7 55%,#f8f7f2)}.landing-hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(13,27,42,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(13,27,42,.05) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 88%);mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 88%);pointer-events:none}.hero-aura{position:absolute;border-radius:999px;filter:blur(18px);opacity:.75;animation:auraDrift 16s ease-in-out infinite alternate;pointer-events:none}.hero-aura-primary{top:8rem;right:-8rem;width:28rem;height:28rem;background:radial-gradient(circle,#00aeef52,#00aeef00 72%)}.hero-aura-secondary{bottom:2rem;left:-6rem;width:24rem;height:24rem;background:radial-gradient(circle,#0f172a1f,#0f172a00 72%);animation-duration:18s}.landing-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.35rem clamp(1.2rem,3vw,2.6rem)}.landing-brand{display:inline-flex;align-items:center}.landing-logo{width:clamp(9.5rem,13vw,12rem);height:auto}.landing-nav{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.landing-nav a,.nav-auth-btn,.hero-btn,.auth-home-link,.auth-footer-link,.auth-close-btn,.auth-page-card .forgot-link,.auth-page-card .btn-primary,.auth-page-card .btn-ghost{transition:transform .18s ease,color .18s ease,border-color .18s ease,background-color .18s ease,box-shadow .18s ease,opacity .18s ease}.landing-nav a{color:#102031c2;text-decoration:none;font-size:.92rem;font-weight:600}.landing-nav a:not(.nav-auth-btn):hover{color:#102031}.nav-auth-btn,.hero-btn,.auth-home-link,.auth-page-card .btn-primary,.auth-page-card .btn-ghost,.auth-close-btn{display:inline-flex;align-items:center;justify-content:center;appearance:none;border:0;border-radius:999px;font:inherit;cursor:pointer;text-decoration:none}.nav-auth-btn{min-height:2.85rem;padding:0 1.1rem;background:#0d1b2a;color:#fff;font-size:.92rem;font-weight:600;box-shadow:0 16px 40px #0d1b2a26}.nav-auth-btn:hover,.hero-btn:hover,.auth-home-link:hover,.auth-page-card .btn-primary:hover,.auth-page-card .btn-ghost:hover,.auth-close-btn:hover,.auth-footer-link:hover,.auth-page-card .forgot-link:hover{transform:translateY(-1px)}.landing-nav .nav-auth-btn,.landing-nav .nav-auth-btn:hover{color:#fff}.nav-auth-btn.is-secondary,.landing-nav .nav-auth-btn.is-secondary{background:#ffffffd6;color:#102031;border:1px solid rgba(16,32,49,.14);box-shadow:none}.landing-nav .nav-auth-btn.is-secondary:hover{color:#102031}.landing-hero-inner,.story-section,.closing-banner{width:min(1180px,calc(100% - 2.4rem));margin:0 auto}.landing-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);align-items:center;gap:clamp(2rem,5vw,4.5rem);padding:clamp(1.8rem,5vw,3.2rem) 0 0}.hero-copy{max-width:34rem}.reveal{opacity:0;transform:translateY(18px);animation:revealUp .72s cubic-bezier(.22,1,.36,1) forwards}.hero-copy .reveal:nth-child(1){animation-delay:.12s}.hero-copy .reveal:nth-child(2){animation-delay:.22s}.hero-copy .reveal:nth-child(3){animation-delay:.32s}.hero-copy .reveal:nth-child(4){animation-delay:.42s}.hero-copy .reveal:nth-child(5){animation-delay:.52s}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;margin:0 0 1.1rem;padding:.38rem .85rem .38rem .65rem;border-radius:999px;background:#00aeef17;border:1px solid rgba(0,174,239,.22);font-size:.82rem;font-weight:600;letter-spacing:.01em;color:#0c6b8e}.hero-badge-dot{display:block;width:6px;height:6px;border-radius:999px;background:#00aeef;flex-shrink:0;box-shadow:0 0 0 3px #00aeef38;animation:badgePulse 2.4s ease-in-out infinite}.hero-kicker,.section-label,.auth-panel-kicker,.workflow-rail-kicker{margin:0 0 .9rem;font-size:.84rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#0f6b8e}.hero-title,.section-title,.closing-title{margin:0;font-family:var(--display-font);font-size:clamp(2.4rem,4.6vw,4rem);font-weight:700;line-height:1;letter-spacing:-.05em;color:#102031}.hero-lead,.section-copy{margin:1.4rem 0 0;font-size:1.06rem;line-height:1.75;color:#102031c2}.hero-actions,.closing-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}.hero-btn,.auth-page-card .btn-primary,.auth-page-card .btn-ghost{min-height:3.15rem;padding:0 1.4rem;font-size:.95rem;font-weight:600}.hero-btn,.auth-page-card .btn-primary{background:linear-gradient(135deg,#0d1b2a,#14385a);color:#fff;box-shadow:0 18px 40px #0d1b2a2e}.hero-btn-secondary,.auth-page-card .btn-ghost{background:#ffffffc7;color:#102031;border:1px solid rgba(16,32,49,.14);box-shadow:none}.hero-caption{margin:1rem 0 0;font-size:.94rem;color:#1020319e}.workflow-rail{position:relative;display:grid;gap:1rem;padding:1.25rem 0 0;animation:railFloat 9s ease-in-out infinite alternate}.workflow-stage{position:relative;display:grid;gap:1.2rem;padding:1.2rem 0 2.2rem}.workflow-stage:before{content:"";position:absolute;top:4rem;bottom:3.5rem;left:50%;width:1px;background:linear-gradient(180deg,#00aeef52,#0d1b2a0f);transform:translate(-50%)}.workflow-ribbon,.workflow-sheet{position:relative;margin-left:auto;margin-right:auto;width:min(100%,30rem);border:1px solid rgba(16,32,49,.1);background:#ffffffc7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.workflow-ribbon{display:flex;justify-content:space-between;gap:1rem;padding:.95rem 1.15rem;border-radius:999px;box-shadow:0 14px 34px #10203114}.workflow-ribbon-top{transform:translate(10%)}.workflow-ribbon-bottom{transform:translate(-8%)}.workflow-ribbon-label{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#10203185}.workflow-ribbon-value{font-size:.96rem;font-weight:600;color:#102031}.workflow-sheet{padding:1.35rem 1.35rem 1.45rem;border-radius:2rem;box-shadow:0 28px 80px #1020311f}.workflow-sheet-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.92rem;font-weight:600;color:#102031ad}.workflow-status{color:#0f6b8e}.workflow-sheet-amount{margin-top:1.05rem;font-size:clamp(1.7rem,3vw,2.45rem);line-height:1.02;letter-spacing:-.04em;color:#102031}.workflow-sheet-copy{margin:.85rem 0 0;font-size:1rem;line-height:1.65;color:#102031b8}.workflow-sheet-items{display:grid;gap:.75rem;margin-top:1.35rem}.workflow-sheet-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem .95rem;border-radius:1rem;background:#0f172a0a;border:1px solid rgba(16,32,49,.07);font-size:.92rem;font-weight:600;color:#102031c2}.workflow-sheet-item span:last-child{color:#0f6b8e}.landing-main{padding:0}.feature-strip{width:min(1180px,calc(100% - 2.4rem));margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:4rem 0 4.5rem}.feature-card{display:flex;flex-direction:column;padding:1.75rem;border-radius:16px;background:#fff;border:1px solid rgba(16,32,49,.09);box-shadow:0 2px 12px #1020310d;transition:transform .22s ease,box-shadow .22s ease;position:relative;overflow:hidden}.feature-card:after{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,#0f6b8e,#1aaddb);transform:scaleX(0);transform-origin:left;transition:transform .28s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #1020311a}.feature-card:hover:after{transform:scaleX(1)}.feature-card-number{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#0f6b8e14;font-size:.7rem;font-weight:700;color:#0f6b8e;letter-spacing:.03em;margin-bottom:1.1rem;flex-shrink:0}.feature-card-label{margin:0 0 .55rem;font-size:1.05rem;font-weight:700;color:#102031;letter-spacing:-.015em;line-height:1.2}.feature-card-body{margin:0;font-size:.9rem;line-height:1.65;color:#10203194}.story-section,.closing-banner{padding:clamp(3rem,8vw,5.5rem) 0}.story-section-dark{color:#f4f8fb;background:radial-gradient(circle at top right,rgba(0,174,239,.16),transparent 32%),linear-gradient(180deg,#0d1b2a,#12273d);border-radius:2rem;padding-left:clamp(1.8rem,4vw,3.2rem);padding-right:clamp(1.8rem,4vw,3.2rem);display:grid;grid-template-columns:minmax(min-content,2fr) minmax(0,3fr);gap:clamp(3rem,6vw,6rem);align-items:start}.story-section-dark .section-label{color:#80d5f6f0}.story-section-dark .section-title{color:#f7fbff;font-size:clamp(1.7rem,2.8vw,2.4rem);line-height:1.08;letter-spacing:-.04em}.story-section-dark .step-body h3{color:#f7fbff}.story-section-dark .step-body p{color:#e9f2f9bd}.story-intro{position:sticky;top:2rem}.section-title,.closing-title{font-size:clamp(2rem,3.8vw,3.2rem)}.steps-list{margin:0;padding:0;list-style:none;display:grid;gap:0}.step-row{display:grid;grid-template-columns:4.2rem minmax(0,1fr);gap:1.2rem;padding:1.6rem 0;border-top:1px solid rgba(255,255,255,.14);align-items:start}.step-row:first-child{border-top:0;padding-top:0}.step-number{font-size:.86rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#80d5f6d1}.step-body h3{margin:0;font-size:1.32rem;font-weight:700;line-height:1.15;letter-spacing:-.02em}.step-xero-lockup{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap}.step-xero-mark{display:inline-block;width:1.7rem;height:1.7rem;padding:.12rem;border-radius:50%;object-fit:contain;vertical-align:-.18em;background:#fffffff5;box-shadow:0 10px 24px #00000029,0 0 0 1px #ffffff24;opacity:1}.workflow-ribbon-xero-value{display:inline-flex;align-items:center;gap:.38rem}.workflow-ribbon-xero-icon{width:15px;height:15px;border-radius:50%;object-fit:cover;flex-shrink:0;opacity:.88}.step-body p{margin:.55rem 0 0;font-size:1rem;line-height:1.7}.closing-cta{margin:clamp(2.5rem,5vw,4rem) 0 0;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,4vw,3rem);background:radial-gradient(circle at top right,rgba(0,174,239,.18),transparent 40%),linear-gradient(145deg,#0d1b2a,#0f3351);text-align:center}.closing-cta-inner{max-width:42rem;margin:0 auto}.closing-eyebrow{margin:0 0 1rem;font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#80d5f6e0}.closing-cta .closing-title{color:#f4f8fb}.closing-sub{margin:1.1rem 0 0;font-size:1.02rem;line-height:1.72;color:#e9f2f9ad}.closing-cta .closing-actions{justify-content:center;margin-top:2.2rem}.closing-btn-primary{background:#fff;color:#0d1b2a;box-shadow:0 16px 40px #00000047}.closing-btn-primary:hover{background:#ffffffe6}.closing-btn-ghost{background:#ffffff1a;color:#ffffffe6;border:1px solid rgba(255,255,255,.2);box-shadow:none}.closing-btn-ghost:hover{background:#ffffff2e}.auth-page-shell{position:relative;min-height:100svh;overflow:hidden;padding:1.35rem 0 2.2rem;background:linear-gradient(135deg,#ffffffb8,#ffffff2e),linear-gradient(180deg,#f4f7fb,#edf2f7 55%,#f8f7f2)}.auth-page-shell:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(13,27,42,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(13,27,42,.05) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.44),transparent 88%);mask-image:linear-gradient(180deg,rgba(0,0,0,.44),transparent 88%);pointer-events:none}.auth-page-aura{position:absolute;border-radius:999px;filter:blur(18px);opacity:.72;animation:auraDrift 16s ease-in-out infinite alternate;pointer-events:none}.auth-page-aura-primary{top:4rem;right:-6rem;width:24rem;height:24rem;background:radial-gradient(circle,#00aeef3d,#00aeef00 72%)}.auth-page-aura-secondary{bottom:0;left:-7rem;width:22rem;height:22rem;background:radial-gradient(circle,#0f172a1a,#0f172a00 72%)}.auth-page-header,.auth-page-main{position:relative;z-index:2}.auth-page-main{width:min(1180px,calc(100% - 2.4rem));margin:0 auto}.auth-page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 clamp(1.2rem,3vw,2.6rem)}.auth-home-link{min-height:2.85rem;padding:0 1.1rem;border-radius:999px;border:1px solid rgba(16,32,49,.14);background:#ffffffd1;color:#102031;font-size:.92rem;font-weight:600}.auth-page-main{min-height:calc(100svh - 6.8rem);display:grid;grid-template-columns:minmax(0,.88fr) minmax(360px,.72fr);align-items:center;gap:clamp(2rem,6vw,5rem);padding-top:2rem}.auth-page-copy{max-width:31rem}.auth-page-display{margin:0;font-family:var(--display-font);font-size:clamp(2.85rem,5.2vw,4.9rem);font-weight:700;line-height:.96;letter-spacing:-.06em;color:#102031}.auth-page-lead{margin:1.15rem 0 0;font-size:1.02rem;line-height:1.72;color:#102031b8}.auth-page-card{display:grid;gap:1.4rem;padding:1.45rem;border-radius:2rem;background:#f8fafce0;border:1px solid rgba(16,32,49,.08);box-shadow:0 28px 90px #10203124;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.auth-overlay{position:fixed;inset:0;display:grid;grid-template-columns:minmax(0,1fr);justify-items:end;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease;z-index:200}.auth-overlay.is-open{opacity:1;visibility:visible}.auth-scrim{position:absolute;inset:0;border:0;background:#09121c73;cursor:pointer}.auth-panel{position:relative;z-index:1;width:min(30rem,100vw);min-height:100vh;padding:1.35rem;background:#f8fafceb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(16,32,49,.08);box-shadow:-30px 0 90px #1020312e;transform:translate(100%);transition:transform .26s cubic-bezier(.22,1,.36,1);display:grid;align-content:start;gap:1.45rem}.auth-overlay.is-open .auth-panel{transform:translate(0)}.auth-panel-header,.auth-panel-footer{display:flex;align-items:flex-start;gap:1rem}.auth-panel-header{justify-content:space-between}.auth-panel-kicker{margin-bottom:.55rem}.auth-panel-title{margin:0;font-size:1.8rem;line-height:1.05;letter-spacing:-.04em;color:#102031}.auth-close-btn{min-height:2.75rem;padding:0 1rem;background:#ffffffd1;border:1px solid rgba(16,32,49,.12);color:#102031c2}.auth-brand-lockup{display:grid;gap:.85rem;padding-bottom:1.1rem;border-bottom:1px solid rgba(16,32,49,.08)}.auth-logo{width:10.5rem;height:auto}.auth-brand-copy,.auth-panel-footer p,.login-helper,.login-confirm{margin:0;font-size:.94rem;line-height:1.7;color:#102031a8}.login-form{display:grid;gap:.95rem}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.95rem}.field{display:grid;gap:.45rem;margin:0;padding:0;border:0;min-width:0}.field-label-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.field-label{font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#102031b8}.field-input{width:100%;min-height:3.15rem;padding:0 1rem;border:1px solid rgba(16,32,49,.12);border-radius:1rem;background:#ffffffd6;color:#102031;font:inherit;font-size:.98rem;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.field-input::placeholder{color:#10203157}.field-input:focus{border-color:#00aeef7a;box-shadow:0 0 0 4px #00aeef1f}.field-input:disabled,.auth-page-card .btn-primary:disabled,.auth-page-card .btn-ghost:disabled,.auth-close-btn:disabled{cursor:not-allowed;opacity:.6}.field-hint{margin:0;font-size:.84rem;line-height:1.5;color:#10203194}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.choice-option{display:flex;align-items:center;gap:.7rem;min-height:3.15rem;padding:.85rem 1rem;border:1px solid rgba(16,32,49,.12);border-radius:1rem;background:#ffffffd6;color:#102031;font-size:.96rem;font-weight:600;cursor:pointer}.choice-input{margin:0;accent-color:#0f6b8e}.auth-page-card .forgot-link,.auth-footer-link{padding:0;background:none;border:0;color:#0f6b8e;font:inherit;font-size:.92rem;font-weight:600;cursor:pointer}.auth-page-card .forgot-link:hover,.auth-footer-link:hover{color:#102031}.login-error{margin:0;padding:.95rem 1rem;border-radius:1rem;background:#ef444414;border:1px solid rgba(239,68,68,.18);color:#8b1e1e;font-size:.92rem;line-height:1.55}.auth-panel-footer{align-items:baseline;justify-content:flex-start;gap:.45rem;flex-wrap:wrap;padding-top:.2rem}.login-confirm{display:grid;gap:1rem}.scroll-reveal{opacity:0;transform:var(--sr-transform, translateY(28px));transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}.scroll-reveal.is-visible{opacity:1;transform:none}.feature-strip .feature-card:nth-child(1){--sr-transform: translateX(-28px) translateY(16px)}.feature-strip .feature-card:nth-child(2){--sr-transform: translateY(36px)}.feature-strip .feature-card:nth-child(3){--sr-transform: translateX(28px) translateY(16px)}.story-intro{--sr-transform: translateX(-28px)}.step-row{--sr-transform: translateX(32px)}.closing-cta{--sr-transform: translateY(24px) scale(.97)}.feature-strip .scroll-reveal:nth-child(1){transition-delay:0ms}.feature-strip .scroll-reveal:nth-child(2){transition-delay:.1s}.feature-strip .scroll-reveal:nth-child(3){transition-delay:.2s}.feature-card.is-visible:hover{transform:translateY(-3px)}.steps-list .scroll-reveal:nth-child(1){transition-delay:0ms}.steps-list .scroll-reveal:nth-child(2){transition-delay:.13s}.steps-list .scroll-reveal:nth-child(3){transition-delay:.26s}.step-number{transition:color .5s ease,text-shadow .5s ease}.step-row.is-visible .step-number{color:#00aeeff2;text-shadow:0 0 18px rgba(0,174,239,.45)}.step-row{border-radius:.75rem;margin-left:-.75rem;margin-right:-.75rem;padding-left:.75rem;padding-right:.75rem;transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1),background-color .2s ease}.step-row:hover{background:#ffffff0a}.steps-list{position:relative}.steps-list:after{content:"";position:absolute;left:1.55rem;top:.4rem;width:1px;height:0%;background:linear-gradient(180deg,#00aeefb3,#00aeef0f);transition:height .7s cubic-bezier(.22,1,.36,1);pointer-events:none}.steps-list[data-steps-visible="1"]:after{height:32%}.steps-list[data-steps-visible="2"]:after{height:65%}.steps-list[data-steps-visible="3"]:after{height:100%}.closing-cta{position:relative;overflow:hidden}.closing-cta:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 30%,rgba(0,174,239,.22),transparent 55%);animation:ctaAuraPulse 5s ease-in-out infinite alternate;pointer-events:none}@keyframes ctaAuraPulse{0%{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.18)}}.workflow-ribbon-top{animation:railItemReveal .56s cubic-bezier(.22,1,.36,1) .32s both}.workflow-sheet{animation:railItemReveal .6s cubic-bezier(.22,1,.36,1) .52s both}.workflow-ribbon-bottom{animation:railItemReveal .56s cubic-bezier(.22,1,.36,1) 1.7s both}.workflow-sheet-item:nth-child(1){animation:railItemReveal .48s cubic-bezier(.22,1,.36,1) .9s both}.workflow-sheet-item:nth-child(2){animation:railItemReveal .48s cubic-bezier(.22,1,.36,1) 1.06s both}.workflow-sheet-item:nth-child(3){animation:railItemReveal .48s cubic-bezier(.22,1,.36,1) 1.22s both}.workflow-stage:before{transform-origin:top center;animation:stageLineDraw .7s cubic-bezier(.22,1,.36,1) .4s both}.workflow-status{display:flex;align-items:center;gap:.38rem}.workflow-status:before{content:"";display:block;width:7px;height:7px;border-radius:50%;background:#00aeef;flex-shrink:0;animation:statusDotPulse 2.2s ease-in-out infinite}@keyframes statusDotPulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 #00aeef66}50%{opacity:.7;transform:scale(.75);box-shadow:0 0 0 4px #00aeef00}}@keyframes railItemReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes stageLineDraw{0%{transform:translate(-50%) scaleY(0)}to{transform:translate(-50%) scaleY(1)}}@keyframes badgePulse{0%,to{box-shadow:0 0 0 3px #00aeef38}50%{box-shadow:0 0 0 5px #00aeef14}}@keyframes revealUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes auraDrift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(1.6rem,-1rem,0) scale(1.06)}}@keyframes railFloat{0%{transform:translateY(0)}to{transform:translateY(-12px)}}@media(max-width:980px){.landing-hero-inner,.auth-page-main{grid-template-columns:1fr}.landing-hero-inner{padding-top:1.8rem}.workflow-rail{max-width:36rem}.feature-strip{grid-template-columns:1fr}.story-section-dark{grid-template-columns:1fr;gap:2rem}.story-intro{position:static}.story-section-dark .section-title{font-size:clamp(1.6rem,5vw,2.2rem)}.auth-page-main{min-height:auto;padding-top:1.6rem}.auth-page-copy{max-width:34rem}}@media(max-width:760px){.landing-header{align-items:flex-start;flex-direction:column}.landing-nav{width:100%;justify-content:flex-start}.landing-nav a{display:none}.hero-title{font-size:clamp(2rem,10vw,2.8rem)}.section-title,.closing-title{font-size:clamp(1.85rem,8vw,2.6rem)}.workflow-ribbon-top,.workflow-ribbon-bottom{transform:none}.step-row{grid-template-columns:1fr;gap:.55rem}.auth-page-header,.auth-panel-header,.auth-panel-footer{flex-direction:column;align-items:flex-start}.auth-page-main{width:min(100%,calc(100% - 1.5rem))}.auth-page-card{padding:1.2rem;border-radius:1.6rem}.auth-page-display{font-size:clamp(2.3rem,13vw,3.5rem)}.field-grid,.choice-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.hero-aura,.auth-page-aura,.workflow-rail,.workflow-ribbon-top,.workflow-sheet,.workflow-ribbon-bottom,.workflow-sheet-item,.workflow-stage:before,.workflow-status:before,.closing-cta:after,.steps-list:after,.reveal,.landing-nav a,.nav-auth-btn,.hero-btn,.auth-home-link,.auth-page-card .btn-primary,.auth-page-card .btn-ghost,.auth-close-btn,.auth-footer-link,.auth-page-card .forgot-link,.auth-overlay,.auth-panel{animation:none;transition:none;transform:none;opacity:1}}.sidebar-inbox-summary{display:grid;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.sidebar-inbox-card{border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,#fff,#f8fbff);padding:12px;display:flex;flex-direction:column;gap:4px}.sidebar-inbox-value{font-size:1.4rem;font-weight:800;color:var(--text)}.sidebar-inbox-label{font-size:.78rem;color:var(--muted)}.inbox-page{width:min(980px,100%);margin:0 auto;display:grid;gap:18px}.inbox-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding:22px 24px;border:1px solid var(--border);border-radius:20px;background:radial-gradient(circle at top right,rgba(0,174,239,.12),transparent 38%),linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 18px 46px #0f172a0d}.inbox-heading{margin:4px 0 6px;font-size:clamp(1.6rem,2vw,2.15rem);line-height:1.05;color:var(--text)}.inbox-copy{max-width:700px;margin:0;color:var(--muted);line-height:1.55}.inbox-hero-actions{display:flex;flex-wrap:wrap;gap:10px}.inbox-address-card,.inbox-empty-card,.inbox-message-card,.inbox-list-section{border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:0 14px 40px #0f172a0a}.inbox-address-card{padding:24px 26px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:22px;align-items:center;border-color:#3b82f624;background:radial-gradient(circle at top right,rgba(14,165,233,.1),transparent 34%),linear-gradient(180deg,#fff,#f8fbff)}.inbox-address-main{display:grid;gap:10px}.inbox-address-value{padding:16px 18px;border:1px solid rgba(148,163,184,.18);border-radius:16px;background:#fff;color:var(--text);font-size:clamp(1rem,1vw + .85rem,1.22rem);font-weight:700;line-height:1.45;word-break:break-word;box-shadow:inset 0 1px #ffffffb3}.inbox-address-help{margin:0;color:var(--muted);line-height:1.55}.inbox-address-actions{display:grid;gap:10px;justify-items:end}.inbox-address-actions .primary-button,.inbox-address-actions .secondary-button{min-width:190px}.inbox-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.inbox-stat-card{padding:16px 18px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 10px 30px #0f172a0a}.inbox-stat-card strong{display:block;margin-top:6px;font-size:1.6rem;line-height:1;color:var(--text)}.inbox-stat-label{font-size:.88rem;font-weight:600;color:var(--muted)}.inbox-empty-card{padding:28px 24px}.inbox-empty-card h2{margin:0 0 8px;font-size:1.15rem;color:var(--text)}.inbox-empty-card p{margin:0;color:var(--muted);line-height:1.55}.inbox-list-section{padding:22px 24px 24px;display:grid;gap:16px}.inbox-section-header{display:flex;align-items:center}.inbox-section-heading{margin:0;font-size:1.18rem;color:var(--text)}.inbox-message-list{display:grid;gap:14px}.inbox-message-card{padding:18px 20px;display:grid;gap:14px;border-radius:16px;box-shadow:none;background:linear-gradient(180deg,#fff,#fcfdff)}.inbox-message-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.inbox-message-subject{margin:0 0 6px;font-size:1.05rem;color:var(--text)}.inbox-message-meta,.inbox-attachment-meta,.inbox-attachment-summary,.inbox-attachment-error{margin:0;color:var(--muted);line-height:1.5}.inbox-status-pill,.inbox-inline-status{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:.73rem;font-weight:700;white-space:nowrap}.inbox-status-pill.is-processed,.inbox-inline-status.is-processed{background:#10b9811f;color:#047857}.inbox-status-pill.is-partial,.inbox-inline-status.is-processing,.inbox-inline-status.is-queued{background:#2563eb1a;color:#1d4ed8}.inbox-status-pill.is-failed,.inbox-inline-status.is-failed{background:#ef44441f;color:#b91c1c}.inbox-inline-status.is-ignored{background:#6b72801f;color:#6b7280}.inbox-attachment-list{display:grid;gap:10px}.inbox-attachment-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:14px;background:#f8fbfe;border:1px solid rgba(148,163,184,.18)}.inbox-attachment-row.is-ignored{background:#f9fafb}.inbox-attachment-info{min-width:0;display:grid;gap:4px}.inbox-attachment-name{margin:0;font-weight:700;color:var(--text);word-break:break-word}.inbox-attachment-error{color:#b45309}.inbox-attachment-actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px;flex-shrink:0}@media(max-width:980px){.inbox-address-card,.inbox-stats-grid{grid-template-columns:1fr}.inbox-address-actions{justify-items:stretch}.inbox-address-actions .primary-button,.inbox-address-actions .secondary-button{width:100%}.inbox-section-header,.inbox-message-header,.inbox-attachment-row{display:grid}.inbox-attachment-actions{justify-content:flex-start}}@media(max-width:760px){.sidebar-inbox-summary{margin-top:14px;padding-top:14px}.inbox-hero,.inbox-message-header,.inbox-attachment-row{flex-direction:column;align-items:stretch}.inbox-hero-actions,.inbox-attachment-actions{width:100%}.inbox-stats-grid{grid-template-columns:1fr}}@media(max-width:420px){.inbox-page{gap:14px}}.charge-through-panel{display:grid;gap:12px}.charge-through-error{margin:0;color:#b91c1c;font-weight:700}.charge-through-upload-notes{margin:10px 0 0;padding:0;display:grid;gap:4px;color:#475569;font-size:.78rem;line-height:1.35;list-style:none}.charge-through-upload-notes li{display:flex;align-items:baseline;justify-content:center;gap:6px}.charge-through-upload-notes li:before{content:"•";color:#0ea5e9;font-weight:900}.charge-through-processing{box-shadow:none}.charge-through-processing-title{margin:0;color:#111827;font-size:1.05rem;font-weight:800}.charge-through-result{display:grid;gap:12px}.charge-through-summary{display:grid;gap:12px;border:1px solid #d8e2ef;border-radius:8px;padding:12px 14px;background:#fff}.charge-through-summary-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.charge-through-summary-header>div{min-width:0}.charge-through-summary-header span,.charge-through-summary-grid span,.charge-through-export-copy span{display:block;color:#64748b;font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.charge-through-summary-header>div>strong{display:block;color:#0f172a;font-size:1.28rem;line-height:1.2;overflow-wrap:anywhere}.charge-through-status-pill{display:inline-flex;align-items:center;min-height:24px;flex:0 0 auto;border-radius:999px;padding:0 9px;font-size:.72rem;font-weight:800}.charge-through-status-pill.is-ok{background:#dcfce7;color:#047857}.charge-through-status-pill.is-warning{background:#fef3c7;color:#92400e}.charge-through-status-pill.is-error{background:#fee2e2;color:#b91c1c}.charge-through-reset-button{flex:0 0 auto;min-width:104px}.charge-through-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px 12px}.charge-through-summary-grid>div{min-width:0}.charge-through-summary-grid strong{display:block;margin-top:3px;color:#111827;font-size:1rem;overflow-wrap:anywhere}.charge-through-validation-list{border-radius:8px;padding:12px}.charge-through-validation-list--error{border:1px solid #fecaca;background:#fef2f2}.charge-through-validation-toggle{appearance:none;width:100%;border:0;background:transparent;color:inherit;display:flex;align-items:center;gap:8px;padding:0;font:inherit;text-align:left;cursor:pointer}.charge-through-validation-toggle span:nth-child(2){font-size:.95rem;font-weight:800}.charge-through-validation-toggle strong{margin-left:auto;border-radius:999px;padding:3px 9px;background:#ffffffbf;color:currentColor;font-size:.72rem;font-weight:800}.charge-through-validation-chevron{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:1.15rem;line-height:1;transition:transform .12s ease}.charge-through-validation-chevron.is-open{transform:rotate(90deg)}.charge-through-validation-list--error .charge-through-validation-toggle{color:#991b1b}.charge-through-validation-list p{margin:6px 0 0}.charge-through-validation-list--error p{color:#7f1d1d}.charge-through-validation-list--warning{border:1px solid #fde68a;background:#fffbeb}.charge-through-validation-list--warning .charge-through-validation-toggle{color:#92400e}.charge-through-validation-list--warning p{color:#78350f}.charge-through-export{display:flex;gap:14px;align-items:center;justify-content:space-between;border:1px solid #d8e2ef;border-radius:8px;padding:12px 14px;background:#f8fafc}.charge-through-export.is-review{border-color:#fed7aa;background:#fff7ed}.charge-through-export-copy{display:grid;gap:2px;min-width:0}.charge-through-export-copy strong{color:#0f172a;font-size:1rem;line-height:1.25}.charge-through-export p{margin:0;max-width:520px;color:#475569;font-size:.82rem;line-height:1.4}.charge-through-export-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto}.charge-through-export .primary-button{flex:0 0 auto;min-width:128px;min-height:38px}.charge-through-export .secondary-button{min-height:38px}@media(max-width:820px){.charge-through-export{grid-template-columns:1fr;align-items:stretch}.charge-through-export{display:grid}.charge-through-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.charge-through-export-actions{justify-content:stretch}.charge-through-export .primary-button,.charge-through-export .secondary-button{flex:1 1 0}}.recent-runs-sidebar{margin-top:18px;padding-top:18px;border-top:1px solid var(--border);display:grid;gap:10px}.recent-runs-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--text);font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.recent-runs-sidebar-header small{color:var(--muted);font-size:.68rem;font-weight:600;letter-spacing:0;text-transform:none}.recent-runs-sidebar-error,.recent-runs-empty{margin:0;color:var(--muted);font-size:.76rem;line-height:1.4}.recent-runs-sidebar-error{color:#b91c1c}.recent-runs-list{display:grid;gap:6px;max-height:min(34vh,320px);overflow-y:auto;padding-right:2px}.recent-run-item{width:100%;min-width:0;padding:9px 10px;border:1px solid transparent;border-radius:8px;background:transparent;color:inherit;display:grid;gap:4px;text-align:left;cursor:pointer}.recent-run-item:hover,.recent-run-item.is-selected{border-color:#0284c738;background:#f8fbff}.recent-run-title,.recent-run-meta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-run-title{color:var(--text);font-size:.78rem;font-weight:700}.recent-run-meta{color:var(--muted);font-size:.7rem}.recent-run-status{width:fit-content;max-width:100%;padding:2px 6px;border-radius:999px;font-size:.68rem;font-weight:700}.recent-run-status.is-ok{background:#ecfdf5;color:#047857}.recent-run-status.is-active{background:#eff6ff;color:#1d4ed8}.recent-run-status.is-error{background:#fef2f2;color:#b91c1c}.recent-run-status.is-neutral{background:#f1f5f9;color:#475569}.recent-run-context-menu{position:fixed;z-index:80;min-width:160px;padding:4px;border:1px solid var(--border);border-radius:8px;background:#fff;box-shadow:0 12px 30px #0f172a29}.recent-run-context-menu button{width:100%;padding:8px 10px;border:0;border-radius:6px;background:transparent;color:#b91c1c;font:inherit;font-size:.78rem;font-weight:800;text-align:left;cursor:pointer}.recent-run-context-menu button:hover{background:#fef2f2}.run-history-page,.run-history-list-page{width:min(900px,100%);margin:0 auto;display:grid;gap:18px}.run-history-page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding-bottom:4px}.run-history-page-header>div:first-child{min-width:0}.run-history-page-header h1,.run-history-page-header p{margin:0}.run-history-page-header h1{margin-top:4px;color:var(--text);font-size:1.45rem;line-height:1.2}.run-history-page-header p:not(.step-num){margin-top:6px;color:var(--muted);font-size:.85rem}.run-history-header-actions{display:flex;flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:8px}.run-history-list{display:grid;gap:10px}.run-history-list-item{width:100%;min-width:0;padding:14px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:inherit;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;text-align:left;cursor:pointer;box-shadow:0 10px 30px #0f172a09;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.run-history-list-item:hover,.run-history-list-item.is-selected{border-color:#0284c747;box-shadow:0 16px 34px #0f172a0f;transform:translateY(-1px)}.run-history-list-main{min-width:0;display:grid;gap:4px}.run-history-list-title,.run-history-list-meta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.run-history-list-title{color:var(--text);font-size:.92rem;font-weight:800}.run-history-list-meta{color:var(--muted);font-size:.78rem}.run-history-list-status{width:fit-content;max-width:100%;padding:4px 8px;border-radius:999px;font-size:.72rem;font-weight:800;white-space:nowrap}.run-history-list-status.is-ok{background:#ecfdf5;color:#047857}.run-history-list-status.is-active{background:#eff6ff;color:#1d4ed8}.run-history-list-status.is-error{background:#fef2f2;color:#b91c1c}.run-history-list-status.is-neutral{background:#f1f5f9;color:#475569}.run-history-steps{width:100%}.run-history-step .step-body{gap:14px}.run-history-stats{gap:18px}.run-history-artifact-row,.run-history-document-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border)}.run-history-artifact-row strong,.run-history-document-row strong,.run-history-document-row span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.run-history-artifact-row strong,.run-history-document-row strong{color:var(--text);font-size:.88rem}.run-history-document-row span{margin-top:3px;color:var(--muted);font-size:.78rem}.run-history-document-list{display:grid}.run-history-row-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;color:var(--muted);font-size:.78rem}.run-history-link{color:#0369a1;font-size:.78rem;font-weight:800;text-decoration:none;white-space:nowrap}.run-history-link:hover{text-decoration:underline;text-underline-offset:.16em}.run-history-send-list{gap:8px}@media(max-width:760px){.run-history-page-header,.run-history-artifact-row,.run-history-document-row{grid-template-columns:1fr}.run-history-page-header{align-items:stretch}.run-history-header-actions,.run-history-row-actions{justify-content:flex-start}.run-history-list-item{grid-template-columns:1fr;align-items:start}}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:var(--bg)}.app-sidebar{width:260px;min-height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 18px 20px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:100}.app-logo{height:auto;width:100%;max-width:160px;display:block;margin-bottom:20px;object-fit:contain}.header-icon{width:14px;height:14px;display:block;flex-shrink:0}.sidebar-action-module{display:flex;flex-direction:column;gap:6px;width:100%;padding:8px;border:1px solid rgba(148,163,184,.28);border-radius:10px;background:#fff;box-shadow:0 10px 28px #0f172a0a}.btn-upload-new,.btn-ct-statement,.btn-recent-runs{display:flex;align-items:center;width:100%;border:0;font:inherit;cursor:pointer;text-align:left;transition:background .14s ease,color .14s ease,box-shadow .14s ease,transform .14s ease}.btn-upload-new{gap:10px;min-height:54px;padding:10px 11px;border-radius:8px;background:linear-gradient(135deg,var(--fc-cyan),#0284c7);box-shadow:0 8px 18px #00aeef38;color:#fff}.btn-upload-new:hover{background:linear-gradient(135deg,#009fe0,#0369a1);box-shadow:0 10px 22px #0284c747;transform:translateY(-1px)}.btn-ct-statement,.btn-recent-runs{gap:9px;min-height:42px;padding:9px 10px;border-radius:8px;font-size:.78rem;font-weight:800;letter-spacing:.01em}.btn-ct-statement{background:#f0fbff;color:#0369a1}.btn-ct-statement:hover:not(:disabled){background:#e6f8ff;color:#075985}.btn-ct-statement:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}.btn-recent-runs{background:#fff;color:var(--text-secondary)}.btn-recent-runs:hover,.btn-recent-runs.is-active{background:#f8fbff;color:#075985}.sidebar-action-icon{width:30px;height:30px;border-radius:8px;flex:0 0 30px;display:flex;align-items:center;justify-content:center;background:#ffffff2e;color:currentColor}.btn-ct-statement .sidebar-action-icon{background:#fff;box-shadow:inset 0 0 0 1px #00aeef47}.btn-recent-runs .sidebar-action-icon{background:#f8fafc;box-shadow:inset 0 0 0 1px #94a3b857;color:#334155}.btn-recent-runs:hover .sidebar-action-icon,.btn-recent-runs.is-active .sidebar-action-icon{color:#075985;box-shadow:inset 0 0 0 1px #0284c733}.sidebar-action-svg{width:18px;height:18px;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sidebar-action-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.sidebar-action-label{min-width:0;color:inherit;font-size:.82rem;font-weight:850;line-height:1.2}.sidebar-action-meta{color:#ffffffd1;font-size:.68rem;font-weight:650;line-height:1.2}.sidebar-action-count{margin-left:auto;min-width:24px;height:22px;padding:0 7px;border-radius:999px;background:#e0f2fe;color:#0369a1;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:850}.sidebar-section-toggle{display:grid;gap:8px;margin-top:18px}.sidebar-section-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--muted);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;text-align:left;transition:border-color .14s ease,background .14s ease,color .14s ease,box-shadow .14s ease}.sidebar-section-btn:hover{border-color:#0284c742;color:var(--text)}.sidebar-section-btn.is-active{border-color:#0284c759;background:linear-gradient(180deg,#00aeef14,#0284c708);box-shadow:0 10px 28px #0284c714;color:var(--text)}.sidebar-section-count{margin-left:auto;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#2563eb1a;color:#1d4ed8;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}.sidebar-nav{display:flex;flex-direction:column;gap:1px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.sidebar-step{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:7px;border:none;background:transparent;font:inherit;text-align:left;width:100%;cursor:pointer;transition:background .12s}.sidebar-step:hover:not(:disabled){background:var(--bg)}.sidebar-step:disabled{opacity:.35;cursor:default}.sidebar-step-badge{width:20px;height:20px;border-radius:50%;background:#f3f4f6;color:#9ca3af;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s}.sidebar-step.is-active .sidebar-step-badge{background:#2563eb;color:#fff}.sidebar-step.is-done .sidebar-step-badge{background:#10b981;color:#fff}.sidebar-step.is-error .sidebar-step-badge{background:#dc2626;color:#fff}.sidebar-step-label{font-size:.8rem;font-weight:500;color:#9ca3af;transition:color .12s}.sidebar-step.is-active .sidebar-step-label,.sidebar-step.is-done .sidebar-step-label,.sidebar-step.is-error .sidebar-step-label{color:var(--text-secondary)}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:1px;padding-top:16px;border-top:1px solid var(--border)}.sidebar-footer-btn{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:7px;border:none;background:transparent;font:inherit;font-size:.8rem;font-weight:500;color:var(--muted);cursor:pointer;width:100%;text-align:left;transition:background .12s,color .12s}.sidebar-footer-btn:hover{background:var(--bg);color:var(--text)}.sidebar-footer-btn:disabled{opacity:.5;cursor:default}.app-body{padding:28px 20px 56px}.steps{width:min(760px,100%);margin:0 auto;display:grid;gap:12px}.step{border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 14px 40px #0f172a0a;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.step.is-active{border-color:#2563eb47;box-shadow:0 0 0 1px #2563eb14,0 18px 44px #2563eb14}.step.is-done{border-color:#d1fae5;box-shadow:0 16px 36px #0596690f}.step.is-error{border-color:#fecaca;box-shadow:0 0 0 1px #ef444414,0 18px 40px #ef444414}.step.is-locked{opacity:.48;pointer-events:none}.step-header{display:flex;align-items:stretch;gap:12px}.step-toggle{flex:1;min-width:0;padding:18px 20px;display:flex;align-items:center;gap:14px;border:0;background:transparent;color:inherit;cursor:pointer;text-align:left;font:inherit;transition:background .15s ease}.step-toggle:hover{background:#0f172a05}.step-toggle:focus-visible{outline:2px solid rgba(37,99,235,.45);outline-offset:-2px}.step-toggle:disabled{cursor:default}.step-hdr-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:18px 20px 18px 0}.step-badge{width:30px;height:30px;border-radius:999px;background:#f3f4f6;color:#4b5563;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s ease,color .15s ease}.step.is-active .step-badge{background:#2563eb;color:#fff}.step.is-done .step-badge{background:#10b981;color:#fff}.step.is-error .step-badge{background:#dc2626;color:#fff}.step-title-block{flex:1;min-width:0}.step-num{margin:0;font-size:.62rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);line-height:1}.step-heading{margin:0;font-size:.92rem;font-weight:700;color:var(--text);line-height:1.3}.step-pill{font-size:.72rem;font-weight:500;padding:3px 8px;border-radius:20px;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.step-pill.is-ok{background:#ecfdf5;color:#065f46}.step-pill.is-choice{background:#eff6ff;color:#1d4ed8;max-width:min(360px,42vw);flex-shrink:1}.step-pill.is-warn{background:#fffbeb;color:#92400e}.step-pill.is-neutral{background:#f1f5f9;color:#475569}.step-pill.is-error{background:#fef2f2;color:#b91c1c}.step-chevron{display:inline-flex;align-items:center;justify-content:center;width:24px;color:var(--muted);font-size:1rem;line-height:1}.step-body{padding:0 20px 20px;display:grid;gap:16px;overflow:visible;opacity:1;max-height:none;transform:translateY(0);transition:max-height .22s ease,opacity .18s ease,transform .22s ease,padding .22s ease}.step-body.is-expanded{max-height:none}.step-body.is-collapsed{padding-top:0;padding-bottom:0;gap:0;opacity:0;max-height:0;overflow:hidden;transform:translateY(-6px)}.card{border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 1px 3px #0000000d}.batch-stats{display:flex;flex-wrap:wrap;gap:24px;padding:10px 0;border-top:1px solid var(--border)}.batch-stats>div{display:flex;flex-direction:column;gap:2px}.dropzone{min-height:180px;display:grid;place-items:center;gap:6px;padding:28px;border:1.5px dashed var(--border);border-radius:8px;background:#fafafa;text-align:center;cursor:pointer;transition:border-color .13s ease,background .13s ease}.dropzone:focus-visible{outline:2px solid var(--fc-cyan);outline-offset:2px}.dropzone.is-active{border-color:var(--fc-cyan);background:#f0faff}.dropzone--locked{cursor:not-allowed;opacity:.55;border-style:dashed;border-color:var(--border);background:var(--surface-2, #f8f9fa);pointer-events:none}.dropzone.is-busy{cursor:progress;border-color:#bfdbfe;background:#f8fbff}.dropzone-title{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.dropzone-copy{font-size:.85rem;color:var(--muted)}.inline-link{color:var(--fc-cyan);text-decoration:underline;text-underline-offset:.15em}.helper-text{margin:0;font-size:.8rem;color:var(--muted)}.access-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(0,174,239,.12),transparent 34%),linear-gradient(180deg,#f6f7f3,#eef2f6 52%,#fbfbf8)}.access-card{width:min(100%,520px);display:grid;gap:18px;padding:1.45rem;border:1px solid rgba(16,32,49,.08);border-radius:2rem;background:#f8fafce0;box-shadow:0 28px 90px #10203124;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.access-card-copy{display:grid;gap:10px}.access-card-title{margin:0;font-family:var(--display-font);font-size:clamp(2.85rem,5.2vw,4.9rem);font-weight:700;line-height:.96;letter-spacing:-.06em;color:#102031}.access-card-subtitle,.access-card-body{margin:0;color:var(--text-secondary)}.access-card-subtitle{font-size:1.02rem;line-height:1.72;color:#102031b8}.access-card-body{font-size:.94rem;line-height:1.65}.access-card-button{width:fit-content}.access-code-form{display:grid;gap:.95rem}.action-row{display:flex;flex-wrap:wrap;gap:10px}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:8px;border:1px solid transparent;font:inherit;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .12s ease,border-color .12s ease,color .12s ease}.primary-button{background:var(--accent);color:#fff}.primary-button:hover:not(:disabled){background:var(--accent-dark)}.secondary-button{background:#fff;color:var(--text-secondary);border-color:var(--border)}.secondary-button:hover:not(:disabled){background:#f9fafb}.primary-button:disabled,.secondary-button:disabled{opacity:.55;cursor:not-allowed}.summary-grid,.integration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.summary-grid div,.integration-grid div{padding:12px 14px;display:grid;gap:4px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.summary-grid div.has-issue,.integration-grid div.has-issue{border-color:#fecaca;background:#fef2f2}.summary-label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.summary-grid strong,.integration-grid strong{font-size:1.2rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.tenant-picker{display:grid;gap:6px}.tenant-picker select{min-height:40px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font:inherit;color:var(--text-secondary);background:#fff}.meta-block{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.meta-block p{margin:0;font-size:.85rem;color:var(--text-secondary)}.meta-block p+p{margin-top:5px}.summary-note-card{padding:16px;display:grid;gap:12px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.processing-card{padding:24px 28px;display:grid;gap:16px}.processing-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.processing-percentage{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.progress-track{height:12px;overflow:hidden;border-radius:999px;background:#e5eef7}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#0ea5e9,#0284c7);transition:width .22s ease}.processing-card.is-indeterminate .progress-fill{background:linear-gradient(90deg,#0ea5e9,#0284c7 52%,#38bdf8,#0284c7);background-size:180px 100%;animation:progress-bar-active 1.1s linear infinite}@keyframes progress-bar-active{0%{background-position:0 0}to{background-position:180px 0}}.processing-meta{display:grid;gap:6px}.verification-summary-card{border-color:#c7e6ff;background:#f4faff}.summary-note-header{display:grid;gap:3px}.summary-note-header h3{margin:0;font-size:.875rem;font-weight:700;color:var(--text)}.summary-note-header p{margin:0;font-size:.8rem;color:var(--muted)}.summary-note-list{display:grid;gap:6px}.summary-note-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:7px;background:var(--surface)}.summary-note-item.is-issue{border-color:#fecaca;background:#fef2f2}.summary-note-number{margin:0 0 2px;font-size:.72rem;font-weight:600;color:var(--fc-cyan);letter-spacing:.02em}.summary-note-title{margin:0;font-size:.875rem;font-weight:600;color:var(--text)}.summary-note-amount{margin:0;font-size:.875rem;font-weight:700;color:var(--text-secondary);white-space:nowrap}.issues-card{border-color:#fecaca;background:#fff7f7}.info-card{border-color:#bfdbfe;background:#f4faff}.issue-pill-list,.issue-tag-list{display:flex;flex-wrap:wrap;gap:6px}.issue-pill,.issue-tag{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;font-size:.73rem;font-weight:600;letter-spacing:.01em;border:1px solid #fecaca;background:#fef2f2;color:#991b1b}.issue-pill.is-info,.issue-tag.is-info{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.invoice-list-toolbar{display:flex;justify-content:flex-end}.invoice-list-toggle-all{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-list-toggle-all:hover{color:var(--text)}.invoice-list{display:grid;gap:7px}.invoice-row{padding:8px 10px;display:grid;gap:6px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.invoice-row.has-supplier-mismatch,.invoice-row.has-unresolved-fields,.invoice-row.has-review{border-color:#fde68a;background:#fffbeb}.invoice-row.has-issue{border-color:#fca5a5;background:#fff8f8}.invoice-main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;cursor:pointer}.invoice-row-content{min-width:0;display:grid;gap:2px}.invoice-row-actions{display:inline-flex;align-items:center;gap:5px;flex-shrink:0}.invoice-row .invoice-number{margin:0;font-size:.66rem!important;font-weight:600;color:var(--fc-cyan);letter-spacing:.03em;line-height:1.1}.invoice-row .invoice-number--credit-note{display:flex;align-items:baseline;gap:5px;flex-wrap:wrap}.invoice-row .invoice-number-type{color:#7c3aed;font-size:.9em;font-weight:600;letter-spacing:.01em}.invoice-row .invoice-number-value{color:inherit}.invoice-row .invoice-supplier{margin:0;font-size:.92rem!important;font-weight:600;color:var(--text);line-height:1.12}.invoice-row .invoice-row-meta{margin:0;font-size:.68rem!important;color:var(--muted);line-height:1.12}.invoice-row-status{min-height:20px;padding:0 7px;font-size:.62rem}.invoice-preview-trigger{min-height:27px;padding:0 10px;border-radius:10px;font-size:.7rem}.invoice-row-expander{color:var(--muted);font-size:.62rem;-webkit-user-select:none;user-select:none}.status-badge{display:inline-flex;align-items:center;min-height:21px;padding:0 7px;border-radius:999px;font-size:.65rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.status-ready{background:#e6f9ef;color:#166534}.status-individual{background:#e0f2fe;color:#0369a1}.status-review{background:#fffbeb;color:#92400e}.status-blocked,.status-missing,.status-missing_source_page{background:#fef2f2;color:#991b1b}.status-badge--credit-note{background:#ddd6fe;color:#5b21b6;border:1px solid #8b5cf6;font-weight:700}.invoice-meta{margin:0;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.invoice-meta dt{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.invoice-meta dd{margin:4px 0 0;font-size:.875rem;color:var(--text-secondary)}.amount-primary{font-weight:600}.amount-strong{font-weight:700}.validation-note{margin:0;font-size:.8rem;font-weight:600;color:#991b1b}.invoice-actions{display:flex;flex-wrap:wrap;gap:10px}.verification-banner{padding:12px 14px;border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:12px}.verification-banner.is-pass{background:#edfdf4;border:1px solid #bbf7d0}.verification-banner.is-fail{background:#fff7f7;border:1px solid #fecaca}.verification-banner p{margin:0;font-size:.85rem;color:var(--text-secondary)}.invoice-details{display:grid;gap:14px;padding:16px;border:1px solid var(--border);border-radius:8px;background:#fcfcfd}.invoice-action-bar{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--border)}.invoice-collapse-trigger{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-collapse-trigger:hover{color:var(--text)}.invoice-collapse-trigger:not(:last-child):after{content:"·";margin-left:8px;color:var(--border)}.invoice-remove-trigger{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-remove-trigger:hover{color:#dc2626}.invoice-remove-prompt{font-size:.78rem;font-weight:600;color:var(--text)}.invoice-remove-confirm{appearance:none;border:1px solid #dc2626;border-radius:6px;background:#dc2626;color:#fff;padding:4px 12px;font:inherit;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .12s ease}.invoice-remove-confirm:hover{background:#b91c1c}.verification-columns{display:block}.verification-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.verification-card{padding:14px;border:1px solid var(--border);border-radius:8px;background:#fff}.verification-card h4{margin:0 0 10px;font-size:.85rem;color:var(--text)}.verification-card-heading h4{margin-bottom:0}.verification-detail-pair{display:contents}.verification-detail-cell{min-height:78px}.supplier-pick-cell{appearance:none;border:none;font:inherit;color:inherit;text-align:left;cursor:pointer;position:relative;transition:box-shadow .12s ease,border-color .12s ease}.supplier-pick-cell:hover{box-shadow:0 0 0 2px #22c55e59}.supplier-pick-cell:focus-visible{outline:2px solid #22c55e;outline-offset:2px}.supplier-pick-cell--selected{background:#f0fdf4!important;border:2px solid #22c55e!important}.supplier-pick-cell--unselected{background:#f9fafb!important;border-color:#e5e7eb!important;opacity:.65}.supplier-pick-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.supplier-pick-badge{display:inline-flex;align-items:center;padding:1px 7px;border-radius:999px;background:#16a34a;color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.supplier-pick-hint{font-size:.65rem;font-weight:600;color:#b45309;opacity:.7;white-space:nowrap;text-transform:none;letter-spacing:0}.supplier-pick-cell:hover .supplier-pick-hint{opacity:1}.supplier-xero-card{grid-column:1 / -1}.supplier-xero-card.is-loading{background:#f8fafc;border-color:#cbd5e1}.supplier-xero-card.is-found{background:#f0fdf4;border-color:#bbf7d0}.supplier-xero-card.is-mapped{background:#ecfdf5;border-color:#86efac}.supplier-xero-card.is-warning{background:#fffbeb;border-color:#fde68a}.supplier-xero-card.is-error{background:#fef2f2;border-color:#fecaca}.supplier-xero-row{display:block}.supplier-xero-info{display:grid;gap:10px;min-width:0}.supplier-xero-contact-row{display:flex;align-items:flex-start;justify-content:flex-start;gap:12px;flex-wrap:wrap}.supplier-xero-contact-copy{display:grid;gap:4px;min-width:0}.supplier-xero-contact-actions{margin-left:auto;display:flex;align-items:flex-start}.supplier-xero-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.supplier-xero-value{font-size:.92rem;font-weight:700;line-height:1.4;color:var(--text)}.supplier-xero-note{margin:0;font-size:.74rem;line-height:1.45;color:#7c2d12}.supplier-name-editor{display:grid;gap:6px}.supplier-name-editor__label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.supplier-name-editor__controls{display:flex;align-items:stretch;gap:8px;flex-wrap:wrap}.supplier-name-editor__input{flex:1 1 220px;min-width:0;min-height:34px;border:1px solid #c7d2e4;border-radius:8px;background:#fff;color:var(--text);font:inherit;font-size:.88rem;padding:6px 10px;box-sizing:border-box}.supplier-name-editor__input:focus{outline:2px solid rgba(37,99,235,.22);border-color:#93b4eb}.supplier-contact-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.supplier-xero-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.supplier-xero-action{appearance:none;min-height:34px;padding:0 14px;border:1px solid #d7dee8;border-radius:999px;background:#fff;color:#0f172a;font:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:border-color .12s ease,background-color .12s ease,color .12s ease}.supplier-xero-action:hover{background:#f8fafc;border-color:#b8c4d6;color:#111827}.supplier-xero-action.is-selected{border-color:#0f766e;background:#ecfeff;color:#115e59}.supplier-contact-option{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:var(--text);font-size:.78rem;font-weight:600;line-height:1;padding:8px 12px;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.supplier-contact-option:hover{border-color:#60a5fa;color:#1d4ed8}.supplier-contact-option.is-selected{border-color:#15803d;background:#dcfce7;color:#166534}.supplier-department-editor{display:grid;gap:12px;margin-top:2px}.supplier-department-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.supplier-department-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.supplier-department-row{display:block}.supplier-department-input{width:100%;min-width:0;border:1px solid #c7d2e4;border-radius:12px;background:#fff;color:var(--text);font:inherit;font-size:.92rem;padding:12px 14px;box-sizing:border-box}.supplier-department-input:focus{outline:2px solid rgba(37,99,235,.12);border-color:#60a5fa}.supplier-department-note{margin:0;font-size:.78rem;color:var(--muted)}.supplier-department-refresh{appearance:none;border:none;background:none;padding:0;color:#2563eb;font:inherit;font-weight:600;cursor:pointer}.supplier-department-refresh:hover:not(:disabled){text-decoration:underline}.supplier-department-refresh:disabled{color:#94a3b8;cursor:default}.supplier-department-create{display:grid;gap:10px;margin-top:10px}.supplier-department-create-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.supplier-department-error{margin:0;font-size:.8rem;color:#b91c1c}.supplier-xero-status{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:.72rem;font-weight:700;white-space:nowrap}.supplier-xero-status--loading{background:#e2e8f0;color:#475569}.supplier-xero-status--found{background:#bbf7d0;color:#166534}.supplier-xero-status--mapped{background:#86efac;color:#14532d}.supplier-xero-status--warning{background:#fde68a;color:#92400e}.supplier-xero-status--error{background:#fecaca;color:#991b1b}.detail-cell-pass{background:#f0fdf4;border-color:#bbf7d0}.detail-cell-warn{background:#fffbeb;border-color:#fde68a}.detail-cell-fail{background:#fef2f2;border-color:#fecaca}.detail-cell-unselected{background:#f9fafb;border-color:#e5e7eb;opacity:.65}.detail-list{margin:0;display:grid;gap:10px}.detail-list div{display:grid;gap:2px}.detail-list dt{font-size:.68rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.detail-list dd{margin:0;font-size:.875rem;color:var(--text-secondary)}.detail-note{margin:4px 0 0;font-size:.72rem;color:#166534}.document-type-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.document-type-action{appearance:none;border:1px solid #d7dee8;border-radius:999px;background:#fff;color:#334155;font:inherit;font-size:.72rem;font-weight:700;line-height:1;padding:7px 10px;cursor:pointer;transition:border-color .12s ease,background-color .12s ease,color .12s ease}.document-type-action:hover{border-color:#94a3b8;background:#f8fafc}.document-type-action.is-active{border-color:#16a34a;background:#f0fdf4;color:#166534}.comparison-list{display:grid;gap:8px}.comparison-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:8px}.comparison-item.is-pass{background:#edfdf4;border:1px solid #bbf7d0}.comparison-item.is-fail{background:#fff7f7;border:1px solid #fecaca}.comparison-item p{margin:4px 0 0;font-size:.8rem;color:var(--text-secondary)}.comparison-label{display:block;font-size:.72rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.05em}.detail-alert,.detail-success{margin:0;padding:12px 14px;border-radius:8px;font-size:.82rem}.detail-alert{border:1px solid #fecaca;background:#fff7f7;color:#991b1b}.detail-alert.is-success,.detail-success{border:1px solid #bbf7d0;background:#edfdf4;color:#166534}.detail-alert p,.detail-success{margin:0}.detail-alert p+p{margin-top:6px}.gst-check-bar{margin-top:2px}.gst-check-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;flex-wrap:wrap}.gst-check-alert p{margin:0;font-size:.8rem;color:#991b1b}.gst-check-acknowledged{margin:0;padding:10px 14px;border:1px solid #bbf7d0;border-radius:8px;background:#f0fdf4;font-size:.8rem;color:#166534}.gst-check-undo{appearance:none;border:none;background:none;padding:0;margin-left:8px;font:inherit;font-size:.75rem;font-weight:600;color:#166534;text-decoration:underline;cursor:pointer}.wrong-store-bar{margin-top:2px}.wrong-store-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;flex-wrap:wrap}.wrong-store-alert p{margin:0;font-size:.8rem;color:#991b1b}.wrong-store-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.raw-response-panel{display:grid;gap:10px}.usage-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.usage-card div{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;display:grid;gap:4px}.usage-card strong{font-size:1rem;color:var(--text)}.prompt-card{display:grid;gap:8px}.prompt-pre{margin:0;padding:14px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text-secondary);font-size:.78rem;line-height:1.5;white-space:pre-wrap}.raw-response-pre{margin:0;padding:14px;border:1px solid var(--border);border-radius:8px;background:#0f172a;color:#e2e8f0;font-size:.75rem;line-height:1.5;overflow:auto;max-height:360px}.invoice-preview-modal{position:fixed;inset:0;z-index:220;display:grid;padding:24px;background:#0f172a80;overflow-y:auto}.invoice-preview-dialog{width:min(1180px,100%);height:min(92vh,940px);margin:auto;min-height:0;display:grid;grid-template-rows:auto 1fr;gap:16px;padding:18px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 18px 50px #0f172a2e}.invoice-preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.invoice-preview-heading{display:grid;gap:6px}.invoice-preview-eyebrow{margin:0;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fc-cyan)}.invoice-preview-heading h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.invoice-preview-copy{margin:0;font-size:.82rem;color:var(--muted)}.invoice-preview-frame-shell{min-height:0;overflow:hidden;border:1px solid var(--border);border-radius:10px;background:#dbe3ec}.invoice-preview-placeholder{min-height:65vh;height:100%;display:grid;place-items:center;padding:24px;text-align:center;background:radial-gradient(circle at top right,rgba(0,174,239,.12),transparent 38%),linear-gradient(180deg,#fff,#f8fbff)}.invoice-preview-placeholder-error{align-content:center;gap:10px}.invoice-preview-placeholder-title{margin:0;display:inline-flex;align-items:center;gap:6px;font-size:.95rem;font-weight:600;color:var(--text)}.invoice-preview-placeholder-dots{color:var(--fc-cyan)}.invoice-preview-frame{width:100%;height:100%;min-height:65vh;border:0;background:#fff}@media(max-width:900px){.invoice-main{grid-template-columns:1fr;align-items:flex-start}.invoice-row-actions{flex-wrap:wrap}}.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}@media(max-width:760px){.app-body{padding:16px 16px 40px}.step-header{flex-direction:column;gap:0}.step-hdr-actions{width:100%;justify-content:flex-start;padding:0 20px 18px}.upload-card,.preview-card,.integration-card,.processing-card{padding:16px}.dropzone{min-height:140px;padding:20px}.summary-grid,.integration-grid,.invoice-meta,.verification-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.invoice-main,.verification-banner,.comparison-item,.summary-note-item,.invoice-preview-header,.processing-header{flex-direction:column;align-items:flex-start}.invoice-preview-modal{padding:12px}.invoice-preview-dialog{width:100%;height:calc(100vh - 24px);padding:14px}.invoice-preview-frame{min-height:58vh}.notice{width:calc(100vw - 32px)}}@media(max-width:720px){.verification-detail-grid{grid-template-columns:1fr}.verification-detail-pair{display:block}.supplier-xero-contact-row{flex-direction:column;align-items:stretch}.supplier-xero-contact-actions{margin-left:0}.supplier-department-grid{grid-template-columns:1fr}}.individual-form{display:grid;gap:12px}.individual-field{display:grid;gap:5px}.individual-field-label{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;color:var(--text-muted, #6b7280);letter-spacing:.04em;text-transform:uppercase}.individual-field-badge{font-size:.65rem;font-weight:600;color:#b45309;background:#fef3c7;border-radius:4px;padding:1px 6px;letter-spacing:0;text-transform:none}.individual-field-input{width:100%;font-size:.9rem;font-family:inherit;padding:9px 12px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text, #111);outline:none;transition:border-color .15s;box-sizing:border-box}.individual-field--missing .individual-field-input{border-color:#fbbf24;background:#fffbeb}.individual-field-input:focus{border-color:var(--fc-cyan, #00aeef);box-shadow:0 0 0 3px #00aeef1f}.individual-field-note{margin:2px 0 0;font-size:.74rem;color:#166534}.individual-send-btn{margin-top:4px;width:100%;justify-content:center}.individual-dept-warning{font-size:.8rem;font-weight:500;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:7px 10px;margin-bottom:2px}.individual-send-result{font-size:.85rem;font-weight:500;padding:10px 14px;border-radius:7px;margin:0}.individual-send-result.is-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.individual-send-result.is-warn{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.individual-send-result.is-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.individual-dev-panel{margin-top:16px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.individual-dev-summary{cursor:pointer;padding:10px 14px;font-size:.72rem;font-weight:600;color:#6b7280;background:#f9fafb;-webkit-user-select:none;user-select:none;list-style:none}.individual-dev-summary::-webkit-details-marker{display:none}.individual-dev-panel[open] .individual-dev-summary{border-bottom:1px solid #e5e7eb}.individual-dev-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px;background:#fff}.individual-dev-label{font-size:.65rem;font-weight:700;letter-spacing:.05em;color:#9ca3af;margin:0 0 4px}.individual-dev-pre{font-family:SF Mono,Fira Code,monospace;font-size:.72rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px;margin:0;color:#111827}.individual-dev-meta{font-size:.68rem;color:#9ca3af;margin:0}.mapping-modal-backdrop{position:fixed;inset:0;z-index:230;display:grid;padding:24px;background:#0f172a80;overflow-y:auto}.mapping-modal-dialog{width:min(540px,100%);max-height:min(80vh,680px);margin:auto;display:flex;flex-direction:column;gap:14px;padding:20px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 18px 50px #0f172a2e;overflow:hidden}.mapping-modal-dialog--settings{width:min(760px,100%);height:min(720px,calc(100vh - 48px));max-height:none}.mapping-modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.mapping-modal-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--text)}.mapping-modal-sub{margin:8px 0 0;font-size:.84rem;line-height:1.5;color:var(--muted);max-width:40rem}.mapping-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;border-radius:6px;color:var(--muted);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}.mapping-modal-close:hover{background:var(--bg);color:var(--text)}.settings-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-top:12px;padding-bottom:0}.settings-tab-btn{appearance:none;border:none;background:none;padding:8px 14px;font:inherit;font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0;transition:color .12s,border-color .12s}.settings-tab-btn:disabled{color:#9ca3af;cursor:not-allowed}.settings-tab-btn.is-active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.settings-tab-btn:hover:not(.is-active):not(:disabled){color:var(--text)}.settings-inline-note{margin:0;padding:0 2px;font-size:.82rem;line-height:1.55;color:var(--muted)}.store-settings-form{padding:20px;display:flex;flex-direction:column;gap:18px}.store-settings-desc{margin:0;font-size:.83rem;color:var(--muted);line-height:1.5}.store-settings-field{display:flex;flex-direction:column;gap:6px}.store-settings-label{font-size:.83rem;font-weight:600;color:var(--text)}.store-settings-input{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font:inherit;font-size:.88rem;color:var(--text);background:var(--surface);outline:none;transition:border-color .12s}.store-settings-input:focus{border-color:var(--accent)}.store-settings-actions{display:flex;align-items:center;gap:12px}.store-settings-saved{font-size:.83rem;color:#166534;font-weight:500}.single-invoice-dev-panel{display:grid;gap:14px}.single-invoice-dev-toolbar{display:flex;flex-wrap:wrap;gap:10px}.single-invoice-dev-meta{margin:-4px 0 0;font-size:.78rem;color:var(--muted)}.single-invoice-dev-dropzone{min-height:160px}.dev-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.dev-result-card{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;display:grid;gap:4px}.dev-result-card strong{font-size:.98rem;color:var(--text)}.mapping-search{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:var(--surface);color:var(--text);outline:none;box-sizing:border-box}.mapping-search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.mapping-contact-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;min-height:0}.mapping-contact-item{text-align:left;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text);font-size:.88rem;cursor:pointer;transition:background .1s,border-color .1s}.mapping-contact-item:hover{background:#f0f4ff;border-color:#2563eb;color:#1d4ed8}.mapping-contact-item.is-selected{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.mapping-loading,.mapping-empty{font-size:.85rem;color:var(--muted);text-align:center;padding:24px 0;margin:0}.mapping-settings-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px}.department-settings-create{padding:0 10px 10px;display:grid;gap:10px}.department-settings-create-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.department-settings-create-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.department-settings-error{margin:0;padding:0 10px 10px}.department-settings-item.is-confirming{flex-wrap:wrap;align-items:flex-start}.department-settings-confirm{width:100%;border-top:1px solid var(--border);padding-top:10px;display:grid;gap:8px}.department-settings-warning{margin:0;font-size:.8rem;font-weight:600;color:#991b1b}.department-settings-confirm-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.mapping-modal-content{flex:1;display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto}.mapping-settings-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.15fr);gap:16px;min-height:0;overflow:hidden}.mapping-settings-panel{min-height:0;border:1px solid var(--border);border-radius:12px;background:#fafafa;display:flex;flex-direction:column;overflow:hidden}.mapping-settings-editor-shell{border:1px solid var(--border);border-radius:12px;background:#fff;display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 12px 30px #0f172a0f}.mapping-settings-editor-shell .mapping-settings-panel-header{border-bottom-color:#2563eb1f;background:linear-gradient(180deg,#f8fbff,#f3f8ff)}.mapping-settings-panel--editor{background:var(--surface)}.mapping-settings-panel-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.mapping-settings-panel-header h4{margin:0;font-size:.88rem;font-weight:600;color:var(--text)}.mapping-count{font-size:.78rem;font-weight:600;color:var(--muted);background:var(--bg);padding:2px 8px;border-radius:20px}.mapping-settings-search-wrap{padding:10px 10px 0}.mapping-settings-list{min-height:0;max-height:340px;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.mapping-settings-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.mapping-settings-item.is-active{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.mapping-settings-item-copy{min-width:0}.mapping-settings-supplier,.mapping-settings-contact{margin:0}.mapping-settings-supplier{font-size:.88rem;font-weight:700;color:var(--text)}.mapping-settings-contact{margin-top:4px;font-size:.78rem;color:var(--muted);overflow-wrap:anywhere}.mapping-settings-item-actions{flex-shrink:0}.mapping-editor{min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.mapping-editor-fields{flex:1;min-height:0;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.mapping-field{display:flex;flex-direction:column;gap:6px}.mapping-field-label{font-size:.8rem;font-weight:600;color:var(--text)}.mapping-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:var(--surface);color:var(--text);outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.mapping-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.mapping-input:disabled{background:#f8fafc;color:var(--muted);cursor:not-allowed}.mapping-field-hint{margin:0;font-size:.76rem;color:var(--muted)}.contact-selected-list{display:flex;flex-wrap:wrap;gap:8px}.contact-selected-chip{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1.5px solid #86efac;border-radius:8px;background:#f0fdf4}.contact-selected-name{flex:1;font-size:.88rem;font-weight:500;color:#15803d;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-selected-clear{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#bbf7d0;color:#166534;font-size:1rem;line-height:1;cursor:pointer;padding:0;transition:background .1s}.contact-selected-clear:hover{background:#86efac}.contact-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;background:#fafafa;padding:4px}.contact-list-item{display:block;width:100%;text-align:left;padding:8px 10px;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:.86rem;cursor:pointer;transition:background .1s}.contact-list-item:hover{background:#eff6ff;color:#1d4ed8}.contact-list-message{margin:0;padding:16px 10px;font-size:.84rem;color:var(--muted);text-align:center}.copy-from-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.copy-from-supplier{font-size:.86rem;font-weight:500;color:var(--text)}.copy-from-contacts{font-size:.76rem;color:var(--muted)}.contact-list-more{margin:2px 0 0;padding:6px 10px;font-size:.75rem;color:var(--muted);text-align:center;border-top:1px solid var(--border)}.mapping-contact-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.mapping-form-error{margin:0;font-size:.82rem;color:#b91c1c}.mapping-editor-actions{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface)}.mapping-editor-footer-note{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.78rem;color:var(--muted)}.mapping-inline-refresh{appearance:none;border:none;background:none;padding:0;color:#2563eb;font:inherit;font-weight:600;cursor:pointer}.mapping-inline-refresh:hover:not(:disabled){text-decoration:underline}.mapping-inline-refresh:disabled{color:#94a3b8;cursor:default}.mapping-inline-create{display:grid;gap:10px;width:100%}.mapping-inline-create-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.mapping-editor-action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.secondary-button--danger{color:#b91c1c;border-color:#fecaca;background:#fff}.secondary-button--danger:hover{color:#991b1b;border-color:#fca5a5;background:#fef2f2}@media(max-width:900px){.mapping-settings-layout{grid-template-columns:1fr;overflow:visible}.mapping-contact-list--editor{max-height:180px}}@media(max-width:640px){.mapping-settings-toolbar{flex-direction:column;align-items:stretch}.department-settings-create-grid{grid-template-columns:1fr}.mapping-settings-item{flex-direction:column;align-items:flex-start}.mapping-settings-item-actions,.mapping-settings-item-actions .secondary-button{width:100%}.mapping-editor-actions{flex-direction:column;align-items:stretch}}.xero-send-progress{display:flex;flex-direction:column;gap:8px}.xero-send-progress__label{margin:0;font-size:.8rem;color:var(--muted)}.xero-send-progress__track{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.xero-send-progress__fill{height:100%;background:var(--fc-cyan);border-radius:99px;transition:width .35s ease}.send-result-summary{font-size:.85rem;font-weight:600;color:var(--text);margin:0 0 12px}.send-result-list{display:flex;flex-direction:column;gap:6px}.send-result-blocked-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.send-result-blocked-item{border:1px solid #fecaca;border-radius:8px;padding:10px 12px;background:#fff7ed}.send-result-blocked-heading{margin:0;font-size:.82rem;font-weight:700;color:#7c2d12}.send-result-blocked-message{margin:4px 0 0;font-size:.8rem;color:#9a3412}.send-result-row{border:1px solid var(--border);border-radius:8px;padding:10px 14px;background:var(--surface)}.send-result-row.is-created{border-color:#a7f3d0;background:#f0fdf9}.send-result-row.is-error{border-color:#fca5a5;background:#fef2f2}.send-result-row.is-skipped{border-color:var(--border);background:#f9fafb;opacity:.8}.send-result-row.is-pending{border-color:#cbd5e1;background:#f8fafc}.send-result-row.is-processing{border-color:#7dd3fc;background:#f0f9ff}.send-result-row-main{display:flex;align-items:center;gap:10px}.send-result-status-icon{font-size:.85rem;font-weight:700;width:18px;flex-shrink:0}.send-result-row.is-created .send-result-status-icon{color:#059669}.send-result-row.is-error .send-result-status-icon{color:#dc2626}.send-result-row.is-skipped .send-result-status-icon{color:#9ca3af}.send-result-row.is-pending .send-result-status-icon{color:#64748b}.send-result-row.is-processing .send-result-status-icon{width:28px;color:#0284c7}.animated-dots{display:inline-flex;align-items:center;gap:3px}.animated-dots__dot{width:4px;height:4px;border-radius:999px;background:currentColor;opacity:.28;animation:send-result-dot-pulse 1s ease-in-out infinite}.animated-dots__dot:nth-child(2){animation-delay:.16s}.animated-dots__dot:nth-child(3){animation-delay:.32s}@keyframes send-result-dot-pulse{0%,80%,to{opacity:.28;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}.send-result-row-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.send-result-row-heading{display:flex;align-items:center;gap:8px;min-width:0}.send-result-invoice-num{font-size:.8rem;font-weight:700;color:var(--fc-cyan, #0ea5e9)}.send-result-type-badge{min-height:18px;padding:0 6px;font-size:.64rem;letter-spacing:.04em}.send-result-supplier{font-size:.82rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.send-result-contact{font-size:.77rem;color:#475569}.send-result-row-right{flex-shrink:0;display:flex;align-items:center;gap:6px;font-size:.74rem}.send-result-xero-link{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border:1px solid #bfdbfe;border-radius:999px;background:#fff;color:#2563eb;font-weight:700;text-decoration:none}.send-result-xero-link:hover{border-color:#93c5fd;background:#eff6ff}.send-result-label-skipped{color:#9ca3af}.send-result-label-success{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#dcfce7;color:#065f46;font-weight:700}.send-result-label-pending{color:#475569;font-weight:500}.send-result-label-processing{display:inline-flex;align-items:center;gap:6px;color:#0369a1;font-weight:600}.send-result-label-dots{color:inherit}.send-result-label-error{color:#dc2626;font-weight:500}.send-result-dept-warn{margin:6px 0 0 28px;font-size:.72rem;line-height:1.35;color:#92400e}.send-result-summary-note{margin:6px 0 0 28px;font-size:.72rem;line-height:1.35;color:#475569}.send-result-notes{margin:6px 0 0 28px;padding:0;display:grid;gap:2px;list-style:none;font-size:.72rem;line-height:1.35;color:#64748b}.send-result-note{position:relative;padding-left:11px;min-width:0;overflow-wrap:anywhere}.send-result-note:before{content:"•";position:absolute;left:0;color:currentColor}.send-result-note.is-warning{color:#9a3412}@media(max-width:760px){.app-shell{grid-template-columns:1fr}.app-sidebar{position:static;width:100%;min-height:auto;height:auto;border-right:0;border-bottom:1px solid var(--border)}.sidebar-nav,.sidebar-section-toggle{margin-top:14px;padding-top:14px}.primary-button,.secondary-button{min-height:44px;padding-top:10px;padding-bottom:10px}.step-toggle{min-height:56px}.btn-upload-new{padding:11px 18px}.btn-ct-statement{min-height:44px}.dropzone{min-height:160px;padding:28px 20px;border-width:2px}.mapping-modal-backdrop{padding:0;align-items:flex-end}.mapping-modal-dialog{width:100%;max-height:92vh;border-radius:16px 16px 0 0;margin:0}.mapping-modal-dialog--settings{width:100%;height:96vh;max-height:96vh;border-radius:16px 16px 0 0;margin:0}.invoice-preview-modal{padding:0;align-items:flex-end}.invoice-preview-dialog{width:100%;height:96vh;border-radius:16px 16px 0 0;margin:0;padding:14px}.invoice-meta{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:420px){.invoice-meta{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.app-body{padding:12px 12px 40px}}
