:root{color-scheme:light;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--bg-app: #f3f4f6;--bg-panel: #ffffff;--text-main: #111827;--text-muted: #6b7280;--border-color: #e5e7eb;--radius-sm: 4px;--radius-md: 8px;--shadow-canvas: 0 18px 36px rgba(17, 24, 39, .12);--shadow-popover: 0 10px 24px rgba(17, 24, 39, .16);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}*{box-sizing:border-box}body{margin:0;color:var(--text-main);background:var(--bg-app)}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app-shell{display:flex;min-width:1200px;height:100vh;flex-direction:column;overflow:hidden}.toolbar{display:flex;height:64px;flex:0 0 64px;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color);background:#ffffffeb;padding:0 16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:32px;height:32px;border-radius:7px;background:linear-gradient(135deg,#1d4ed8 0,#1d4ed8 50%,#38bdf8 50%,#38bdf8);box-shadow:inset 0 0 0 1px #fff6}.brand strong,.brand span,.brand small{display:block}.brand span{margin-top:2px;color:var(--text-muted);font-size:12px}.brand small{margin-top:1px;color:#94a3b8;font-size:11px;font-weight:500}.toolbar-back{width:34px;height:34px;min-height:34px}.toolbar-actions{display:flex;align-items:center;gap:10px}.icon-button,.ghost-button,.primary-button,.danger-button{display:inline-flex;min-height:38px;align-items:center;justify-content:center;gap:8px;border:1px solid #cfd6e1;border-radius:var(--radius-md);background:#fff;color:#111827;padding:0 14px;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}.icon-button{width:38px;padding:0}.ghost-button:hover,.icon-button:hover{border-color:#94a3b8;background:#f8fafc}.primary-button{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.primary-button:hover{border-color:var(--color-primary-hover);background:var(--color-primary-hover)}.danger-button{width:100%;border-color:#fecaca;background:#fff5f5;color:#b91c1c}.editor-layout{display:grid;min-height:0;flex:1;grid-template-columns:280px minmax(800px,1fr) 320px}.panel{min-height:0;overflow-y:auto;border-right:1px solid var(--border-color);background:var(--bg-panel)}.right-panel{display:flex;flex-direction:column;overflow:hidden;border-right:none;border-left:1px solid var(--border-color)}.right-panel>.inspector-header{flex:0 0 auto}.right-panel>.control-group{flex:1 1 auto;min-height:0;overflow-y:auto}.inspector-footer{flex:0 0 auto;background:#fffffff0;padding:8px 16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.inspector-footer .danger-button{min-height:34px}.panel-section,.inspector-header,.control-group{padding:16px}.panel-section+.panel-section,.control-group+.control-group{border-top:1px solid var(--border-color)}.panel-section h2,.inspector-header h2{margin:0 0 12px;font-size:15px;font-weight:700}.inspector-header p{margin:0;color:var(--text-muted);font-size:12px;word-break:break-all}.panel-help{margin:-4px 0 12px;color:var(--text-muted);font-size:12px;line-height:1.5}.module-library{padding-bottom:12px}.flat-library-list{display:flex;flex-direction:column;gap:6px}.flat-library-item{display:grid;width:100%;grid-template-columns:34px 1fr;align-items:center;gap:10px;border:1px solid transparent;border-radius:var(--radius-md);background:#fff;padding:8px;color:#334155;text-align:left;transition:border-color .18s ease,background-color .18s ease,color .18s ease}.flat-library-item:hover{border-color:#bfdbfe;background:var(--color-primary-light);color:var(--color-primary)}.flat-library-item.is-layout{background:#f8fafc}.flat-library-icon{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#fff}.flat-library-copy{min-width:0}.flat-library-copy strong,.flat-library-copy small{display:block}.flat-library-copy strong{font-size:13px;font-weight:700}.flat-library-copy small{margin-top:2px;overflow:hidden;color:var(--text-muted);font-size:11px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.canvas-stage{min-width:0;min-height:0;background:radial-gradient(circle at 20% 12%,rgba(37,99,235,.09),transparent 22%),radial-gradient(circle at 86% 24%,rgba(20,184,166,.09),transparent 18%),#eef2f7}.canvas-scroll{height:100%;overflow:auto;padding:36px 40px 80px}.resume-pages{display:flex;flex-direction:column;gap:28px}.resume-paper{position:relative;width:794px;height:1123px;overflow:visible;margin:0 auto;padding:var(--resume-padding);background:#fff;color:var(--resume-text-color);font-family:var(--resume-font-family);font-size:var(--resume-font-size);line-height:var(--resume-line-height);--resume-inner-gap: max(6px, calc(var(--resume-block-gap) * .56));--resume-tight-gap: max(3px, calc(var(--resume-block-gap) * .32));box-shadow:var(--shadow-canvas)}.resume-page-content{height:100%;overflow:visible;min-width:0}.canvas-empty-state{display:flex;height:100%;min-height:220px;align-items:center;justify-content:center;border:1px dashed #cbd5e1;border-radius:var(--radius-md);background:#f8fafc;color:#64748b;font-size:13px}.page-number{position:absolute;right:12px;bottom:8px;color:#94a3b8;font-family:Inter,system-ui,sans-serif;font-size:11px;pointer-events:none}.resume-measure{position:absolute;left:-10000px;top:0;width:794px;visibility:hidden;pointer-events:none}.measure-paper{height:1123px;overflow:visible;box-shadow:none}.measure-content{overflow:visible}.measure-node-wrapper,.measure-node-wrapper:hover,.measure-node-wrapper.is-active{outline:none;background:transparent}.node-wrapper{position:relative;min-width:0;max-width:100%;margin-bottom:var(--node-gap, var(--resume-block-gap));outline:1px solid transparent;outline-offset:3px;transition:background-color .18s ease,outline-color .18s ease}.node-wrapper:hover{outline-color:#60a5fa}.node-wrapper.is-active{background:#2563eb08;outline:2px solid var(--color-primary)}.node-wrapper.is-dragging{opacity:.45}.node-wrapper.drop-before:before,.node-wrapper.drop-after:after{position:absolute;right:-10px;left:-10px;height:4px;border-radius:999px;background:var(--color-primary);box-shadow:0 0 0 4px #2563eb21,0 6px 14px #2563eb42;content:"";z-index:6}.node-wrapper.drop-before:not(.drop-blocked),.node-wrapper.drop-after:not(.drop-blocked){background:#2563eb06}.node-wrapper.drop-before:before{top:calc(var(--node-gap, var(--resume-block-gap)) / -2)}.node-wrapper.drop-after:after{bottom:calc(var(--node-gap, var(--resume-block-gap)) / -2)}.node-wrapper.drop-blocked:before,.node-wrapper.drop-blocked:after{display:none}.node-wrapper.drop-blocked{cursor:not-allowed}@keyframes drop-line-pulse{0%,to{opacity:.82;transform:scaleX(.98)}50%{opacity:1;transform:scaleX(1)}}.section-body>.node-wrapper,.resume-column>.node-wrapper{--node-gap: var(--resume-inner-gap)}.resume-column .resume-column>.node-wrapper,.resume-column .section-body>.node-wrapper,.resume-section .resume-column>.node-wrapper{--node-gap: var(--resume-tight-gap)}.resume-row>.node-wrapper,.resume-column>.node-wrapper:last-child,.section-body>.node-wrapper:last-child,.resume-list .node-wrapper,.experience-content .node-wrapper{margin-bottom:0}.drag-handle{position:absolute;top:50%;left:-28px;display:none;width:22px;height:28px;align-items:center;justify-content:center;transform:translateY(-50%);border-radius:var(--radius-sm);color:#64748b;cursor:grab;background:#ffffffeb}.drag-handle:active{cursor:grabbing}.node-wrapper.is-active>.drag-handle,.node-wrapper.is-dragging>.drag-handle{display:flex}.resume-paper:has(.node-wrapper.is-dragging) .node-wrapper:not(.is-dragging)>.drag-handle{display:none}.node-bubble{position:absolute;top:-38px;right:0;display:flex;gap:4px;border:1px solid #d1d5db;border-radius:var(--radius-md);background:#fff;padding:4px;box-shadow:var(--shadow-popover);z-index:5}.node-bubble button{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:#334155}.node-bubble button:hover{background:#eff6ff;color:var(--color-primary)}.resume-row{display:grid;min-width:0;max-width:100%;align-items:start}.resume-column{min-width:0;min-height:24px;max-width:100%}.resume-heading,.section-title{margin:0;font-weight:800;letter-spacing:0}.resume-heading.level-1{font-size:26pt;line-height:1.1}.resume-heading.level-2,.section-title{font-size:15pt;line-height:1.25}.resume-heading.level-3{font-size:12.5pt;line-height:1.35}.resume-heading.with-line,.section-title{border-bottom:1.5px solid currentColor;padding-bottom:6px}.resume-text{margin:0;white-space:pre-wrap;overflow-wrap:anywhere}.editable-text{display:block;min-width:100%;outline:none;overflow-wrap:anywhere}.resume-list{margin:0;padding-left:20px}.resume-list-item{margin:2px 0;padding-left:2px}.resume-section{margin:0;min-width:0;max-width:100%}.section-body{min-width:0;max-width:100%;padding-top:10px}.empty-slot{display:flex;min-height:40px;align-items:center;justify-content:center;border:1px dashed #93c5fd;border-radius:var(--radius-md);background:#eff6ffb8;color:#2563eb;font-size:12px;line-height:1.4;text-align:center}.empty-slot.is-compact{min-height:24px;border-color:#bfdbfe;background:#eff6ff6b;font-size:11px;line-height:1.2}.empty-slot.is-compact span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-wrapper.is-active .empty-slot{border-color:#2563eb;background:#eff6ff}.resume-list>.empty-slot,.experience-content ul>.empty-slot{list-style:none;margin-left:-18px}.experience-item{display:grid;grid-template-columns:130px 1fr;gap:18px}.experience-time{color:var(--resume-muted-color);font-weight:600}.experience-content strong,.experience-content span{display:block;overflow-wrap:anywhere}.experience-content strong{color:var(--resume-text-color);font-size:11.5pt}.experience-content span{margin:2px 0 5px;color:var(--resume-muted-color)}.experience-content ul{margin:0;padding-left:18px}.image-node{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px}.image-node img,.image-placeholder{width:100%;aspect-ratio:var(--image-aspect-ratio, 1);object-fit:cover;border:1px solid #cbd5e1}.image-circle{border-radius:999px}.image-rounded{border-radius:var(--image-radius, 10px)}.image-square{border-radius:0}.image-placeholder{display:flex;align-items:center;justify-content:center;border-style:dashed;color:#94a3b8}.image-upload-button{display:inline-flex;min-height:28px;align-items:center;border:1px solid #cbd5e1;border-radius:var(--radius-sm);background:#fff;padding:0 8px;color:#334155;font-size:12px;cursor:pointer}.image-upload-button input{display:none}.upload-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#ffffffb3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:var(--color-primary);font-size:12px;font-weight:700}.crop-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172a47;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40}.crop-dialog{width:min(760px,calc(100vw - 32px));overflow:hidden;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-popover)}.crop-dialog-wide{width:min(860px,calc(100vw - 32px))}.crop-header,.crop-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px}.crop-header{border-bottom:1px solid #edf2f7}.crop-header strong,.crop-header span{display:block}.crop-header strong{font-size:15px}.crop-header span{margin-top:2px;color:var(--text-muted);font-size:12px}.crop-layout{display:grid;grid-template-columns:minmax(320px,1fr) 260px;gap:16px;padding:16px}.crop-layout-wide{grid-template-columns:420px minmax(260px,1fr)}.crop-stage{display:flex;min-height:360px;align-items:center;justify-content:center;border:1px solid #e2e8f0;border-radius:var(--radius-md);background:linear-gradient(45deg,#f8fafc 25%,transparent 25%),linear-gradient(-45deg,#f8fafc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f8fafc 75%),linear-gradient(-45deg,transparent 75%,#f8fafc 75%),#fff;background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px}.crop-frame{display:flex;width:min(320px,86%);max-height:320px;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--color-primary);background:#f8fafc;color:#94a3b8;box-shadow:0 0 0 999px #0f172a29}.crop-frame img{width:100%;height:100%;object-fit:cover;transform-origin:center;-webkit-user-select:none;user-select:none;pointer-events:none}.crop-controls{display:flex;flex-direction:column;gap:14px}.crop-control{display:flex;flex-direction:column;gap:8px}.crop-control>span:first-child{color:#374151;font-size:13px;font-weight:700}.segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.segmented-control button{min-height:34px;border:1px solid #dbe3ef;border-radius:var(--radius-sm);background:#fff;color:#475569;font-size:13px}.segmented-control button:hover,.segmented-control button.is-active{border-color:#bfdbfe;background:#eff6ff;color:var(--color-primary)}.crop-footer{justify-content:flex-end;border-top:1px solid #edf2f7}.free-crop-stage{position:relative;overflow:hidden;border:1px solid #e2e8f0;border-radius:var(--radius-md);background:#f8fafc;touch-action:none}.free-crop-image{position:absolute;top:50%;left:50%;width:100%;height:100%;object-fit:contain;transform-origin:center;translate:-50% -50%;cursor:grab;-webkit-user-select:none;user-select:none}.free-crop-image:active{cursor:grabbing}.free-crop-image.is-disabled{cursor:default}.crop-shade{position:absolute;background:#0f172a75;pointer-events:none}.free-crop-box{position:absolute;border:2px solid #fff;box-shadow:0 0 0 1px var(--color-primary),0 0 0 999px #0f172a0a;cursor:move}.free-crop-box:before,.free-crop-box:after,.free-crop-box span:before,.free-crop-box span:after{position:absolute;background:#ffffffb8;content:""}.free-crop-box:before,.free-crop-box:after{top:33.333%;bottom:33.333%;width:1px}.free-crop-box:before{left:33.333%}.free-crop-box:after{right:33.333%}.free-crop-box span:before,.free-crop-box span:after{right:33.333%;left:33.333%;height:1px}.free-crop-box span:before{top:33.333%}.free-crop-box span:after{bottom:33.333%}.crop-resize-handle{position:absolute;right:-8px;bottom:-8px;width:18px;height:18px;border:2px solid #fff;border-radius:999px;background:var(--color-primary);box-shadow:0 2px 8px #0f172a3d;cursor:nwse-resize}.segmented-control.is-dense{grid-template-columns:repeat(3,minmax(0,1fr))}.segmented-control button:disabled{background:#f8fafc;color:#cbd5e1}.roundness-grid,.crop-tool-grid{display:grid;gap:6px}.roundness-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.crop-tool-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.roundness-grid button,.crop-tool-grid button{display:inline-flex;min-height:34px;align-items:center;justify-content:center;gap:6px;border:1px solid #dbe3ef;border-radius:var(--radius-sm);background:#fff;color:#475569;font-size:13px}.roundness-grid button:hover,.roundness-grid button.is-active,.crop-tool-grid button:hover{border-color:#bfdbfe;background:#eff6ff;color:var(--color-primary)}.crop-bottom-tools{display:flex;justify-content:center;gap:8px;margin-top:12px}.crop-bottom-tools button{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border:1px solid #dbe3ef;border-radius:var(--radius-sm);background:#fff;color:#475569;padding:0}.crop-bottom-tools button:hover{border-color:#bfdbfe;background:#eff6ff;color:var(--color-primary)}.control-group{display:flex;flex-direction:column;gap:15px}.field{display:grid;grid-template-columns:78px minmax(0,1fr);align-items:center;gap:10px;color:#374151}.field span,.switch-row{color:#374151;font-size:13px}.text-control,.field input:not([type=range]):not([type=color]):not([type=checkbox]),.field select{min-width:0;height:36px;border:1px solid #cfd6e1;border-radius:var(--radius-md);background:#fff;color:#111827;padding:0 11px;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.text-control:hover,.field input:not([type=range]):not([type=color]):not([type=checkbox]):hover,.field select:hover{border-color:#94a3b8;background:#f8fafc}.text-control:focus,.field input:not([type=range]):not([type=color]):not([type=checkbox]):focus,.field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1f;outline:none}.select-field select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:32px}.select-control{position:relative;display:block;min-width:0}.select-control svg{position:absolute;top:50%;right:10px;transform:translateY(-50%);color:#64748b;pointer-events:none}.range-field{align-items:start}.range-control{display:grid;min-width:0;grid-template-columns:minmax(0,1fr) 54px;align-items:center;gap:10px}.control-range{width:100%;height:24px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}.control-range::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:linear-gradient(90deg,var(--color-primary) 0 var(--range-progress, 50%),#e2e8f0 var(--range-progress, 50%) 100%)}.control-range::-webkit-slider-thumb{width:16px;height:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid #fff;border-radius:999px;background:var(--color-primary);box-shadow:0 1px 5px #0f172a47;margin-top:-5px}.control-range::-moz-range-track{height:6px;border-radius:999px;background:#e2e8f0}.control-range::-moz-range-progress{height:6px;border-radius:999px;background:var(--color-primary)}.control-range::-moz-range-thumb{width:14px;height:14px;border:2px solid #fff;border-radius:999px;background:var(--color-primary);box-shadow:0 1px 5px #0f172a47}.range-control strong{justify-self:end;border:1px solid #dbe3ef;border-radius:var(--radius-sm);background:#f8fafc;color:#475569;padding:3px 7px;font-size:12px;font-weight:800;line-height:1.2;white-space:nowrap}.color-field{grid-template-columns:78px minmax(0,1fr);align-items:start}.color-control{display:grid;min-width:0;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:8px}.color-control input[type=color]{width:42px;height:36px;border:1px solid #cfd6e1;border-radius:var(--radius-md);background:#fff;padding:2px}.color-control input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-control input[type=color]::-webkit-color-swatch{border:none;border-radius:6px}.color-value{display:inline-flex;min-width:0;height:36px;align-items:center;gap:8px;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#f8fafc;padding:0 9px;color:#334155;font-size:12px;font-weight:700}.color-hex-input{width:100%;min-width:0;height:100%;border:none!important;background:transparent!important;box-shadow:none!important;padding:0!important;color:#334155;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;font-weight:700}.color-hex-input:focus{outline:none}.color-value i{width:14px;height:14px;flex:0 0 auto;border:1px solid rgba(15,23,42,.16);border-radius:999px}.color-swatches{grid-column:2;display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.color-swatches button{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;border:1px solid rgba(15,23,42,.16);border-radius:999px;color:#fff;padding:0;box-shadow:inset 0 0 0 1px #ffffff59}.color-swatches button.is-active{border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb29,inset 0 0 0 1px #ffffff6b}.switch-row{display:flex;align-items:center;gap:8px}.switch-row input{width:16px;height:16px;accent-color:var(--color-primary)}.inspector-note{border:1px solid #bfdbfe;border-radius:var(--radius-md);background:#eff6ff;padding:10px 12px;color:#1d4ed8;font-size:13px;line-height:1.5}.column-editor{display:flex;flex-direction:column;gap:12px}.column-preview{display:grid;min-height:36px;gap:4px;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#f8fafc;padding:4px}.column-preview span{display:flex;min-width:0;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#dbeafe;color:#1d4ed8;font-size:12px;font-weight:700}.column-ratio-field{position:relative;grid-template-columns:30px 38px minmax(0,1fr) 86px;gap:8px;border:1px solid #edf2f7;border-radius:var(--radius-sm);background:#fff;padding:5px 8px}.column-ratio-field:hover{border-color:#bfdbfe;background:#f8fafc}.column-ratio-grip{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;justify-self:center;border:1px solid #dbe3ef;border-radius:var(--radius-sm);background:#ffffffeb;color:#94a3b8;cursor:grab}.column-ratio-field:hover .column-ratio-grip{border-color:#cbd5e1;color:#64748b}.column-ratio-label{color:#475569;font-size:12px;font-weight:700;white-space:nowrap}.column-ratio-grip:active{cursor:grabbing}.column-ratio-field[data-drop-position=before]:before,.column-ratio-field[data-drop-position=after]:after{position:absolute;right:0;left:0;height:2px;border-radius:999px;background:var(--color-primary);box-shadow:0 0 0 3px #2563eb29,0 0 10px #2563eb52;content:"";z-index:2}.column-ratio-field[data-drop-position=before]:before{top:-4px}.column-ratio-field[data-drop-position=after]:after{bottom:-4px}.number-stepper{display:inline-grid;min-width:0;height:36px;grid-template-columns:28px minmax(36px,1fr) 28px;overflow:hidden;border:1px solid #cfd6e1;border-radius:var(--radius-md);background:#fff}.number-stepper.is-compact{height:32px;grid-template-columns:24px 34px 24px}.number-stepper button{display:inline-flex;align-items:center;justify-content:center;border:none;background:#f8fafc;color:#475569;padding:0}.number-stepper button:hover:not(:disabled){background:#eff6ff;color:var(--color-primary)}.number-stepper input{width:100%;min-width:0;height:100%;border:none!important;border-right:1px solid #e2e8f0!important;border-left:1px solid #e2e8f0!important;border-radius:0!important;box-shadow:none!important;padding:0 4px!important;text-align:center}.number-stepper input::-webkit-outer-spin-button,.number-stepper input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.toast{position:fixed;right:24px;bottom:24px;max-width:360px;border:1px solid #cbd5e1;border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-popover);padding:12px 14px;color:#111827;text-align:left;z-index:20}.toast.success{border-color:#bbf7d0;color:#166534}.toast.error{border-color:#fecaca;color:#b91c1c}.auth-shell,.home-shell{min-height:100vh;background:linear-gradient(180deg,#eff6ffe6,#f3f4f6f2),#f3f4f6}.auth-shell{display:flex;align-items:center;justify-content:center;padding:32px}.auth-panel,.loading-card{width:min(420px,100%);border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#fffffff5;box-shadow:var(--shadow-popover)}.auth-panel{padding:28px}.loading-card{padding:20px;color:#475569;text-align:center}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand strong,.auth-brand span{display:block}.auth-brand strong{font-size:16px}.auth-brand span{margin-top:2px;color:var(--text-muted);font-size:12px}.auth-panel h1{margin:26px 0 8px;font-size:28px;line-height:1.15;letter-spacing:0}.auth-panel p{margin:0 0 24px;color:var(--text-muted);font-size:14px;line-height:1.65}.auth-field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.auth-field span{color:#374151;font-size:13px;font-weight:700}.auth-field input,.search-box input{min-width:0;height:40px;border:1px solid #cfd6e1;border-radius:var(--radius-md);background:#fff;color:#111827;padding:0 12px;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.auth-field input:focus,.search-box input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1f;outline:none}.auth-submit{width:100%;min-height:42px;margin-top:6px}.auth-message,.dev-code,.workspace-error{border-radius:var(--radius-md);padding:10px 12px;font-size:13px;line-height:1.45}.auth-message{margin-bottom:12px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8}.dev-code{margin-bottom:12px;border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.home-shell{display:flex;flex-direction:column;color:var(--text-main)}.home-topbar{display:flex;height:64px;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color);background:#ffffffeb;padding:0 28px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-actions{display:flex;align-items:center;gap:10px}.home-main{width:min(1180px,calc(100vw - 48px));margin:0 auto;padding:30px 0 56px}.workspace-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:22px}.workspace-head h1{margin:0;font-size:28px;line-height:1.2;letter-spacing:0}.workspace-head p{margin:6px 0 0;color:var(--text-muted);font-size:14px}.search-box{position:relative;display:flex;width:280px;align-items:center}.search-box svg{position:absolute;left:12px;color:#94a3b8;pointer-events:none}.search-box input{width:100%;padding-left:38px}.workspace-error{margin-bottom:18px;border:1px solid #fecaca;background:#fff5f5;color:#b91c1c}.resume-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(206px,1fr));gap:18px}.resume-card,.resume-create-card{display:flex;min-height:236px;flex-direction:column;align-items:stretch;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#fffffff5;padding:12px;color:#111827;text-align:left;box-shadow:0 1px 2px #0f172a0a;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.resume-card:hover,.resume-create-card:hover{border-color:#93c5fd;box-shadow:0 12px 24px #2563eb1f;transform:translateY(-2px)}.resume-create-card{align-items:center;justify-content:center;gap:8px;border-style:dashed;background:#f8fafc;text-align:center}.resume-create-card span{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border:1px solid #bfdbfe;border-radius:var(--radius-md);background:#eff6ff;color:var(--color-primary)}.resume-create-card strong,.resume-card strong{margin-top:12px;overflow:hidden;font-size:15px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.resume-create-card small,.resume-card small{margin-top:5px;color:var(--text-muted);font-size:12px}.resume-card-preview{position:relative;display:flex;height:158px;align-items:center;justify-content:center;overflow:hidden;border:1px solid #e2e8f0;border-radius:var(--radius-sm);background:linear-gradient(90deg,transparent 0 32%,rgba(37,99,235,.08) 32% 34%,transparent 34%),repeating-linear-gradient(180deg,#fff 0,#fff 18px,#f8fafc 18px,#f8fafc 19px);color:#2563eb}.resume-card-preview:before{position:absolute;top:22px;left:26px;width:88px;height:10px;border-radius:999px;background:#1d4ed8;content:""}.resume-card-preview:after{position:absolute;right:24px;bottom:24px;width:70px;height:9px;border-radius:999px;background:#bae6fd;box-shadow:-16px -20px #dbeafe,-52px -40px #e2e8f0;content:""}.resume-card-spark{position:absolute;top:14px;right:14px;color:#0f766e}.skeleton-card{background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent),#e5e7eb;background-size:220% 100%,auto;animation:skeleton-move 1.2s infinite linear}@keyframes skeleton-move{0%{background-position:220% 0,0 0}to{background-position:-220% 0,0 0}}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172a3d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:30}.confirm-dialog{display:grid;width:min(360px,calc(100vw - 32px));grid-template-columns:38px 1fr;gap:12px;border:1px solid #dbe3ef;border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-popover);padding:16px}.confirm-dialog-mark{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid #fecaca;border-radius:var(--radius-md);background:#fff5f5;color:#b91c1c;font-size:18px;font-weight:900}.confirm-dialog-copy{min-width:0}.confirm-dialog-copy h3{margin:0;color:#111827;font-size:15px;line-height:1.35}.confirm-dialog-copy p{margin:6px 0 0;color:#64748b;font-size:13px;line-height:1.55}.confirm-dialog-actions{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}.confirm-dialog-actions .danger-button,.confirm-dialog-actions .ghost-button{width:100%;min-height:36px}@media (max-width: 1240px){.app-shell{overflow-x:auto}}@media print{body{background:#fff}.toolbar,.left-panel,.right-panel,.toast,.drag-handle,.node-bubble,.page-number,.resume-measure,.image-upload-button{display:none!important}.app-shell,.editor-layout,.canvas-stage,.canvas-scroll{display:block;width:auto;height:auto;min-width:0;overflow:visible;padding:0;background:#fff}.resume-paper{width:210mm;height:297mm;margin:0;box-shadow:none;break-after:page;page-break-after:always}.resume-paper:last-child{break-after:auto;page-break-after:auto}.node-wrapper,.node-wrapper:hover,.node-wrapper.is-active{background:transparent!important;outline:none!important}.editable-text{caret-color:transparent}@page{size:A4;margin:0}}
