@import"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=DM+Sans:wght@400;500;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:inherit;text-decoration:inherit}body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box}.authgate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.authgate__card{width:100%;max-width:380px;background:#fff;border:1px solid #e5e9f1;border-radius:16px;padding:32px 28px;text-align:center;box-shadow:0 24px 60px #0f172a40}.authgate__brand{font-weight:700;font-size:18px;letter-spacing:-.01em;color:#2563eb;margin-bottom:18px}.authgate__title{margin:0 0 8px;font-size:20px;font-weight:700;color:#0f172a}.authgate__sub{margin:0 0 22px;font-size:14px;line-height:1.5;color:#64748b}.authgate__google{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;font-size:14px;font-weight:600;color:#1f2937;background:#fff;border:1px solid #d6dbe6;border-radius:10px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.authgate__google:hover:not(:disabled){background:#f8fafc;border-color:#c2c9d6}.authgate__google:disabled{opacity:.65;cursor:default}.authgate__error{margin:14px 0 0;font-size:13px;color:#dc2626}.authgate__legal{margin:18px 0 0;font-size:11px;line-height:1.5;color:#94a3b8}.authgate--loading{background:#f8fafc;-webkit-backdrop-filter:none;backdrop-filter:none}.authgate__spinner{width:36px;height:36px;border:3px solid #dbe2ef;border-top-color:#2563eb;border-radius:50%;animation:authgate-spin .8s linear infinite}@keyframes authgate-spin{to{transform:rotate(360deg)}}:root{--ink: #0a0f1e;--ink-2: #3d4a63;--ink-3: #8896b0;--canvas: #f8faff;--surface: #ffffff;--blue: #2355f4;--blue-dark: #1740d0;--blue-glow: rgba(35, 85, 244, .18);--blue-soft: rgba(35, 85, 244, .08);--gold: #f5a623;--border: rgba(15, 23, 64, .09);--radius-sm: 12px;--radius-md: 20px;--radius-lg: 32px;--shadow-sm: 0 2px 8px rgba(10,15,30,.06);--shadow-md: 0 8px 32px rgba(10,15,30,.1);--shadow-lg: 0 24px 64px rgba(10,15,30,.13);--font-display: "Instrument Serif", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--max-w: 1120px;--gutter: clamp(1rem, 4vw, 3rem)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-body);background:var(--canvas);color:var(--ink);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none;font-weight:500}button,a{-webkit-tap-highlight-color:transparent}p,h1,h2,h3{margin:0}.lp{overflow-x:hidden}.wrap{width:min(var(--max-w),100% - var(--gutter) * 2);margin-inline:auto}.topbar{position:sticky;top:0;z-index:100;background:#f8faffd1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.topbar__inner{width:min(var(--max-w),100% - var(--gutter) * 2);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}.brand{font-family:var(--font-display);font-size:1.35rem;font-style:italic;letter-spacing:-.01em;color:var(--ink)}.topbar__nav{display:flex;align-items:center;gap:.25rem}.topbar__link{padding:.45rem .85rem;border-radius:999px;font-size:.9rem;font-weight:500;color:var(--ink-2);transition:color .15s,background .15s}.topbar__link:hover{background:var(--blue-soft);color:var(--blue)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:.7rem 1.35rem;border:none;border-radius:999px;font-family:var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn--primary{background:var(--blue);color:#fff;box-shadow:0 4px 20px var(--blue-glow)}.btn--primary:hover{background:var(--blue-dark);color:#fff;box-shadow:0 8px 28px var(--blue-glow)}.btn--ghost{background:transparent;color:var(--ink-2);border:1.5px solid var(--border)}.btn--ghost:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}.btn--sm{min-height:36px;padding:.45rem 1rem;font-size:.875rem}.btn--lg{min-height:52px;padding:.85rem 1.75rem;font-size:1rem}.eyebrow{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;background:var(--blue-soft);color:var(--blue);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.eyebrow--light{background:#ffffff1f;color:#ffffffe6}.hero{padding:5rem 0 4rem;position:relative}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 60% -10%,rgba(35,85,244,.1) 0%,transparent 65%),radial-gradient(ellipse 50% 40% at 90% 80%,rgba(245,166,35,.06) 0%,transparent 60%);pointer-events:none}.hero__inner{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:3rem;align-items:center}.hero__eyebrow{margin-bottom:1.25rem}.hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,6vw,4.6rem);line-height:1.06;letter-spacing:-.02em;max-width:14ch}.hero h1 em{font-style:italic;color:var(--blue)}.hero__sub{margin-top:1.25rem;font-size:1.05rem;line-height:1.7;color:var(--ink-2);max-width:52ch}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}.hero__bullets{list-style:none;margin:1.75rem 0 0;padding:0;display:grid;gap:.6rem}.hero__bullets li{display:flex;align-items:center;gap:.6rem;font-size:.95rem;color:var(--ink-2)}.hero__bullets li:before{content:"";flex-shrink:0;width:6px;height:6px;border-radius:999px;background:var(--blue)}.hero__visual{position:relative}.hero__mockup{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 0 1px var(--border);overflow:hidden}.mockup__bar{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.1rem;background:#f1f4fb;border-bottom:1px solid var(--border)}.mockup__dot{width:10px;height:10px;border-radius:999px}.mockup__dot:nth-child(1){background:#ff6058}.mockup__dot:nth-child(2){background:#ffbb2c}.mockup__dot:nth-child(3){background:#28ca42}.mockup__body{display:grid;grid-template-columns:48px 1fr;min-height:280px}.mockup__sidebar{background:#f8faff;border-right:1px solid var(--border);padding:.75rem .5rem;display:grid;gap:.5rem;align-content:start}.mockup__icon{width:28px;height:28px;border-radius:8px;background:var(--blue-soft);display:flex;align-items:center;justify-content:center;margin:0 auto;font-size:.75rem}.mockup__icon--active{background:var(--blue);color:#fff}.mockup__canvas{padding:1rem;position:relative;background:#fafbff;background-image:linear-gradient(rgba(35,85,244,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(35,85,244,.04) 1px,transparent 1px);background-size:20px 20px}.mockup__doc{background:#fff;border-radius:8px;border:1px solid var(--border);padding:1rem;box-shadow:var(--shadow-sm)}.mockup__doc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.mockup__doc-title{font-size:.65rem;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.05em}.mockup__doc-logo{width:28px;height:10px;background:var(--blue);border-radius:3px;opacity:.8}.mockup__line{height:6px;border-radius:999px;background:var(--border);margin-bottom:.4rem}.mockup__line--short{width:60%}.mockup__line--med{width:80%}.mockup__line--blue{background:var(--blue-soft);width:45%}.mockup__table{margin-top:.75rem;border:1px solid var(--border);border-radius:6px;overflow:hidden}.mockup__tr{display:grid;grid-template-columns:2fr 1fr 1fr;border-bottom:1px solid var(--border)}.mockup__tr:last-child{border-bottom:none}.mockup__td{padding:.3rem .45rem;font-size:.6rem;color:var(--ink-2);border-right:1px solid var(--border)}.mockup__td:last-child{border-right:none}.mockup__tr--head .mockup__td{background:var(--blue-soft);font-weight:700;color:var(--blue);font-size:.55rem;text-transform:uppercase}.mockup__badge{position:absolute;bottom:1rem;right:1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;color:var(--ink);white-space:nowrap}.mockup__badge-dot{width:8px;height:8px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px #22c55e33;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #22c55e33}50%{box-shadow:0 0 0 6px #22c55e00}}.stats{margin-top:1.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden}.stat{background:var(--surface);padding:1.1rem 1rem;text-align:center}.stat__num{font-family:var(--font-display);font-size:1.8rem;line-height:1;color:var(--ink)}.stat__label{margin-top:.25rem;font-size:.8rem;color:var(--ink-3)}.section{padding:5rem 0}.section--dark{background:var(--ink);color:#f0f4ff}.section--tinted{background:#f0f4ff}.section__head{max-width:680px;margin-bottom:3rem}.section__head--center{margin-inline:auto;text-align:center}.section__eyebrow{margin-bottom:1rem}.section h2{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3rem);line-height:1.1;letter-spacing:-.02em;margin-top:.75rem}.section h2 em{font-style:italic;color:var(--blue)}.section--dark h2{color:#f0f4ff}.section--dark h2 em{color:#93b4ff}.section__lead{margin-top:.85rem;font-size:1.05rem;line-height:1.7;color:var(--ink-2)}.section--dark .section__lead{color:#94a3b8}.feat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem}.feat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.75rem;transition:transform .2s ease,box-shadow .2s ease}.feat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.feat-card__icon{width:44px;height:44px;border-radius:12px;background:var(--blue-soft);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:1.1rem}.feat-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem}.feat-card p{font-size:.95rem;line-height:1.65;color:var(--ink-2)}.feat-card--dark{background:#ffffff0d;border-color:#ffffff14}.feat-card--dark h3{color:#f0f4ff}.feat-card--dark p{color:#94a3b8}.feat-card--dark .feat-card__icon{background:#ffffff14}.steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;counter-reset:step}.step-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.75rem}.step-card__head{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.step-card__num{flex:none;display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:999px;background:var(--blue);color:#fff;font-family:var(--font-display);font-size:1.15rem;font-weight:700;line-height:1;box-shadow:0 6px 16px #2355f459}.step-card__label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}.step-card h3{font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.5rem}.step-card p{font-size:.95rem;color:var(--ink-2);line-height:1.65}.steps{position:relative}.video-wrap{margin-top:2.5rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-lg)}.video-wrap video{display:block;width:100%;height:auto;background:#000}.footer{background:linear-gradient(135deg,#0d1420,#0a0f1e);color:#f0f4ff;padding:5rem 0;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:999px;background:radial-gradient(circle,rgba(35,85,244,.12) 0%,transparent 70%);pointer-events:none}.footer__inner{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(240px,.8fr);gap:4rem;align-items:start}.footer__tag{margin-bottom:1rem}.footer h2{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.1;letter-spacing:-.02em;color:#f0f4ff;margin-top:0}.footer__sub{margin-top:.75rem;font-size:1rem;color:#64748b;line-height:1.7;max-width:46ch}.waitlist-form{display:flex;gap:.6rem;margin-top:1.5rem}.waitlist-input{flex:1;min-height:48px;padding:0 1.1rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#f0f4ff;font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color .2s}.waitlist-input:focus{border-color:var(--blue)}.waitlist-input::placeholder{color:#f0f4ff66}.footer__nav{display:grid;gap:2rem}.footer__nav-group h4{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#f0f4ff80;margin-bottom:.85rem}.footer__nav-group ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}.footer__nav-group a,.footer__nav-btn{font-size:.95rem;color:#f0f4ffbf;text-decoration:none;background:none;border:none;padding:0;font-family:var(--font-body);cursor:pointer;transition:color .15s}.footer__nav-group a:hover{color:#fff}.footer__nav-btn--dim{color:#f0f4ff4d;cursor:not-allowed}.footer__bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem;color:#f0f4ff59}@media (max-width: 900px){.hero__inner{grid-template-columns:1fr}.hero__visual{order:-1;max-width:480px}.feat-grid{grid-template-columns:repeat(2,1fr)}.steps{grid-template-columns:1fr}.footer__inner{grid-template-columns:1fr;gap:2.5rem}}@media (max-width: 600px){.hero{padding:3rem 0}.section{padding:3.5rem 0}.feat-grid{grid-template-columns:1fr}.stats{grid-template-columns:repeat(3,1fr)}.topbar__nav{display:none}.waitlist-form{flex-direction:column}.waitlist-form .btn{width:100%}}.tb{position:fixed;top:12px;right:16px;left:auto;z-index:1001;display:flex;align-items:center;gap:4px;height:48px;padding:0 10px;background:#ffffffe0;backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);border:1px solid rgba(15,23,42,.09);border-radius:14px;box-shadow:0 1px 2px #0f172a0a,0 4px 16px #0f172a14,inset 0 1px #ffffffe6}.tb-group{display:flex;align-items:center;gap:2px}.tb-divider{width:1px;height:22px;background:#0f172a1a;margin:0 4px;flex-shrink:0;border-radius:999px}.tb-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:5px;width:34px;height:34px;padding:0;border:1px solid transparent;border-radius:9px;background:transparent;color:#3d4a63;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .12s ease,box-shadow .15s ease}.tb-btn svg{flex-shrink:0}.tb-btn:hover:not(.tb-btn--disabled){background:#2355f412;border-color:#2355f426;color:#2355f4;transform:translateY(-1px)}.tb-btn:active:not(.tb-btn--disabled){transform:translateY(0);background:#2355f41f}.tb-btn--active{background:#2355f41a;border-color:#2355f438;color:#2355f4}.tb-btn--action{color:#475569}.tb-btn--action:hover:not(.tb-btn--disabled){background:#0f172a0d;border-color:#0f172a1f;color:#0f172a}.tb-btn--page{color:#166534}.tb-btn--page:hover:not(.tb-btn--disabled){background:#22c55e1a;border-color:#22c55e4d;color:#15803d}.tb-btn--page:active:not(.tb-btn--disabled){background:#22c55e29}.tb-btn--danger{color:#dc2626}.tb-btn--danger:hover:not(.tb-btn--disabled){background:#ef444414;border-color:#ef444440;color:#b91c1c}.tb-btn--danger:active:not(.tb-btn--disabled){background:#ef444424}.tb-btn--primary{width:auto;padding:0 13px;background:#2355f4;border-color:#2355f4;color:#fff;font-size:.82rem;font-weight:600;letter-spacing:.01em;box-shadow:0 2px 10px #2355f447}.tb-btn--primary:hover:not(.tb-btn--disabled){background:#1740d0;border-color:#1740d0;color:#fff;box-shadow:0 4px 16px #2355f45c;transform:translateY(-1px)}.tb-btn--primary:active:not(.tb-btn--disabled){transform:translateY(0);box-shadow:0 2px 8px #2355f43d}.tb-export-label{font-family:DM Sans,system-ui,sans-serif}.tb-btn--disabled,.tb-btn:disabled{opacity:.38;cursor:not-allowed;transform:none!important;box-shadow:none!important}.tb-chevron{margin-left:-2px;opacity:.5;transition:transform .2s ease}.tb-btn[aria-expanded=true] .tb-chevron{transform:rotate(180deg)}.tb-btn[aria-expanded=true]{width:auto;padding:0 10px}.tb-shapes-wrap{position:relative}.tb-shapes-menu{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);min-width:150px;background:#fffffff5;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(15,23,42,.09);border-radius:12px;box-shadow:0 4px 6px #0f172a0a,0 12px 32px #0f172a1f;padding:6px;animation:tb-menu-in .15s ease;z-index:100}@keyframes tb-menu-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tb-shapes-menu__label{padding:4px 8px 6px;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8}.tb-shapes-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;border-radius:7px;background:transparent;color:#334155;font-size:.875rem;font-weight:500;cursor:pointer;text-align:left;transition:background .12s ease,color .12s ease}.tb-shapes-item:hover{background:#2355f412;color:#2355f4}.tb-shapes-item__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:#0f172a0d;color:inherit;flex-shrink:0}.tb-shapes-item--active{background:#2355f414;color:#2355f4;font-weight:600}.tb-shapes-item--active .tb-shapes-item__icon{background:#2355f41f;color:#2355f4;font-size:.75rem}.tb-page-size-menu{min-width:220px}.tb-page-size-label{display:flex;align-items:baseline;gap:6px;flex:1}.tb-page-size-dim{font-size:.72rem;font-weight:400;color:#94a3b8;margin-left:auto}.tb-menu-divider{height:1px;background:#0f172a14;margin:4px 8px}.tb-custom-size{padding:8px 10px 6px}.tb-custom-size__row{display:flex;align-items:center;gap:6px}.tb-custom-size__label{display:flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;color:#475569;flex:1}.tb-custom-size__unit{font-size:.68rem;font-weight:400;color:#94a3b8}.tb-custom-size__input{width:100%;padding:5px 7px;border:1px solid rgba(15,23,42,.12);border-radius:6px;font-size:.82rem;font-weight:500;color:#1e293b;background:#f8fafce6;outline:none;transition:border-color .15s ease,box-shadow .15s ease;margin-top:2px}.tb-custom-size__input:focus{border-color:#2355f4;box-shadow:0 0 0 2px #2355f41f}.tb-custom-size__input::-webkit-inner-spin-button,.tb-custom-size__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.tb-custom-size__input[type=number]{-moz-appearance:textfield}.tb-custom-size__x{font-size:.85rem;color:#94a3b8;flex-shrink:0;padding-top:14px}.tb-custom-size__apply{display:block;width:100%;margin-top:8px;padding:6px 12px;border:none;border-radius:7px;background:#2355f4;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .1s ease}.tb-custom-size__apply:hover{background:#1a44d6}.tb-custom-size__apply:active{transform:scale(.97)}.tb-tooltip-wrap{position:relative;display:inline-flex}.tb-tooltip{pointer-events:none;position:absolute;top:calc(100% + 9px);left:50%;transform:translate(-50%);white-space:nowrap;z-index:200;display:flex;align-items:center;gap:6px;padding:5px 9px;background:#0f172a;color:#f0f4ff;border-radius:7px;font-size:.75rem;font-weight:500;letter-spacing:.01em;opacity:0;transform:translate(-50%) translateY(2px);transition:opacity .15s ease,transform .15s ease;box-shadow:0 4px 12px #0000002e}.tb-tooltip:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:8px;height:8px;background:#0f172a;clip-path:polygon(50% 0%,0% 100%,100% 100%)}.tb-tooltip-wrap:hover .tb-tooltip{opacity:1;transform:translate(-50%) translateY(0);transition-delay:.4s}.tb-tooltip__label{color:#f0f4ff}.tb-tooltip__key{display:inline-flex;align-items:center;padding:1px 5px;border-radius:4px;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);font-family:ui-monospace,SF Mono,monospace;font-size:.68rem;color:#f0f4ffbf;font-style:normal}.tb-export-group{gap:6px}.tb-format-toggle{display:flex;align-items:center;border:1px solid rgba(15,23,42,.1);border-radius:8px;overflow:hidden;height:30px}.tb-format-btn{display:flex;align-items:center;justify-content:center;padding:0 10px;height:100%;border:none;background:transparent;color:#64748b;font-size:.72rem;font-weight:600;letter-spacing:.03em;cursor:pointer;transition:all .15s ease}.tb-format-btn:hover{background:#0f172a0a;color:#334155}.tb-format-btn--active{background:#2355f4;color:#fff}.tb-format-btn--active:hover{background:#1a44d6;color:#fff}@media (max-width: 700px){.tb-export-label{display:none}.tb-btn--primary{width:34px;padding:0}.tb-format-toggle{display:none}}.rb-root{background:#fff}.rb-steps{display:flex;align-items:center;padding:14px 20px 10px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;gap:0}.rb-step{display:flex;align-items:center;gap:6px;flex-shrink:0}.rb-step-dot{width:22px;height:22px;border-radius:50%;border:1.5px solid #cbd5e1;background:#fff;color:#94a3b8;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.rb-step--active .rb-step-dot{border-color:#214883;background:#214883;color:#fff}.rb-step--done .rb-step-dot{border-color:#22c55e;background:#dcfce7;color:#166534;font-size:11px}.rb-step-label{font-size:11px;font-weight:500;color:#94a3b8;white-space:nowrap}.rb-step--active .rb-step-label{color:#214883}.rb-step--done .rb-step-label{color:#64748b}.rb-step-line{flex:1;height:1.5px;background:#e2e8f0;margin:0 8px;min-width:20px;transition:background .15s}.rb-step-line--done{background:#22c55e}.rb-body{padding:0}.rb-step-content{padding:16px 20px 14px}.rb-step-desc{margin:0 0 14px;font-size:12.5px;color:#64748b;line-height:1.5}.rb-coll-cards{display:flex;align-items:center;gap:0;margin-bottom:16px}.rb-coll-card{flex:1;border:.5px solid #e2e8f0;border-radius:8px;padding:12px 14px;background:#f8fafc}.rb-coll-card--driver{border-color:#93c5fd;background:#eff8ff}.rb-coll-card--child{border-color:#86efac;background:#f0fdf4}.rb-coll-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.rb-coll-role{font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:10px;background:#dbeafe;color:#1e40af;text-transform:uppercase;letter-spacing:.4px}.rb-coll-role--child{background:#dcfce7;color:#166534}.rb-coll-name{font-size:13px;font-weight:700;color:#0f172a}.rb-coll-stats{font-size:11px;color:#64748b;margin-bottom:8px}.rb-coll-cols{display:flex;flex-wrap:wrap;gap:4px}.rb-col-chip{font-family:Menlo,Monaco,monospace;font-size:10px;padding:1px 6px;background:#fff;border:.5px solid #e2e8f0;border-radius:3px;color:#475569}.rb-col-more{font-size:10px;color:#94a3b8;padding:1px 4px;align-self:center}.rb-coll-link-arrow{display:flex;flex-direction:column;align-items:center;padding:0 10px;flex-shrink:0}.rb-arrow-line{width:30px;height:1.5px;background:#cbd5e1}.rb-arrow-head{font-size:16px;color:#94a3b8;margin-top:-2px}.rb-col-selector{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px}.rb-col-selector-side{flex:1;display:flex;flex-direction:column;gap:6px}.rb-col-label{font-size:11px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.4px}.rb-col-select{height:32px;width:100%;padding:0 8px;font-size:12.5px;border:.5px solid #cbd5e1;border-radius:6px;background:#fff;color:#0f172a;outline:none}.rb-col-select:focus{border-color:#378add}.rb-col-sample{display:flex;flex-wrap:wrap;gap:4px}.rb-sample-val{font-family:Menlo,Monaco,monospace;font-size:10.5px;padding:1px 5px;background:#f1f5f9;border-radius:3px;color:#334155}.rb-col-selector-arrow{align-self:center;font-size:11.5px;font-weight:600;color:#94a3b8;padding-top:20px;flex-shrink:0;white-space:nowrap}.rb-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.rb-coverage-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;flex-shrink:0}.rb-coverage--good{background:#dcfce7;color:#166534}.rb-coverage--warn{background:#fef3c7;color:#92400e}.rb-coverage-warning{margin-bottom:10px;padding:8px 12px;background:#fffbeb;border:.5px solid #fde68a;border-radius:6px;font-size:12px;color:#92400e}.rb-join-previews{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;max-height:260px;overflow-y:auto}.rb-join-block{border:.5px solid #e2e8f0;border-radius:6px;overflow:hidden}.rb-join-driver{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:8px 10px;background:#eff8ff;border-bottom:.5px solid #e2e8f0}.rb-join-driver-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#1e40af;padding:1px 5px;background:#dbeafe;border-radius:3px;flex-shrink:0}.rb-join-field{display:inline-flex;gap:3px;font-size:11px}.rb-join-field-key{color:#94a3b8;font-family:Menlo,Monaco,monospace}.rb-join-field-val{color:#334155;font-family:Menlo,Monaco,monospace}.rb-join-arrow-down{padding:3px 10px;font-size:11px;color:#64748b;background:#f8fafc;border-bottom:.5px solid #f1f5f9}.rb-join-children{background:#f8fafc}.rb-join-child-row{display:flex;flex-wrap:wrap;gap:8px;padding:5px 10px;border-bottom:.5px solid #f1f5f9}.rb-join-child-row:last-child{border-bottom:none}.rb-join-more{padding:4px 10px;font-size:10.5px;color:#94a3b8;font-style:italic}.rb-join-empty{padding:8px 10px;font-size:11.5px;color:#f97316;background:#fff7ed}.rb-nav{display:flex;justify-content:space-between;align-items:center;padding-top:4px}.rb-btn-secondary{padding:6px 12px;font-size:12px;font-weight:500;border-radius:5px;border:.5px solid #cbd5e1;background:#fff;color:#475569;cursor:pointer}.rb-btn-secondary:hover{background:#f1f5f9}.rb-btn-primary{padding:6px 14px;font-size:12px;font-weight:500;border-radius:5px;border:none;background:#214883;color:#fff;cursor:pointer}.rb-btn-primary:hover:not(:disabled){background:#1a3a6b}.rb-btn-primary:disabled{opacity:.5;cursor:not-allowed}.rr-root{display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0f172a24;border:.5px solid #e2e8f0;width:min(680px,100%);max-height:calc(100vh - 80px);overflow:hidden}.rr-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 22px 14px;border-bottom:.5px solid #e2e8f0;flex-shrink:0;gap:16px}.rr-title{margin:0 0 4px;font-size:15px;font-weight:600;color:#0f172a}.rr-subtitle{margin:0;font-size:12.5px;color:#64748b;line-height:1.5}.rr-pending-note{color:#b45309;font-weight:500}.rr-progress-pill{font-size:11px;font-weight:600;padding:3px 10px;background:#f1f5f9;border-radius:20px;color:#475569;white-space:nowrap;flex-shrink:0}.rr-driver-bar{display:flex;align-items:center;gap:8px;padding:9px 22px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;font-size:12px;flex-shrink:0}.rr-driver-dot{width:8px;height:8px;border-radius:50%;background:#3b82f6;flex-shrink:0}.rr-driver-label{color:#0f172a}.rr-driver-meta{color:#94a3b8;margin-left:4px}.rr-body{flex:1;overflow-y:auto;padding:6px 0}.rr-empty{padding:24px 22px;font-size:13px;color:#94a3b8;text-align:center}.rr-row{padding:12px 22px;border-bottom:.5px solid #f1f5f9;transition:background .1s}.rr-row:last-child{border-bottom:none}.rr-row--approved{background:#fafffe}.rr-row--rejected{background:#fafafa;opacity:.7}.rr-row--pending{background:#fffdf7}.rr-row--unlinked{background:#fff}.rr-row--edited{background:#f0fdf4}.rr-row-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.rr-row-left{flex:0 0 140px;min-width:0}.rr-coll-name{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#0f172a}.rr-coll-meta{font-size:11px;color:#94a3b8;margin-top:2px}.rr-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rr-dot--auto{background:#22c55e}.rr-dot--suggest{background:#f59e0b}.rr-dot--uncertain{background:#f97316}.rr-dot--none{background:#cbd5e1}.rr-join{display:flex;align-items:center;gap:6px;flex:1;min-width:0;font-family:Menlo,Monaco,monospace;font-size:11px}.rr-join-key{background:#f1f5f9;padding:2px 6px;border-radius:4px;color:#185fa5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rr-join-arrow{color:#94a3b8;flex-shrink:0}.rr-row-right{display:flex;align-items:center;gap:7px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.rr-badge{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap}.rr-badge--auto{background:#dcfce7;color:#166534}.rr-badge--suggest{background:#fef3c7;color:#92400e}.rr-badge--uncertain{background:#ffedd5;color:#9a3412}.rr-badge--none{background:#f1f5f9;color:#64748b;border:.5px solid #e2e8f0}.rr-status{font-size:11.5px;font-weight:500}.rr-status--approved,.rr-status--edited{color:#166534}.rr-status--rejected{color:#94a3b8}.rr-actions{display:flex;align-items:center;gap:5px}.rr-btn{font-size:11.5px;font-weight:500;padding:3px 10px;border-radius:5px;cursor:pointer;border:.5px solid transparent;transition:background .12s,border-color .12s;white-space:nowrap}.rr-btn--approve{background:#214883;color:#fff;border-color:#214883}.rr-btn--approve:hover{background:#1a3a6b}.rr-btn--edit{background:#f8fafc;color:#475569;border-color:#e2e8f0}.rr-btn--edit:hover{background:#f1f5f9;border-color:#cbd5e1}.rr-btn--reject{background:transparent;color:#94a3b8;border-color:#e2e8f0}.rr-btn--reject:hover{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.rr-btn--undo{background:transparent;color:#64748b;border-color:#e2e8f0}.rr-btn--undo:hover{background:#f8fafc}.rr-explanation{margin-top:7px;font-size:11.5px;color:#64748b;padding-left:14px;border-left:2px solid #e2e8f0;line-height:1.5}.rr-builder-inline{margin-top:10px;border:.5px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f8fafc}.rr-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 22px;border-top:.5px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.rr-btn-secondary{padding:7px 14px;font-size:12px;font-weight:500;border-radius:6px;border:.5px solid #cbd5e1;background:#fff;color:#475569;cursor:pointer}.rr-btn-secondary:hover{background:#f1f5f9}.rr-btn-primary{padding:7px 16px;font-size:12px;font-weight:500;border-radius:6px;border:none;background:#214883;color:#fff;cursor:pointer;transition:background .12s}.rr-btn-primary:hover:not(:disabled){background:#1a3a6b}.rr-btn-primary:disabled{opacity:.55;cursor:not-allowed;background:#b45309}.icp-root{padding:24px 24px 8px}.icp-eyebrow{font-size:10.5px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:#94a3b8;margin-bottom:8px}.icp-heading{margin:0 0 6px;font-size:17px;font-weight:600;color:#0f172a;line-height:1.3}.icp-sub{margin:0 0 20px;font-size:13px;color:#64748b;line-height:1.5}.icp-options{display:flex;flex-direction:column;gap:8px}.icp-option{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;text-align:left;transition:border-color .14s,box-shadow .14s,background .14s;width:100%}.icp-option:hover{border-color:#378add;background:#f8fbff;box-shadow:0 2px 8px #378add1a}.icp-option:active{background:#eff6ff}.icp-option-icon{width:42px;height:42px;border-radius:8px;background:#f0f7ff;color:#185fa5;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .14s}.icp-option:hover .icp-option-icon{background:#dbeafe}.icp-option-icon--relational{background:#f0fdf4;color:#166534}.icp-option:hover .icp-option-icon--relational{background:#dcfce7}.icp-option-body{flex:1;display:flex;flex-direction:column;gap:3px}.icp-option-title{font-size:13.5px;font-weight:600;color:#0f172a;line-height:1.3}.icp-option-desc{font-size:12px;color:#64748b;line-height:1.5}.icp-option-arrow{font-size:18px;color:#cbd5e1;align-self:center;flex-shrink:0;transition:color .14s,transform .14s}.icp-option:hover .icp-option-arrow{color:#378add;transform:translate(2px)}.upload-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a80}.upload-panel-card{width:min(100%,680px);max-height:min(100%,92vh);overflow-y:auto;background:#fff;border-radius:12px;border:.5px solid #e2e8f0;box-shadow:0 20px 60px #0f172a24;display:flex;flex-direction:column}.upload-panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px;border-bottom:.5px solid #e2e8f0;flex-shrink:0}.upload-panel-header h2{margin:0;font-size:15px;font-weight:500;color:#0f172a}.upload-panel-header p{margin:3px 0 0;font-size:12px;color:#64748b;line-height:1.5}.upload-close{border:none;background:transparent;font-size:16px;line-height:1;cursor:pointer;color:#94a3b8;padding:2px 6px;border-radius:4px}.upload-close:hover{color:#334155;background:#f1f5f9}.upload-file-bar{display:flex;align-items:center;gap:10px;padding:10px 20px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;flex-shrink:0}.upload-file-icon{width:28px;height:28px;border-radius:6px;background:#eaf3de;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.upload-file-info{flex:1;min-width:0}.upload-file-name{font-size:12px;font-weight:500;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-file-meta{font-size:11px;color:#64748b;margin-top:1px}.upload-file-pills{display:flex;gap:5px;flex-wrap:wrap;flex-shrink:0}.upload-dropzone{border:1.5px dashed #cbd5e1;border-radius:8px;padding:28px 20px;text-align:center;background:#f8fafc;transition:background .15s,border-color .15s;position:relative;margin:16px 20px}.upload-dropzone.active{border-color:#4f46e5;background:#eef2ff}.upload-dropzone.parsing{opacity:.75;pointer-events:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:8px}.upload-icon{font-size:36px}.upload-dropzone h3{margin:0;font-size:14px;font-weight:500;color:#0f172a}.upload-dropzone p{margin:0;font-size:12px;color:#64748b}.upload-browse-btn{margin-top:8px;padding:7px 16px;border:none;border-radius:6px;background:#214883;color:#fff;cursor:pointer;font-size:12px;font-weight:500}.upload-browse-btn:hover{background:#1a3a6b}.upload-progress{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffe6;gap:10px;border-radius:7px}.upload-spinner{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#214883;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.upload-error{margin:0 20px 12px;padding:10px 14px;background:#fef2f2;color:#991b1b;border-radius:6px;border:.5px solid #fca5a5;font-size:13px}.up-pill{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}.up-pill-blue{background:#e6f1fb;color:#0c447c}.up-pill-green{background:#eaf3de;color:#27500a}.up-pill-amber{background:#faeeda;color:#854f0b}.up-pill-gray{background:#f1f5f9;color:#475569;border:.5px solid #e2e8f0}.up-section{border-top:.5px solid #e2e8f0;padding:14px 20px}.up-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.up-section-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.up-section-hint{font-size:12px;color:#64748b;margin-bottom:10px;line-height:1.5}.up-field-list{display:flex;flex-direction:column;gap:1px}.up-field-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr) 68px;align-items:center;gap:8px;padding:5px 8px;border-radius:5px}.up-field-row:hover{background:#f8fafc}.up-field-key{font-family:Menlo,Monaco,monospace;font-size:11.5px;color:#185fa5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-field-source{font-size:11.5px;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-field-source code{font-family:Menlo,Monaco,monospace;font-size:10.5px;background:#f1f5f9;padding:1px 4px;border-radius:3px;color:#475569}.up-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:500;text-align:center;white-space:nowrap}.up-badge-auto,.up-badge-set{background:#eaf3de;color:#27500a}.up-badge-required{background:#f1f5f9;color:#94a3b8;border:.5px solid #e2e8f0}.up-meta-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr) 68px;align-items:center;gap:8px;padding:5px 8px;border-radius:5px}.up-meta-row:hover{background:#f8fafc}.up-meta-input{width:100%;height:28px;font-size:12px;padding:0 8px;border:.5px solid #cbd5e1;border-radius:5px;background:#fff;color:#0f172a;outline:none;transition:border-color .15s}.up-meta-input:focus{border-color:#378add;box-shadow:0 0 0 2px #378add1f}.up-meta-input::placeholder{color:#94a3b8;font-style:italic}.up-table-card{border:.5px solid #e2e8f0;border-radius:8px;overflow:hidden;margin-bottom:8px}.up-table-card:last-child{margin-bottom:0}.up-table-card-head{display:flex;align-items:center;gap:7px;padding:8px 12px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;font-size:12px;font-weight:500;color:#334155}.up-table-card-body{padding:10px 12px}.up-coll-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.up-coll-label{font-size:11.5px;color:#64748b;min-width:70px}.up-coll-select{flex:1;height:28px;font-size:12px;padding:0 8px;border:.5px solid #cbd5e1;border-radius:5px;background:#fff;color:#0f172a;outline:none}.up-coll-select:focus{border-color:#378add}.up-col-map-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}.up-col-map-row{display:flex;align-items:center;gap:5px}.up-col-map-key{font-family:Menlo,Monaco,monospace;font-size:11px;color:#185fa5;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-col-map-arrow{font-size:11px;color:#94a3b8;flex-shrink:0}.up-col-map-sel{flex:1;height:24px;font-size:11px;padding:0 4px;border:.5px solid #e2e8f0;border-radius:4px;background:#fff;color:#0f172a;outline:none;min-width:0}.up-col-map-sel:focus{border-color:#378add}.upload-warnings{margin-top:8px}.upload-warning{font-size:12px;color:#92400e;background:#fffbeb;border:.5px solid #fde68a;border-radius:5px;padding:6px 10px;margin-bottom:4px}.upload-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:.5px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.upload-footer-hint{font-size:12px;color:#94a3b8}.upload-footer-hint.hint-ready{color:#27500a}.upload-footer-actions{display:flex;gap:8px}.upload-btn-secondary{padding:7px 14px;font-size:12px;font-weight:500;border-radius:6px;border:.5px solid #cbd5e1;background:#fff;color:#475569;cursor:pointer}.upload-btn-secondary:hover{background:#f1f5f9}.upload-btn-primary{padding:7px 16px;font-size:12px;font-weight:500;border-radius:6px;border:none;background:#214883;color:#fff;cursor:pointer}.upload-btn-primary:hover:not(:disabled){background:#1a3a6b}.upload-btn-primary:disabled{opacity:.5;cursor:not-allowed}.mapping-collection-meta{font-weight:400;color:#94a3b8;font-size:12px}.mapping-panel{margin-top:0;padding:0;border-radius:0;background:transparent;border:none}.mapping-panel-header h3{margin:0 0 4px;font-size:13px;font-weight:500;color:#334155}.mapping-panel-header p{margin:0;font-size:12px;color:#64748b;line-height:1.5}.mapping-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center}.mapping-row span{font-size:12px;color:#334155}.mapping-row select{height:28px;font-size:12px;padding:0 6px;border:.5px solid #cbd5e1;border-radius:5px;background:#fff;color:#0f172a}.mapping-subheading{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;margin:10px 0 4px}.mapping-collection-picker{margin-bottom:8px}@media (max-width: 640px){.upload-panel-card{border-radius:8px}.up-field-row,.up-meta-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 56px}.up-col-map-grid{grid-template-columns:1fr}}.up-phase-bar{display:flex;align-items:center;padding:10px 20px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;flex-shrink:0;gap:0}.up-phase-step{display:flex;align-items:center;gap:5px;flex-shrink:0}.up-phase-dot{width:20px;height:20px;border-radius:50%;border:1.5px solid #cbd5e1;background:#fff;color:#94a3b8;font-size:9.5px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.up-phase-step--active .up-phase-dot{border-color:#214883;background:#214883;color:#fff}.up-phase-step--done .up-phase-dot{border-color:#22c55e;background:#dcfce7;color:#166534;font-size:10px}.up-phase-label{font-size:11px;font-weight:500;color:#94a3b8}.up-phase-step--active .up-phase-label{color:#214883}.up-phase-step--done .up-phase-label{color:#64748b}.up-phase-line{flex:1;height:1.5px;background:#e2e8f0;margin:0 8px;min-width:12px;transition:background .15s}.up-phase-line--done{background:#22c55e}.up-intent-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:#f8fafc;border-bottom:.5px solid #e2e8f0;flex-shrink:0}.up-intent-chip{font-size:12px;font-weight:500;padding:3px 10px;border-radius:20px}.up-intent-chip--flat{background:#e0f2fe;color:#0369a1}.up-intent-chip--relational{background:#dcfce7;color:#166534}.up-intent-change{font-size:11.5px;color:#64748b;background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;text-decoration:underline;text-underline-offset:2px}.up-intent-change:hover{color:#334155}.up-single-coll-warn{margin:0 20px 12px;padding:9px 12px;background:#fffbeb;border:.5px solid #fde68a;border-radius:6px;font-size:12px;color:#92400e;line-height:1.5}.up-rel-summary{background:#f0fdf4;border-bottom:.5px solid #bbf7d0!important}.up-rel-chips{display:flex;flex-direction:column;gap:5px}.up-rel-chip{display:flex;align-items:center;gap:6px;font-size:11.5px;padding:4px 8px;background:#fff;border:.5px solid #bbf7d0;border-radius:5px}.up-rel-chip-driver{font-weight:600;color:#166534;font-family:Menlo,Monaco,monospace}.up-rel-chip-arrow{color:#94a3b8}.up-rel-chip-child{font-weight:600;color:#0f172a;font-family:Menlo,Monaco,monospace}.up-rel-chip-keys{color:#64748b;font-size:10.5px;font-family:Menlo,Monaco,monospace}.upload-panel-card--wide{width:min(100%,720px)}.dsv-root{display:flex;flex-direction:column;width:min(720px,calc(100vw - 48px));max-height:calc(100vh - 80px);background:var(--color-background-primary, #ffffff);border-radius:12px;box-shadow:0 20px 60px #0f172a2e;overflow:hidden}.dsv-header{padding:20px 24px 16px;border-bottom:1px solid var(--color-border-tertiary, #e2e8f0)}.dsv-header h3{margin:0 0 4px;font-size:15px;font-weight:600;color:var(--color-text-primary, #0f172a)}.dsv-description{margin:0;font-size:13px;color:var(--color-text-secondary, #64748b);line-height:1.45}.dsv-rel-bar{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:10px 24px;background:var(--color-background-secondary, #f8fafc);border-bottom:1px solid var(--color-border-tertiary, #e2e8f0)}.dsv-rel-item{display:flex;align-items:center;gap:6px;font-size:12px}.dsv-rel-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dsv-dot-driver{background:#3b82f6}.dsv-dot-related{background:#22c55e}.dsv-rel-name{font-weight:600;color:var(--color-text-primary, #0f172a)}.dsv-rel-meta{color:var(--color-text-secondary, #64748b)}.dsv-rel-none{font-size:12px;color:var(--color-text-tertiary, #94a3b8);font-style:italic}.dsv-code{font-family:var(--font-mono, "Menlo", monospace);font-size:11px;background:#f1f5f9;padding:1px 4px;border-radius:3px;color:#0369a1}.dsv-nav-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 24px;border-bottom:1px solid var(--color-border-tertiary, #e2e8f0);background:var(--color-background-primary, #ffffff)}.dsv-nav-btn{width:28px;height:28px;border:1px solid var(--color-border-secondary, #cbd5e1);border-radius:6px;background:var(--color-background-primary, #ffffff);color:var(--color-text-primary, #0f172a);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;line-height:1}.dsv-nav-btn:hover:not(:disabled){background:#eff6ff;border-color:#93c5fd}.dsv-nav-btn:disabled{opacity:.35;cursor:not-allowed}.dsv-nav-label{font-size:12px;font-weight:600;color:var(--color-text-primary, #374151);min-width:160px;text-align:center;font-family:var(--font-sans, system-ui, sans-serif)}.dsv-nav-coll{font-weight:400;color:var(--color-text-secondary, #64748b)}.dsv-tree{flex:1;overflow-y:auto;padding:14px 20px;background:var(--color-background-primary, #fafafa);font-family:var(--font-mono, "Menlo", "Monaco", "Cascadia Code", monospace);font-size:12.5px;line-height:1.55}.dsv-empty{color:var(--color-text-tertiary, #94a3b8);font-size:13px;font-family:var(--font-sans, system-ui, sans-serif);padding:20px 0;text-align:center}.dsv-row{display:flex;align-items:baseline;gap:2px;padding:1px 4px;border-radius:3px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .08s;outline:none}.dsv-row:hover,.dsv-row:focus-visible{background:#6366f10f}.dsv-leaf{display:flex;align-items:baseline;gap:2px;padding:1px 4px}.dsv-toggle{width:14px;text-align:center;font-size:11px;font-weight:600;color:var(--color-text-tertiary, #94a3b8);flex-shrink:0;font-family:var(--font-sans, system-ui, sans-serif);-webkit-user-select:none;user-select:none}.dsv-key{color:#185fa5}.dsv-colon{color:var(--color-text-tertiary, #94a3b8);margin-right:2px}.dsv-punct{color:var(--color-text-secondary, #64748b)}.dsv-str{color:#3b6d11}.dsv-num{color:#ba7517}.dsv-bool{color:#6b21a8}.dsv-null{color:#991b1b}.dsv-preview{color:var(--color-text-tertiary, #94a3b8);font-size:11.5px;max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsv-children{padding-left:20px;border-left:1px solid var(--color-border-tertiary, #e2e8f0);margin-left:7px}.dsv-close{padding:1px 4px}.dsv-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 24px;border-top:1px solid var(--color-border-tertiary, #e2e8f0);background:var(--color-background-primary, #ffffff)}.dsv-footer-hint{margin:0;font-size:12px;color:var(--color-text-tertiary, #94a3b8);text-align:center;flex:1}.dsv-btn{height:34px;padding:0 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;flex-shrink:0}.dsv-btn-back{background:var(--color-background-secondary, #f1f5f9);color:var(--color-text-secondary, #475569);border:1px solid var(--color-border-secondary, #cbd5e1)}.dsv-btn-back:hover{background:#e2e8f0}.dsv-btn-confirm{background:#4f46e5;color:#fff;border:none}.dsv-btn-confirm:hover{background:#4338ca}.page-break-divider{display:flex;align-items:center;gap:16px;padding:12px 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .15s}.page-break-divider:hover .page-break-badge{background:#e0e7ff;border-color:#a5b4fc;color:#3730a3}.page-break-line{flex:1;height:1px;background:#cbd5e1;transition:background .15s}.page-break-divider--selected .page-break-line{background:#6366f1}.page-break-centre{display:flex;flex-direction:column;align-items:center;gap:0}.page-break-badge{display:flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#475569;font-size:12px;font-weight:600;white-space:nowrap;transition:all .15s}.page-break-divider--selected .page-break-badge{background:#eef2ff;border-color:#6366f1;color:#4338ca}.page-break-icon{font-size:14px}.page-break-chevron{font-size:9px;opacity:.6}.page-break-settings{margin-top:10px;padding:16px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 4px 16px #0f172a14;display:flex;flex-direction:column;gap:14px;min-width:320px;z-index:100}.page-break-field{display:flex;flex-direction:column;gap:6px;cursor:default}.page-break-field--toggle{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:16px}.page-break-field-label{font-size:12px;font-weight:600;color:#374151;display:flex;flex-direction:column;gap:2px}.page-break-hint{font-size:11px;font-weight:400;color:#9ca3af;line-height:1.4}.page-break-input{height:34px;border:1px solid #d1d5db;border-radius:6px;padding:0 10px;font-size:13px;color:#111827;outline:none;transition:border-color .15s}.page-break-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.toggle-switch{width:40px;height:22px;border-radius:999px;background:#d1d5db;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.toggle-switch--on{background:#6366f1}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0003;transition:transform .2s}.toggle-switch--on .toggle-knob{transform:translate(18px)}.page-break-delete-btn{align-self:flex-start;padding:6px 12px;border-radius:6px;border:1px solid #fca5a5;background:#fee2e2;color:#991b1b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.page-break-delete-btn:hover{background:#fecaca;border-color:#f87171}.boundary-line{position:absolute;left:0;width:100%;z-index:50;pointer-events:none}.boundary-line__track{display:flex;align-items:center;gap:8px;cursor:ns-resize;pointer-events:all;-webkit-user-select:none;user-select:none}.boundary-line__dash{flex:1;height:1px;background:repeating-linear-gradient(to right,#cbd5e1 0px,#cbd5e1 6px,transparent 6px,transparent 12px);transition:background .15s}.boundary-line--enabled .boundary-line__dash{background:repeating-linear-gradient(to right,#6366f1 0px,#6366f1 6px,transparent 6px,transparent 12px)}.boundary-line--selected .boundary-line__dash{background:#6366f1}.boundary-line__pill{display:flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#64748b;font-size:11px;font-weight:600;white-space:nowrap;transition:all .15s;pointer-events:all}.boundary-line--enabled .boundary-line__pill{border-color:#a5b4fc;background:#eef2ff;color:#4338ca}.boundary-line--selected .boundary-line__pill{border-color:#6366f1;background:#eef2ff;color:#3730a3}.boundary-line__track:hover .boundary-line__pill{border-color:#6366f1;color:#4338ca}.boundary-line__chevron{font-size:8px;opacity:.6}.boundary-line__panel{position:absolute;left:50%;transform:translate(-50%);z-index:200;width:300px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0f172a1f;padding:14px;display:flex;flex-direction:column;gap:12px;pointer-events:all}.boundary-line__panel--header{top:4px}.boundary-line__panel--footer{bottom:4px;top:auto}.bl-field{display:flex;flex-direction:column;gap:4px}.bl-field--toggle{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:12px}.bl-field--column{flex-direction:column;align-items:stretch;gap:8px}.bl-scope-group{display:flex;flex-direction:column;gap:4px}.bl-scope-btn{text-align:left;padding:7px 10px;border-radius:5px;border:1px solid #d1d5db;background:#f8fafc;color:#475569;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.bl-scope-btn:hover{border-color:#cbd5e1}.bl-scope-btn--active{border-color:#6366f1;background:#eef2ff;color:#4338ca;font-weight:600}.bl-label{font-size:12px;font-weight:600;color:#374151;display:flex;flex-direction:column;gap:2px}.bl-hint{font-size:11px;font-weight:400;color:#9ca3af;line-height:1.4}.bl-input{height:32px;border:1px solid #d1d5db;border-radius:6px;padding:0 8px;font-size:13px;color:#111827;outline:none}.bl-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.bl-color{width:100%;height:32px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:0}.bl-opacity-control{display:flex;align-items:center;gap:8px}.bl-slider{flex:1;height:6px;border-radius:3px;background:linear-gradient(to right,#6366f11a,#6366f14d);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.bl-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#6366f1;cursor:pointer;box-shadow:0 1px 3px #0003}.bl-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#6366f1;cursor:pointer;border:none;box-shadow:0 1px 3px #0003}.bl-opacity-value{font-size:12px;font-weight:600;color:#6366f1;min-width:40px;text-align:right}.bl-toggle{width:38px;height:20px;border-radius:999px;background:#d1d5db;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.bl-toggle--on{background:#6366f1}.bl-toggle__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.bl-toggle--on .bl-toggle__knob{transform:translate(18px)}.bl-delete{align-self:flex-start;padding:5px 10px;border-radius:6px;border:1px solid #fca5a5;background:#fee2e2;color:#991b1b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.bl-delete:hover{background:#fecaca}.boundary-line--header.boundary-line--enabled:before{content:"";position:absolute;left:0;bottom:1px;width:100%;height:9999px;transform:translateY(100%)}.bl-separator{height:1px;background:#e2e8f0;margin:12px 0}.bl-section-title{font-size:13px;font-weight:600;color:#475569;margin-bottom:12px}.bl-radio-group{display:flex;flex-direction:column;gap:6px}.bl-radio-option{display:flex;align-items:center;gap:8px;font-size:13px;color:#475569;cursor:pointer;-webkit-user-select:none;user-select:none}.bl-radio-option input[type=radio]{width:14px;height:14px;cursor:pointer;accent-color:#6366f1}.bl-radio-option--selected{color:#1e293b;font-weight:500}.bl-align-group{display:flex;gap:4px}.bl-align-btn{flex:1;padding:6px 8px;border-radius:4px;border:1px solid #d1d5db;background:#f8fafc;color:#475569;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.bl-align-btn:hover{border-color:#cbd5e1}.bl-align-btn--active{border-color:#6366f1;background:#eef2ff;color:#6366f1}.bl-hint--preview{font-size:12px;color:#64748b;margin-top:8px}.bl-add-pagenum{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;margin-top:4px;margin-bottom:4px;background:#eff6ff;color:#2563eb;border:1.5px solid #bfdbfe;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.bl-add-pagenum:hover{background:#dbeafe;border-color:#93c5fd}.bl-add-pagenum:active{background:#bfdbfe}.bl-section-hint{font-size:10px;font-weight:400;color:#94a3b8;margin-left:4px}.bl-hint--muted{font-size:11px;color:#94a3b8;margin-top:8px;line-height:1.5}.bl-hint--muted strong{color:#64748b}.stm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:3000;display:flex;align-items:center;justify-content:center}.stm-card{background:#fff;border-radius:14px;padding:28px 28px 24px;width:min(420px,calc(100vw - 32px));box-shadow:0 24px 64px #0f172a2e}.stm-title{font-size:18px;font-weight:700;color:#0f172a;margin:0 0 4px}.stm-subtitle{font-size:13px;color:#64748b;margin:0 0 20px}.stm-input{width:100%;height:42px;border:1px solid #cbd5e1;border-radius:8px;padding:0 12px;font-size:14px;color:#0f172a;outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.stm-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.stm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.stm-btn{height:38px;padding:0 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .15s}.stm-btn--cancel{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.stm-btn--cancel:hover{background:#e2e8f0}.stm-btn--save{background:#6366f1;color:#fff}.stm-btn--save:hover:not(:disabled){background:#4f46e5}.stm-btn--save:disabled{opacity:.5;cursor:not-allowed}.tlm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1600;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tlm-card{width:100%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;background:#fff;border:1px solid #e5e9f1;border-radius:14px;box-shadow:0 24px 60px #0f172a40;overflow:hidden}.tlm-body{overflow-y:auto;padding-bottom:8px}.tlm-section{padding:16px 16px 4px}.tlm-section-title{margin:0;padding:14px 18px 0;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#94a3b8}.tlm-section .tlm-section-title{padding:0}.tlm-section-sub{margin:4px 0 12px;font-size:12px;color:#94a3b8}.tlm-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.tlm-tile{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:14px;min-height:96px;background:#fff;border:1px solid #e5e9f1;border-radius:11px;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.tlm-tile:hover{border-color:#c7dbff;box-shadow:0 6px 18px #2563eb1f;transform:translateY(-1px)}.tlm-tile-size{position:absolute;top:12px;right:12px;font-size:10px;font-weight:700;color:#2563eb;background:#eef4ff;border-radius:6px;padding:2px 7px}.tlm-tile-name{font-size:15px;font-weight:700;color:#0f172a}.tlm-tile-desc{font-size:12px;line-height:1.4;color:#64748b}.tlm-tile-cat{margin-top:auto;font-size:11px;font-weight:600;color:#94a3b8}.tlm-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid #eef1f6}.tlm-title{margin:0;font-size:17px;font-weight:700;color:#0f172a}.tlm-close{border:none;background:none;font-size:24px;line-height:1;color:#94a3b8;cursor:pointer;padding:0 4px}.tlm-close:hover{color:#475569}.tlm-msg{margin:0;padding:28px 20px;text-align:center;font-size:14px;color:#64748b}.tlm-msg--error{color:#dc2626}.tlm-list{list-style:none;margin:0;padding:8px}.tlm-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:9px;cursor:pointer}.tlm-row:hover{background:#f5f8ff}.tlm-row--current{background:#eef4ff;box-shadow:inset 0 0 0 1px #c7dbff}.tlm-row-main{display:flex;flex-direction:column;min-width:0}.tlm-name{font-size:14px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tlm-date{font-size:12px;color:#94a3b8}.tlm-row-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.tlm-open{font-size:13px;font-weight:600;color:#2563eb;background:#fff;border:1px solid #c7dbff;border-radius:7px;padding:5px 12px;cursor:pointer}.tlm-open:hover:not(:disabled){background:#eef4ff}.tlm-delete{font-size:14px;background:none;border:1px solid transparent;border-radius:7px;padding:5px 8px;cursor:pointer;opacity:.6}.tlm-delete:hover:not(:disabled){opacity:1;background:#fff1f1}.tlm-open:disabled,.tlm-delete:disabled{opacity:.4;cursor:default}.canvas-text-element{cursor:move;-webkit-user-select:none;user-select:none;white-space:nowrap;min-width:50px;touch-action:none}.canvas-text-element:hover:not(.dragging):not(.selected){outline:1px dashed #007bff;outline-offset:2px}.canvas-text-element.selected{outline:2px solid #007bff;outline-offset:2px;z-index:100}.canvas-text-element.dragging{opacity:.5;cursor:grabbing;z-index:1000}.resize-handle{position:absolute;bottom:-4px;right:-4px;width:12px;height:12px;background-color:#007bff;border:2px solid white;border-radius:50%;cursor:nwse-resize;z-index:101;box-shadow:0 2px 4px #0003}.text-element-input{background:transparent;border:1px solid #007bff;outline:none;padding:2px 4px;min-width:100px;font-family:inherit;cursor:text}.placeholder-text{background-color:#fff3cd;color:#856404;padding:2px 4px;border-radius:3px;font-weight:600;border:1px solid #ffc107}.placeholder-text.placeholder-invalid{background-color:#f8d7da;color:#721c24;border:1px solid #dc3545}.canvas-image-element{cursor:move;-webkit-user-select:none;user-select:none;touch-action:none;border:2px solid transparent;box-sizing:border-box}.canvas-image-element:hover:not(.dragging):not(.selected){outline:1px dashed #007bff;outline-offset:2px}.canvas-image-element.selected{outline:2px solid #007bff;outline-offset:2px;z-index:100}.canvas-image-element.dragging{opacity:.5;cursor:grabbing;z-index:1000}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f8f9fa;border:2px dashed #dee2e6;border-radius:4px;color:#6c757d}.image-placeholder-icon{font-size:48px;margin-bottom:8px}.image-placeholder-text{font-size:14px;font-weight:600;background-color:#fff3cd;color:#856404;padding:4px 8px;border-radius:3px;border:1px solid #ffc107}.image-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f8d7da;color:#721c24;border:1px solid #dc3545;border-radius:4px;font-size:12px}.resize-handle{position:absolute;background-color:#007bff;border:2px solid white;z-index:101;box-shadow:0 2px 4px #0003}.resize-handle:hover{background-color:#0056b3;transform:scale(1.2)}.resize-handle-corner{bottom:-6px;right:-6px;width:12px;height:12px;border-radius:50%;cursor:nwse-resize}.resize-handle-right{top:50%;right:-6px;width:12px;height:24px;transform:translateY(-50%);border-radius:2px;cursor:ew-resize}.resize-handle-bottom{bottom:-6px;left:50%;width:24px;height:12px;transform:translate(-50%);border-radius:2px;cursor:ns-resize}.canvas-line-element{cursor:move;-webkit-user-select:none;user-select:none;touch-action:none;box-sizing:border-box}.canvas-line-element.horizontal{border-bottom:2px solid;height:0}.canvas-line-element.vertical{border-left:2px solid;width:0}.canvas-line-element:hover:not(.dragging):not(.selected){outline:1px dashed #007bff;outline-offset:4px}.canvas-line-element.selected{outline:2px solid #007bff;outline-offset:4px;z-index:100}.canvas-line-element.dragging{opacity:.5;cursor:grabbing;z-index:1000}.line-resize-handle{position:absolute;width:12px;height:12px;background-color:#007bff;border:2px solid white;border-radius:50%;cursor:pointer;z-index:101;box-shadow:0 2px 4px #0003;transform:translate(-50%,-50%)}.line-resize-handle:hover{background-color:#0056b3;transform:translate(-50%,-50%) scale(1.2)}.canvas-line-element.horizontal .line-resize-start{left:0;top:50%}.canvas-line-element.horizontal .line-resize-end{right:0;top:50%}.canvas-line-element.vertical .line-resize-start{left:50%;top:0}.canvas-line-element.vertical .line-resize-end{left:50%;bottom:0}.canvas-box-element{cursor:move;-webkit-user-select:none;user-select:none;touch-action:none}.canvas-box-element:hover:not(.dragging):not(.selected){outline:1px dashed #007bff;outline-offset:2px}.canvas-box-element.selected{outline:2px solid #007bff;outline-offset:2px;z-index:100}.canvas-box-element.dragging{opacity:.5;cursor:grabbing;z-index:1000}.box-resize-handle{position:absolute;background-color:#007bff;border:2px solid white;z-index:101;box-shadow:0 2px 4px #0003}.box-resize-handle:hover{background-color:#0056b3;transform:scale(1.2)}.box-resize-corner{width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%)}.box-resize-edge{background-color:#007bff;border:2px solid white}.box-resize-top-left{top:0;left:0;cursor:nwse-resize}.box-resize-top-right{top:0;right:0;cursor:nesw-resize}.box-resize-bottom-left{bottom:0;left:0;cursor:nesw-resize}.box-resize-bottom-right{bottom:0;right:0;cursor:nwse-resize}.box-resize-right{top:50%;right:-6px;width:12px;height:24px;transform:translateY(-50%);border-radius:2px;cursor:ew-resize}.box-resize-bottom{bottom:-6px;left:50%;width:24px;height:12px;transform:translate(-50%);border-radius:2px;cursor:ns-resize}.box-resize-left{top:50%;left:-6px;width:12px;height:24px;transform:translateY(-50%);border-radius:2px;cursor:ew-resize}.box-resize-top{top:-6px;left:50%;width:24px;height:12px;transform:translate(-50%);border-radius:2px;cursor:ns-resize}.canvas-date-element{cursor:move;-webkit-user-select:none;user-select:none;touch-action:none}.canvas-date-element:hover:not(.dragging):not(.selected){outline:1px dashed #007bff;outline-offset:2px}.canvas-date-element.selected{outline:2px solid #007bff;outline-offset:2px;z-index:100}.canvas-date-element.dragging{opacity:.5;cursor:grabbing;z-index:1000}.date-element-input{background:transparent;border:none;outline:none;cursor:pointer;font-size:14px;color:#333;padding:6px 8px;min-width:120px}.date-element-input:focus{outline:none}.layout-table-wrap{position:absolute;z-index:2;-webkit-user-select:none;user-select:none}.layout-table-wrap.selected{outline:2px solid #2563eb;outline-offset:2px}.layout-table-wrap.dragging{opacity:.92;z-index:20}.layout-table-drag-handle{position:absolute;left:0;top:-22px;width:100%;height:18px;margin:0;padding:0;border:none;border-radius:4px 4px 0 0;background:linear-gradient(180deg,#e8eef9,#d8e2f5);cursor:grab;font-size:10px;color:#475569;line-height:18px;text-align:center;opacity:0;transition:opacity .12s ease}.layout-table-drag-handle:before{content:"⋮⋮";letter-spacing:2px}.layout-table-wrap:hover .layout-table-drag-handle,.layout-table-wrap.selected .layout-table-drag-handle{opacity:1}.layout-table-drag-handle:active{cursor:grabbing}.layout-table{border-collapse:collapse;table-layout:fixed;background:#fff;box-shadow:0 1px 3px #0f172a14}.layout-table.borderless{box-shadow:none}.layout-table-header-cell{border:1px solid #e5e7eb;padding:6px 8px;background:#f3f4f6;color:#111827;font-size:.92em}.layout-table.borderless .layout-table-header-cell{border:none}.layout-table-header-cell.active{box-shadow:inset 0 0 0 2px #3b82f6;background:#eef2ff}.layout-table-header-cell.range{box-shadow:inset 0 0 0 1px #93c5fd;background:#e0e7ff}.layout-table-cell{border:1px solid #e5e7eb;padding:4px 8px;min-width:48px;min-height:28px;vertical-align:middle;cursor:cell}.layout-table.borderless .layout-table-cell{border:none}.layout-table-cell.active{box-shadow:inset 0 0 0 2px #3b82f6;background:#f8fafc}.layout-table-cell.range{box-shadow:inset 0 0 0 1px #93c5fd;background:#eff6ff}.layout-table-cell.range.active{box-shadow:inset 0 0 0 2px #3b82f6}.layout-table-cell-input{width:100%;min-width:0;border:none;outline:none;font:inherit;color:inherit;background:transparent;box-sizing:border-box}.layout-table-cell-inner{display:block;max-width:360px}.layout-table-text{white-space:pre-wrap;word-break:break-word}.layout-table-binding-hint{font-size:.85em;color:#7c3aed;font-family:ui-monospace,monospace}.layout-table-placeholder{color:transparent}.template-canvas.export-mode .layout-table-drag-handle{display:none}.properties-panel{position:fixed;left:12px;top:68px;width:300px;background-color:#fff;border:1px solid #d7dce5;border-radius:10px;box-shadow:0 10px 24px #0f172a1a;z-index:999;max-height:calc(100vh - 52px);overflow-y:auto}.properties-panel-header{padding:12px 14px;font-weight:600;font-size:14px;border-bottom:1px solid #e5e9f1;background-color:#f6f8fc;border-radius:10px 10px 0 0;display:flex;align-items:center;justify-content:space-between}.panel-type-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#475467;background:#eaf0ff;border:1px solid #ccdaf7;border-radius:999px;padding:2px 8px}.properties-panel-empty{padding:40px 16px;text-align:center;color:#888;font-size:14px}.properties-panel-content{padding:10px}.property-section{border:1px solid #e5e9f1;border-radius:8px;padding:10px;margin-bottom:10px;background:#fcfdff}.property-section-title{font-size:12px;font-weight:700;color:#344054;margin-bottom:8px}.property-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:8px}.property-group{margin-bottom:10px}.property-group:last-child{margin-bottom:0}.property-label{display:block;margin-bottom:4px;font-size:12px;font-weight:500;color:#344054}.property-input,.property-select{width:100%;padding:7px 10px;border:1px solid #d0d5dd;border-radius:6px;font-size:13px;font-family:inherit;box-sizing:border-box;background:#fff}.property-input:focus,.property-select:focus{outline:none;border-color:#84a3e6;box-shadow:0 0 0 3px #2b66dd1f}.property-color{width:100%;height:34px;border:1px solid #d0d5dd;border-radius:6px;cursor:pointer}.property-color::-webkit-color-swatch-wrapper{padding:0}.property-color::-webkit-color-swatch{border:none;border-radius:4px}.property-button{margin-top:8px;width:100%;padding:8px 10px;border:1px solid #c9d7f2;border-radius:6px;background:#edf3ff;color:#1d4fbd;font-size:12px;font-weight:600;cursor:pointer}.property-button:hover{background:#dfeaff}.property-hint{margin:0 0 10px;font-size:12px;line-height:1.45;color:#64748b}.property-subtitle{margin-top:12px;padding-top:8px;border-top:1px solid #eef1f6;font-size:12px}.property-inline{display:flex;align-items:center;gap:8px;font-size:13px}.property-inline input[type=checkbox]{width:auto}.property-row-buttons{display:flex;gap:8px;flex-wrap:wrap}.property-button-secondary{flex:1;min-width:0;padding:6px 10px;border:1px solid #c9d7f2;border-radius:6px;background:#fff;color:#1d4fbd;font-size:12px;font-weight:600;cursor:pointer}.property-button-secondary:hover:not(:disabled){background:#f3f6ff}.property-button-secondary:disabled{opacity:.45;cursor:not-allowed}.property-textarea{width:100%;min-height:72px;padding:8px 10px;border:1px solid #d7dce5;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box}.property-textarea:focus{outline:none;border-color:#2f6adf;box-shadow:0 0 0 2px #2f6adf33}.pn-section{border:1px solid #e5e9f1;border-radius:8px;padding:10px;margin-bottom:10px;background:#fcfdff}.pn-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.pn-title{font-size:12px;font-weight:700;color:#344054}.pn-toggle{width:38px;height:20px;border-radius:999px;background:#d1d5db;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.pn-toggle--on{background:#6366f1}.pn-toggle__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.pn-toggle--on .pn-toggle__knob{transform:translate(18px)}.pn-field{margin-bottom:10px}.pn-label{display:block;font-size:12px;font-weight:600;color:#344054;margin-bottom:6px}.pn-input{width:100%;height:32px;border:1px solid #d0d5dd;border-radius:6px;padding:0 8px;font-size:13px;box-sizing:border-box}.pn-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.pn-radio-group{display:flex;flex-direction:column;gap:6px}.pn-radio-option{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;border:1px solid #e2e8f0;cursor:pointer;font-size:12px;color:#374151;transition:all .15s}.pn-radio-option--selected{border-color:#6366f1;background:#eef2ff;color:#4338ca;font-weight:600}.pn-radio-option input{accent-color:#6366f1}.pn-align-group{display:flex;gap:6px}.pn-align-btn{flex:1;height:32px;border:1px solid #d0d5dd;border-radius:6px;background:#f8fafc;cursor:pointer;font-size:14px;transition:all .15s}.pn-align-btn:hover{background:#e0e7ff;border-color:#a5b4fc}.pn-align-btn--active{background:#eef2ff;border-color:#6366f1;color:#4338ca}.pn-hint{font-size:11px;color:#64748b;margin:4px 0 0}.page-rulers{--ruler-size: 30px;--ruler-bg: #f8fafc;--ruler-border: #cbd5e1;--ruler-text: #64748b;--ruler-tick: #94a3b8;--ruler-active: #2355f4;position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:130}.page-ruler-corner{position:absolute;top:calc(var(--ruler-size) * -1);left:calc(var(--ruler-size) * -1);width:var(--ruler-size);height:var(--ruler-size);border:1px solid var(--ruler-border);border-right:none;border-bottom:none;border-radius:5px 0 0;background:var(--ruler-bg);color:#94a3b8;font-size:9px;font-weight:700;line-height:var(--ruler-size);text-align:center;text-transform:uppercase}.page-ruler{position:absolute;background:linear-gradient(180deg,#ffffffc2,#f1f5f9e0),var(--ruler-bg);border:1px solid var(--ruler-border);color:var(--ruler-text);overflow:hidden;box-shadow:inset 0 1px #ffffffb8}.page-ruler--horizontal{top:calc(var(--ruler-size) * -1);left:0;width:100%;height:var(--ruler-size);border-bottom:none;border-radius:0 5px 0 0}.page-ruler--vertical{top:0;left:calc(var(--ruler-size) * -1);width:var(--ruler-size);height:100%;border-right:none;border-radius:0 0 0 5px}.page-ruler-tick{position:absolute;background:var(--ruler-tick)}.page-ruler--horizontal .page-ruler-tick{bottom:0;width:1px;height:7px}.page-ruler--horizontal .page-ruler-tick--major{height:12px}.page-ruler--horizontal .page-ruler-tick--label{height:17px;background:#64748b}.page-ruler--vertical .page-ruler-tick{right:0;width:7px;height:1px}.page-ruler--vertical .page-ruler-tick--major{width:12px}.page-ruler--vertical .page-ruler-tick--label{width:17px;background:#64748b}.page-ruler-label{position:absolute;color:var(--ruler-text);font-size:9px;font-weight:700;line-height:1}.page-ruler-label--horizontal{top:4px;left:4px}.page-ruler-label--vertical{top:4px;right:14px;transform:rotate(-90deg);transform-origin:right center}.page-ruler-selection{position:absolute;background:#2355f41f}.page-ruler-selection--horizontal{inset-block:0}.page-ruler-selection--vertical{inset-inline:0}.page-ruler-marker{position:absolute;z-index:2;color:#fff;font-size:9px;font-weight:700;white-space:nowrap}.page-ruler-marker:before{content:"";position:absolute;background:var(--ruler-active)}.page-ruler-marker span{position:absolute;display:block;padding:2px 5px;border-radius:4px;background:var(--ruler-active);box-shadow:0 2px 8px #2355f447}.page-ruler-marker--x{top:0;height:100%}.page-ruler-marker--x:before{top:0;left:0;width:2px;height:100%}.page-ruler-marker--x span{top:4px;left:5px}.page-ruler-marker--y{left:0;width:100%}.page-ruler-marker--y:before{top:0;left:0;width:100%;height:2px}.page-ruler-marker--y span{top:5px;left:4px;transform:rotate(-90deg);transform-origin:left top}.page-ruler-guide{position:absolute;z-index:105;pointer-events:none}.page-ruler-guide--x{top:0;bottom:0;border-left:1px dashed rgba(35,85,244,.52)}.page-ruler-guide--y{left:0;right:0;border-top:1px dashed rgba(35,85,244,.52)}.page-ruler-coordinate{position:absolute;z-index:106;max-width:112px;padding:4px 7px;border:1px solid rgba(35,85,244,.22);border-radius:5px;background:#fffffff5;color:#1740d0;font-size:10px;font-weight:700;line-height:1.2;box-shadow:0 4px 12px #0f172a1f}.bep-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1100;padding:24px}.bep-panel{background:#fff;border-radius:12px;border:.5px solid #e2e8f0;box-shadow:0 20px 60px #0f172a24;width:min(540px,100%);max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden}.bep-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:.5px solid #e2e8f0;flex-shrink:0}.bep-header-left{display:flex;align-items:center;gap:10px}.bep-title{margin:0;font-size:15px;font-weight:500;color:#0f172a;line-height:1.2}.bep-subtitle{margin:3px 0 0;font-size:12px;color:#64748b}.bep-close{background:none;border:none;font-size:16px;color:#94a3b8;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}.bep-close:hover{color:#334155;background:#f1f5f9}.bep-body{flex:1;overflow-y:auto}.bep-section{padding:14px 20px;border-bottom:.5px solid #e2e8f0}.bep-section:last-child{border-bottom:none}.bep-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.bep-section-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.bep-section-hint{font-size:12px;color:#64748b;margin-bottom:10px;line-height:1.5}.bep-pill{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}.bep-pill-blue{background:#e6f1fb;color:#0c447c}.bep-pill-green{background:#eaf3de;color:#27500a}.bep-pill-amber{background:#faeeda;color:#854f0b}.bep-select{width:100%;height:32px;padding:0 10px;font-size:13px;border:.5px solid #cbd5e1;border-radius:6px;background:#fff;color:#0f172a;outline:none}.bep-select:focus{border-color:#378add}.bep-select:disabled{background:#f8fafc;color:#94a3b8}.bep-related{display:flex;align-items:center;flex-wrap:wrap;gap:5px;margin-top:8px}.bep-related-label{font-size:11px;color:#94a3b8}.bep-related-chip{display:flex;align-items:center;gap:3px;padding:2px 7px;background:#f0f4ff;border:.5px solid #c8d8f8;border-radius:4px;font-size:11px;color:#36c}.bep-related-key{color:#94a3b8;font-size:10px}.bep-input{width:100%;box-sizing:border-box;height:32px;padding:0 10px;font-size:12.5px;font-family:Menlo,Monaco,monospace;border:.5px solid #cbd5e1;border-radius:6px;outline:none;color:#0f172a;background:#fff}.bep-input:focus{border-color:#378add}.bep-input:disabled{background:#f8fafc;color:#94a3b8}.bep-code{font-family:Menlo,Monaco,monospace;font-size:11px;background:#f1f5f9;padding:1px 4px;border-radius:3px;color:#185fa5}.bep-preview-name{margin:7px 0 0;font-size:11.5px;color:#64748b}.bep-preview-label{font-weight:500;color:#475569}.bep-meta-list{display:flex;flex-direction:column;gap:1px}.bep-meta-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr) 64px;align-items:center;gap:8px;padding:5px 0}.bep-meta-key{font-family:Menlo,Monaco,monospace;font-size:11.5px;color:#185fa5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bep-meta-input{width:100%;height:28px;font-size:12px;padding:0 8px;border:.5px solid #cbd5e1;border-radius:5px;background:#fff;color:#0f172a;outline:none}.bep-meta-input:focus{border-color:#378add;box-shadow:0 0 0 2px #378add1f}.bep-meta-input:disabled{background:#f8fafc}.bep-meta-input::placeholder{color:#94a3b8;font-style:italic}.bep-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:500;text-align:center;white-space:nowrap}.bep-badge-set{background:#eaf3de;color:#27500a}.bep-badge-required{background:#f1f5f9;color:#94a3b8;border:.5px solid #e2e8f0}.bep-nav{display:flex;align-items:center;gap:6px}.bep-nav-btn{width:24px;height:24px;border:.5px solid #cbd5e1;border-radius:4px;background:#fff;color:#475569;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.bep-nav-btn:hover:not(:disabled){border-color:#378add;color:#185fa5}.bep-nav-btn:disabled{opacity:.4;cursor:not-allowed}.bep-nav-label{font-size:12px;color:#475569;min-width:40px;text-align:center}.bep-record-preview{background:#f8fafc;border:.5px solid #e2e8f0;border-radius:6px;overflow:hidden;margin-top:8px}.bep-record-row{display:flex;align-items:baseline;gap:8px;padding:5px 10px;border-bottom:.5px solid #f1f5f9}.bep-record-row:last-child{border-bottom:none}.bep-record-key{font-family:Menlo,Monaco,monospace;font-size:11px;color:#185fa5;min-width:110px;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.bep-record-val{font-size:12px;color:#334155;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bep-record-more{padding:5px 10px;font-size:11px;color:#94a3b8;font-style:italic}.bep-progress-wrap{display:flex;align-items:center;gap:10px;margin-bottom:8px}.bep-progress-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.bep-progress-fill{height:100%;background:#214883;border-radius:3px;transition:width .3s ease}.bep-progress-label{font-size:12px;color:#64748b;white-space:nowrap;min-width:55px;text-align:right}.bep-success{margin:0;font-size:12.5px;color:#166534;background:#f0fdf4;border:.5px solid #bbf7d0;padding:8px 12px;border-radius:5px}.bep-error{margin:0;font-size:12.5px;color:#991b1b;background:#fef2f2;border:.5px solid #fecaca;padding:8px 12px;border-radius:5px}.bep-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:.5px solid #e2e8f0;flex-shrink:0;background:#f8fafc}.bep-btn-primary,.bep-btn-secondary{padding:7px 16px;font-size:12px;font-weight:500;border-radius:6px;cursor:pointer}.bep-btn-primary{background:#214883;color:#fff;border:none}.bep-btn-primary:hover:not(:disabled){background:#1a3a6b}.bep-btn-primary:disabled{opacity:.5;cursor:not-allowed}.bep-btn-secondary{background:#fff;color:#475569;border:.5px solid #cbd5e1}.bep-btn-secondary:hover:not(:disabled){background:#f1f5f9}.bep-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.barcode-element{cursor:grab;border-radius:6px;border:2px solid transparent;transition:border-color .15s ease,box-shadow .15s ease;overflow:hidden;-webkit-user-select:none;user-select:none}.barcode-element:hover{border-color:#6366f159}.barcode-element--selected{border-color:#6366f1;box-shadow:0 0 0 2px #6366f12e}.barcode-element__placeholder{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fafbfc;border:1.5px dashed #cbd5e1;border-radius:4px}.barcode-element__pattern{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;color:#334155}.barcode-element__field-info{position:relative;z-index:1;display:flex;align-items:center;gap:6px;padding:4px 10px;background:#ffffffeb;border-radius:4px;border:1px solid #e2e8f0;max-width:90%}.barcode-element__icon{font-size:14px;color:#6366f1;flex-shrink:0;font-weight:700;letter-spacing:-1px}.barcode-element__field-name{font-size:12px;font-weight:600;color:#f59e0b;font-family:SF Mono,Fira Code,Consolas,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.barcode-element__field-name--literal{color:#64748b;font-style:italic}.barcode-element__badge{position:absolute;top:4px;right:4px;font-size:9px;font-weight:600;color:#6366f1;background:#6366f11a;padding:1px 5px;border-radius:3px;letter-spacing:.3px;text-transform:uppercase;pointer-events:none}.template-canvas-container{display:flex;justify-content:center;align-items:flex-start;padding:72px 320px 48px 340px;min-height:100vh;background-color:#eef1f6;box-sizing:border-box}.canvas-pages-wrapper{display:flex;flex-direction:column;align-items:center;gap:0}.canvas-page-block{display:flex;flex-direction:column;align-items:center;width:100%}.canvas-page-stage{position:relative;flex-shrink:0}.canvas-page-stage--with-rulers{margin-top:30px}.canvas-page-label{align-self:flex-start;font-size:11px;font-weight:600;color:#94a3b8;letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px;padding-left:2px}.template-canvas{background:#fff;border:1px solid #d7dce5;box-shadow:0 10px 30px #0f172a1f;border-radius:6px;position:relative;overflow:visible;transition:box-shadow .15s,border-color .15s;flex-shrink:0}.template-canvas--active{border-color:#a5b4fc;box-shadow:0 10px 30px #0f172a1f,0 0 0 2px #6366f126}.template-canvas.export-mode{border:none;box-shadow:none}.tb-shapes-item--active{background:#e0e7ff;font-weight:600}.batch-export-controls{position:fixed;top:56px;left:50%;transform:translate(-50%);z-index:900;width:min(760px,calc(100vw - 48px));padding:10px 16px;border:1px solid #d7dce5;border-radius:8px;background:#fff;box-shadow:0 2px 12px #0f172a14;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px}.batch-export-summary{font-size:13px;color:#344054}.preview-label{color:#6366f1;font-weight:500}.batch-export-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.batch-control{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#475569}.batch-control span{white-space:nowrap}.batch-control select,.batch-control input,.bulk-field-map-row select{height:30px;border:1px solid #d7dce5;border-radius:6px;background:#fff;color:#1f2937;font-size:12px;font-weight:500;padding:0 8px;outline:none}.batch-control input{width:170px}.batch-control--wide{min-width:250px}.bulk-field-map{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;max-height:116px;overflow-y:auto;padding-top:8px;border-top:1px solid #eef2f7}.bulk-field-map-row{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:center;gap:6px}.bulk-field-map-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#475569;font-size:12px;font-weight:600}.preview-nav{display:flex;align-items:center;gap:6px}.preview-nav-btn{width:28px;height:28px;border-radius:6px;border:1px solid #d7dce5;background:#f8fafc;color:#374151;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.preview-nav-btn:hover:not(:disabled){background:#e0e7ff;border-color:#a5b4fc}.preview-nav-btn:disabled{opacity:.4;cursor:not-allowed}.preview-nav-count{font-size:12px;font-weight:600;color:#374151;min-width:40px;text-align:center}.clear-button{height:30px;padding:0 12px;border-radius:6px;border:none;background:#6b7280;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.clear-button:hover{background:#4b5563}.export-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:2000;display:flex;justify-content:center;align-items:center}.export-overlay-card{background:#fff;border-radius:12px;padding:28px 32px;width:min(380px,calc(100% - 32px));box-shadow:0 20px 60px #0f172a2e;text-align:center;color:#0f172a;font-size:14px;font-weight:500}.upload-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:1500;display:flex;align-items:center;justify-content:center}.canvas-zone{position:absolute;left:0;width:100%;pointer-events:none;z-index:10}.canvas-zone--header{top:0}.batch-control-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-secondary);border-radius:6px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s}.batch-control-btn:hover{color:var(--color-text-primary);border-color:var(--color-border-primary);background:var(--color-background-secondary)}.batch-control-btn:active{background:var(--color-background-tertiary)}.mapping-collection-meta{font-weight:400;color:var(--color-text-tertiary);font-size:12px}.batch-control-btn--primary{background:#214883;color:#fff;border-color:#214883}.batch-control-btn--primary:hover:not(:disabled){background:#1a3a6b;border-color:#1a3a6b}.batch-control-btn--primary:disabled{opacity:.5;cursor:not-allowed}.batch-control-btn--bulk{background:#f0f4ff;color:#214883;border-color:#c8d8f8}.batch-control-btn--bulk:hover:not(:disabled){background:#dbe8ff;border-color:#214883}.batch-control-btn--bulk:disabled{opacity:.5;cursor:not-allowed}
