@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;500&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-sm:.25rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.fixed{position:fixed}.flex{display:flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.italic{font-style:italic}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--bg:#f5f5f7;--bg-subtle:#ebebed;--panel:#ffffffd9;--raised:#fff;--hover:#0000000a;--border:#00000014;--border-hi:#00000024;--text:#1d1d1f;--text-sec:#424245;--text-muted:#86868b;--text-dim:#c7c7cc;--accent:#007aff;--accent-soft:#007aff14;--accent-glow:#007aff24;--gold:#ff9f0a;--gold-soft:#ff9f0a14;--success:#34c759;--danger:#ff3b30;--danger-soft:#ff3b3014;--font-ui:"Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", monospace;--radius-sm:8px;--radius:12px;--radius-lg:18px;--topbar-h:56px;--sidebar-w:240px;--sidebar-rail-w:84px;--editor-w:340px;--drawer-w:380px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 16px #00000014, 0 1px 4px #0000000a;--shadow-lg:0 12px 40px #0000001a, 0 4px 12px #0000000d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:13px;line-height:1.5}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}input,textarea,select{font:inherit;color:inherit;background:0 0;border:none;outline:none}::selection{background:var(--accent-soft);color:var(--text)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.layout{background:var(--bg);flex-direction:column;height:100%;display:flex}.workspace{grid-template-columns:var(--sidebar-w) 1fr;flex:1;min-height:0;transition:grid-template-columns .42s cubic-bezier(.16,1,.3,1);display:grid}.workspace--sidebar-collapsed{grid-template-columns:var(--sidebar-rail-w) 1fr}.workspace-main{min-width:0;position:relative;overflow:hidden}.workspace-main:before{content:"";pointer-events:none;opacity:.85;background:radial-gradient(circle at 100% 0,#007aff14,#0000 30%),radial-gradient(circle at 0 100%,#ffffffa6,#0000 35%);position:absolute;inset:0}.workspace-main--inspector-open .canvas-phone-frame{transform:translate(-32px)scale(.965)}.loading{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.loading:before{content:"";border:2px solid var(--border-hi);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.topbar{height:var(--topbar-h);background:var(--panel);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(24px)saturate(1.8);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:relative}.topbar-left{align-items:center;gap:14px;display:flex}.topbar-nav-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-sec);letter-spacing:-.01em;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;transition:all .18s;display:inline-flex}.topbar-nav-btn:hover:not(:disabled){color:var(--text);border-color:var(--border-hi);background:var(--raised);box-shadow:var(--shadow-sm)}.topbar-nav-btn:disabled{opacity:.45;cursor:default;box-shadow:none}.topbar-logo{letter-spacing:-.03em;align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.topbar-logo-icon{color:#fff;background:linear-gradient(145deg,#007aff 0%,#0055d4 100%);border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 8px #007aff59,inset 0 1px #fff3}.topbar-logo-text{color:var(--text);letter-spacing:-.03em;font-weight:700}.topbar-logo-img{width:auto;height:20px;display:block}.topbar-divider{background:var(--border-hi);width:1px;height:18px}.topbar-title{color:var(--text-muted);letter-spacing:-.01em;border-bottom:1px solid #0000;padding:4px 0;font-size:14px;font-weight:500;transition:all .2s}.topbar-title:hover{color:var(--text);border-bottom-color:var(--border-hi)}.topbar-title-input{color:var(--text);border-radius:var(--radius-sm);background:var(--raised);border:1.5px solid var(--accent);width:260px;box-shadow:0 0 0 3px var(--accent-soft);padding:6px 12px;font-size:14px;font-weight:500}.topbar-right{align-items:center;gap:8px;display:flex}.topbar-btn{border-radius:var(--radius-sm);letter-spacing:-.01em;padding:7px 20px;font-size:13px;font-weight:600;transition:all .2s}.topbar-btn--ghost{color:var(--text-sec);background:0 0}.topbar-btn--ghost:hover{background:var(--hover);color:var(--text)}.topbar-save-btn{position:relative;overflow:hidden}.topbar-save-label,.topbar-save-check{align-items:center;gap:5px;transition:transform .5s cubic-bezier(.65,0,.35,1),opacity .4s;display:flex}.topbar-save-check{color:var(--success);opacity:0;justify-content:center;position:absolute;inset:0;transform:translateY(120%)}.topbar-save-btn--saved .topbar-save-label{opacity:0;transform:translateY(-120%)}.topbar-save-btn--saved .topbar-save-check{opacity:1;transform:translateY(0)}.topbar-save-btn--error{color:var(--danger)}.topbar-save-btn--saving{opacity:.5;transition:opacity .3s}.topbar-btn--outlined{color:var(--accent);background:var(--accent-soft);border:1px solid #007aff33}.topbar-btn--outlined:hover{border-color:var(--accent);background:#007aff1f}.topbar-btn--primary{color:#fff;background:var(--accent);box-shadow:0 2px 8px #007aff4d}.topbar-btn--primary:hover{background:#0066d6;transform:translateY(-1px);box-shadow:0 4px 16px #007aff66}.topbar-btn--primary:active{transform:translateY(0)}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;transition:width .42s cubic-bezier(.16,1,.3,1),background .28s;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.sidebar-header-copy,.sidebar-header-actions{align-items:center;gap:8px;display:flex}.sidebar-header-copy{transform-origin:0 0;max-height:36px;transition:opacity .24s,transform .4s cubic-bezier(.16,1,.3,1),max-height .4s cubic-bezier(.16,1,.3,1)}.sidebar-label{letter-spacing:.04em;text-transform:uppercase;color:var(--text-sec);font-size:11px;font-weight:600}.sidebar-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text);text-align:center;flex:1;font-size:22px;font-weight:700}.sidebar-count{min-width:22px;height:22px;color:var(--accent);background:var(--accent-soft);border-radius:999px;justify-content:center;align-items:center;padding:0 7px;font-size:11px;font-weight:600;display:inline-flex}.sidebar-toggle{width:28px;height:28px;color:var(--text-muted);background:0 0;border-radius:999px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.sidebar-toggle:hover{color:var(--text);background:var(--hover)}.sidebar-list{flex:1;padding:10px 8px;overflow-y:auto}.sidebar-empty{color:var(--text-dim);text-align:center;padding:40px 16px;font-size:12px;line-height:1.9}.sidebar-item{border-radius:var(--radius-sm);text-align:center;cursor:pointer;background:0 0;border:2px solid #0000;flex-direction:column;align-items:center;width:100%;margin-bottom:6px;padding:8px;transition:background .18s,border-color .18s;display:flex;position:relative}.sidebar-item:hover{background:var(--bg-subtle);border-color:var(--border-hi)}.sidebar-item.active{background:var(--accent-soft);border-color:var(--accent)}.sidebar-item.active .step-num{color:var(--accent);font-weight:600}.sidebar-item--add{border-style:dashed;border-color:var(--border)}.sidebar-item--add:hover{background:var(--bg-subtle);border-color:var(--border-hi)}.sidebar-item-inner{flex-direction:column;align-items:center;gap:7px;width:100%;display:flex}.step-num{font-family:var(--font-ui);color:var(--text-muted);letter-spacing:.02em;font-size:10px;font-weight:500}.step-thumb{background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:82px;height:178px;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.step-thumb img{object-fit:cover;object-position:center top;width:100%;height:100%}.step-thumb-empty{color:var(--text-dim);font-size:11px}.step-thumb--add{border:1px dashed var(--border-hi);box-shadow:none;flex-direction:column;gap:6px}.step-add-plus{color:var(--text-muted);font-size:34px;font-weight:400;line-height:1}.sidebar-item--add:hover .step-add-plus{color:var(--text)}.step-add-label{letter-spacing:.01em;color:var(--text-dim);font-size:11px;font-weight:500;line-height:1}.sidebar-item--add:hover .step-add-label{color:var(--text-muted)}.thumb-overlay{pointer-events:none;position:absolute;inset:0}.thumb-hotspot{background:#007aff;border:1.5px solid #fff;border-radius:50%;width:6px;height:6px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 1.5px #007aff80}.thumb-focus{background:#ff9f0a1f;border:1.5px solid;border-radius:2px;position:absolute}.step-delete{color:var(--text-muted);opacity:0;border:1px solid var(--border);background:#ffffffe6;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:13px;line-height:1;transition:all .15s;display:flex;position:absolute;top:5px;right:5px}.sidebar-item:hover .step-delete{opacity:1}.step-delete:hover{color:var(--danger);background:var(--danger-soft);border-color:#0000}.sidebar-item--dragging{opacity:.35;transform:scale(.95)}.sidebar-item--dragover{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent-soft)!important}.sidebar--collapsed .sidebar-header{flex-direction:column;gap:10px;padding:14px 10px 12px}.sidebar--collapsed .sidebar-header-copy{opacity:0;pointer-events:none;max-height:0;overflow:hidden;transform:translateY(-6px)}.sidebar--collapsed .sidebar-list{padding:8px 6px}.sidebar--collapsed .sidebar-empty{display:none}.sidebar--collapsed .sidebar-toggle svg{transform:rotate(180deg)}.sidebar-item--collapsed{padding:6px 4px}.sidebar-item--collapsed .step-thumb{width:46px;height:100px;box-shadow:none;border-radius:6px}.sidebar-item--collapsed .step-num{font-size:9px}.sidebar--collapsed .step-delete{display:none}.canvas{background:radial-gradient(circle at 20% 20%, #fffc, transparent 24%), radial-gradient(circle at 80% 80%, #007aff14, transparent 28%), var(--bg-subtle);justify-content:center;align-items:center;transition:background .2s,transform .28s cubic-bezier(.22,1,.36,1);display:flex;position:relative;overflow:visible}.canvas--empty{color:var(--text-dim);font-size:14px}.canvas--drag{background:var(--accent-soft)}.canvas-phone-frame{height:calc(100vh - var(--topbar-h) - 48px);aspect-ratio:421/850;filter:drop-shadow(0 18px 48px #0f172a3d);background:0 0;transition:transform .42s cubic-bezier(.16,1,.3,1),box-shadow .25s;position:relative;overflow:visible}.canvas-phone-inner{z-index:auto;background:#000;border-radius:12.267%/5.665%;width:89.074%;height:95.529%;position:absolute;top:2.118%;left:5.225%;overflow:visible}.canvas-phone-shell{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2;width:100%;height:100%;position:absolute;inset:0}.canvas-image-clip{border-radius:inherit;z-index:1;background:#000;position:absolute;inset:0;overflow:hidden}.canvas-image-clip:after{content:"";pointer-events:none;background:linear-gradient(#ffffff14,#0000 18% 82%,#0000000f);position:absolute;inset:0}.canvas-hint{z-index:5;color:#fff;-webkit-backdrop-filter:blur(16px);background:linear-gradient(135deg,#0f172adb,#007affc2);border-radius:16px;flex-direction:column;gap:3px;padding:12px 14px;display:flex;position:absolute;top:18px;left:18px;right:18px;box-shadow:0 10px 24px #0f172a38}.canvas-hint-kicker{letter-spacing:.1em;text-transform:uppercase;opacity:.7;font-size:10px;font-weight:700}.canvas-hint strong{font-size:13px;font-weight:700}.canvas-hint span:last-child{opacity:.82;font-size:11px;line-height:1.45}.canvas-phone-image{object-fit:cover;object-position:center top;cursor:crosshair;width:100%;height:100%;display:block}.ann-hotspot{cursor:grab;z-index:10;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:transform .15s,box-shadow .15s;animation:2.5s ease-in-out infinite hotspot-pulse;display:flex;position:absolute;transform:translate(-50%,-50%)}.ann-hotspot:active{cursor:grabbing}.ann-hotspot-core{background:var(--hotspot-color,var(--accent));width:16px;height:16px;box-shadow:0 0 0 4px rgba(var(--hotspot-rgb,0 122 255) / .2), 0 2px 6px #0003;border:2.5px solid #fff;border-radius:999px}.ann-focus{cursor:move;z-index:7;background:0 0;border:4px solid;border-radius:18px;position:absolute;overflow:visible;box-shadow:0 0 0 999px #0f172a17}.ann-focus:before,.ann-focus:after{content:"";border:3px solid rgb(var(--focus-rgb,255 159 10) / .65);box-shadow:0 0 0 2px rgb(var(--focus-rgb,255 159 10) / .2);pointer-events:none;transform-origin:50%;border-radius:24px;animation:1.8s ease-out infinite focus-ripple;position:absolute;inset:-8px}.ann-focus:after{animation-delay:.95s}.ann-focus--selected{box-shadow:0 0 0 2px #ffffff9e, 0 0 0 6px rgb(var(--focus-rgb,255 159 10) / .22), 0 0 0 999px #0f172a21}.ann-menu-handle{width:12px;height:12px;color:inherit;box-shadow:var(--shadow-sm);z-index:10;opacity:.75;background:#fff;border:1.5px solid;border-radius:3px;position:absolute}.ann-menu-handle:hover{opacity:1}.ann-menu-handle--n{cursor:ns-resize;top:-7px;left:calc(50% - 6px)}.ann-menu-handle--ne{cursor:nesw-resize;top:-7px;right:-7px}.ann-menu-handle--e{cursor:ew-resize;top:calc(50% - 6px);right:-7px}.ann-menu-handle--se{cursor:nwse-resize;bottom:-7px;right:-7px}.ann-menu-handle--s{cursor:ns-resize;bottom:-7px;left:calc(50% - 6px)}.ann-menu-handle--sw{cursor:nesw-resize;bottom:-7px;left:-7px}.ann-menu-handle--w{cursor:ew-resize;top:calc(50% - 6px);left:-7px}.ann-menu-handle--nw{cursor:nwse-resize;top:-7px;left:-7px}.ann-focus-handle{width:12px;height:12px;color:inherit;box-shadow:var(--shadow-sm);z-index:1;background:#fff;border:1.5px solid;border-radius:3px;position:absolute}.ann-focus-handle--n{cursor:ns-resize;top:-7px;left:calc(50% - 6px)}.ann-focus-handle--ne{cursor:nesw-resize;top:-7px;right:-7px}.ann-focus-handle--e{cursor:ew-resize;top:calc(50% - 6px);right:-7px}.ann-focus-handle--se{cursor:nwse-resize;bottom:-7px;right:-7px}.ann-focus-handle--s{cursor:ns-resize;bottom:-7px;left:calc(50% - 6px)}.ann-focus-handle--sw{cursor:nesw-resize;bottom:-7px;left:-7px}.ann-focus-handle--w{cursor:ew-resize;top:calc(50% - 6px);left:-7px}.ann-focus-handle--nw{cursor:nwse-resize;top:-7px;left:-7px}@keyframes focus-ripple{0%{opacity:.9;transform:scale(.97)}65%{opacity:.22;transform:scale(1.15)}to{opacity:0;transform:scale(1.27)}}.ann-hotspot--selected{animation:none;transform:translate(-50%,-50%)scale(1.2)}.ann-hotspot--selected .ann-hotspot-core{box-shadow:0 0 0 6px rgba(var(--hotspot-rgb,0 122 255) / .25), 0 2px 8px #00000040}@keyframes hotspot-pulse{0%,to{filter:drop-shadow(0 0 #007aff33)}50%{filter:drop-shadow(0 0 6px #007aff40)}}.ann-menu{cursor:grab;z-index:9;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(12px);border:1.5px solid #0000;border-radius:10px;width:42%;min-width:140px;max-width:min(86%,560px);min-height:88px;padding:10px 14px 12px;transition:box-shadow .15s,transform .15s,border-color .15s;position:absolute;transform:translateY(0);box-shadow:0 4px 20px #0000002e,0 1px 4px #0000001a}.ann-menu:active{cursor:grabbing}.ann-menu:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0000002e,0 2px 6px #00000014}.ann-menu--selected{box-shadow:0 4px 24px #00000038,0 0 0 2px #007aff4d}.ann-menu-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.ann-menu-pointer{background:inherit;width:18px;height:18px;position:absolute;transform:rotate(45deg)}.ann-menu-pointer--top{top:-9px;left:calc(var(--pointer-offset) - 9px)}.ann-menu-pointer--bottom{bottom:-9px;left:calc(var(--pointer-offset) - 9px)}.ann-menu-pointer--left{left:-9px;top:calc(var(--pointer-offset) - 9px)}.ann-menu-pointer--right{right:-9px;top:calc(var(--pointer-offset) - 9px)}.ann-menu-grip{background:#0000001f;border-radius:999px;width:34px;height:5px}.ann-menu-chip{letter-spacing:.08em;text-transform:uppercase;color:#0000007a;background:#ffffff8c;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:700}.ann-menu-text{pointer-events:none;word-wrap:break-word;margin:0;line-height:1.5}.ann-menu-footer{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.ann-menu-btn{letter-spacing:.01em;border:1px solid #0000;border-radius:7px;min-width:58px;height:28px;font-size:11px;font-weight:600;transition:all .16s}.ann-menu-btn:disabled{opacity:.4;cursor:not-allowed}.ann-menu-btn--secondary{color:#000000a3;background:#ffffffbd;border-color:#00000014}.ann-menu-btn--secondary:hover:not(:disabled){background:#fffffff2}.ann-menu-btn--primary{color:#fff;background:#007affeb;border-color:#0060d6e6}.ann-menu-btn--primary:hover:not(:disabled){background:#006ce7f2}.ann-menu-placeholder{opacity:.35}.ann-delete{background:var(--danger);color:#fff;z-index:12;width:20px;height:20px;box-shadow:var(--shadow-sm);border-radius:999px;justify-content:center;align-items:center;font-size:13px;transition:transform .1s;display:flex;position:absolute;top:-9px;right:-9px}.ann-delete:hover{transform:scale(1.15)}.style-sidebar-enter{animation:.42s cubic-bezier(.16,1,.3,1) sidebarIn}@keyframes sidebarIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.canvas-replace-btn{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--text-sec);cursor:pointer;box-shadow:var(--shadow-sm);white-space:nowrap;z-index:5;background:#ffffffe0;border-radius:999px;padding:5px 14px;font-size:11px;font-weight:500;transition:all .2s;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.canvas-replace-btn:hover{color:var(--accent);border-color:var(--accent);background:#fffffffa}.canvas-dropzone{cursor:pointer;justify-content:center;align-items:center;width:100%;height:100%;transition:all .2s;display:flex}.dropzone-content{pointer-events:none;border:2px dashed var(--border-hi);border-radius:var(--radius-lg);background:var(--raised);box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:14px;padding:52px 60px;transition:all .22s;display:flex}.canvas-dropzone:hover .dropzone-content{border-color:var(--accent);background:var(--raised);box-shadow:var(--shadow), 0 0 0 4px var(--accent-soft)}.dropzone-icon{background:var(--accent-soft);width:56px;height:56px;color:var(--accent);border-radius:16px;justify-content:center;align-items:center;font-size:24px;transition:all .22s;display:flex}.canvas-dropzone:hover .dropzone-icon{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 16px #007aff4d}.dropzone-text{color:var(--text-sec);letter-spacing:-.02em;font-size:15px;font-weight:600;transition:color .2s}.canvas-dropzone:hover .dropzone-text{color:var(--text)}.dropzone-sub{color:var(--text-muted);font-size:12px}.editor{background:var(--panel);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--border);flex-direction:column;display:flex;overflow-y:auto}.editor--empty{color:var(--text-dim);justify-content:center;align-items:center;font-size:14px}.style-drawer{z-index:20;pointer-events:none;position:absolute;inset:0}.style-drawer-scrim{opacity:0;pointer-events:none;background:linear-gradient(90deg,#0000,#0f172a14 45%,#0f172a29);transition:opacity .42s cubic-bezier(.16,1,.3,1);position:absolute;inset:0}.style-drawer-panel{width:min(var(--drawer-w), calc(100% - 36px));-webkit-backdrop-filter:blur(24px)saturate(1.35);opacity:0;pointer-events:auto;background:#ffffffbd;border:1px solid #ffffff75;border-radius:24px;transition:transform .42s cubic-bezier(.16,1,.3,1),opacity .32s;position:absolute;top:18px;bottom:18px;right:18px;overflow:hidden;transform:translate(calc(100% + 28px));box-shadow:0 18px 50px #0f172a29}.style-drawer--open .style-drawer-scrim{opacity:1}.style-drawer--open .style-drawer-panel{opacity:1;transform:translate(0)}.style-drawer-header{background:linear-gradient(#ffffffb8,#ffffff4d);border-bottom:1px solid #0000000f;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 20px 14px;display:flex}.style-drawer-heading{flex-direction:column;gap:2px;display:flex}.style-drawer-heading strong{letter-spacing:-.03em;font-size:18px}.style-drawer-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:10px;font-weight:700}.style-drawer-copy{color:var(--text-muted);font-size:12px}.style-drawer-close{width:34px;height:34px;color:var(--text-muted);background:#ffffffb8;border:1px solid #0000000f;border-radius:999px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.style-drawer-close:hover{color:var(--text);box-shadow:var(--shadow-sm);background:#fff}.style-drawer .editor{-webkit-backdrop-filter:none;background:0 0;border-left:none;height:calc(100% - 83px)}.style-drawer-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;height:calc(100% - 83px);padding:28px;display:flex}.style-drawer-empty strong{letter-spacing:-.03em;font-size:18px}.style-drawer-empty p{max-width:260px;color:var(--text-muted);line-height:1.6}.style-drawer-empty-visual{width:158px;height:122px;position:relative}.style-drawer-empty-dot{background:linear-gradient(145deg,#3ba1ff,#007aff);border-radius:999px;width:18px;height:18px;position:absolute;top:22px;left:18px;box-shadow:0 0 0 8px #007aff1f}.style-drawer-empty-line{transform-origin:0;background:linear-gradient(90deg,#007affcc,#007aff1a);border-radius:999px;width:62px;height:3px;position:absolute;top:30px;left:32px;transform:rotate(16deg)}.style-drawer-empty-card{background:#ffffffe6;border:1px solid #0000000f;border-radius:18px;width:86px;height:56px;position:absolute;top:28px;right:6px;box-shadow:0 14px 24px #0f172a1f}.style-drawer-empty-card:before,.style-drawer-empty-card:after{content:"";background:#0000001a;border-radius:999px;height:6px;position:absolute;left:14px;right:14px}.style-drawer-empty-card:before{top:16px}.style-drawer-empty-card:after{top:28px;right:30px}.editor-section{border-bottom:1px solid var(--border);padding:18px 20px}.editor-section--grow{flex-direction:column;flex:1;min-height:0;display:flex}.editor-label{letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.editor-label-icon{opacity:.7;font-size:13px}.editor-tooltip{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;font-size:13px;font-family:var(--font-ui);color:var(--text);resize:none;padding:12px 14px;line-height:1.65;transition:all .2s}.editor-tooltip:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--raised)}.editor-tooltip::placeholder{color:var(--text-dim)}.editor-code-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.editor-lang-select{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:500;font-family:var(--font-mono);border-radius:999px;padding:4px 12px;transition:all .15s}.editor-lang-select:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.code-wrap{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--raised);flex:1;min-height:0;transition:all .2s;position:relative;overflow:hidden}.code-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.code-input,.code-highlight{font:12.5px/1.7 var(--font-mono);tab-size:2;white-space:pre-wrap;word-wrap:break-word;margin:0;padding:14px 16px;position:absolute;inset:0;overflow-y:auto}.code-input{z-index:1;color:#0000;caret-color:var(--accent);resize:none;background:0 0;border:none}.code-highlight{z-index:0;pointer-events:none;background:0 0}.hotspot-coords{font-size:12px;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 12px;display:inline-block}.style-row{gap:8px;display:flex}.style-select{border-radius:var(--radius-sm);background:var(--bg);border:1.5px solid var(--border);color:var(--text);cursor:pointer;flex:1;padding:8px 12px;font-size:13px;font-weight:500;transition:all .15s}.style-select:hover{border-color:var(--border-hi)}.style-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.style-select--small{flex:0 0 80px}.position-group+.position-group{margin-top:14px}.position-group--compact{margin-top:12px}.position-group-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-sec);margin-bottom:8px;font-size:11px;font-weight:700;display:inline-flex}.position-row{flex-direction:column;gap:8px;display:flex}.position-row+.position-row{margin-top:10px}.position-row-label{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:12px;display:flex}.position-row-label strong{color:var(--text-sec);font-size:11px;font-family:var(--font-mono)}.position-slider{appearance:none;background:linear-gradient(90deg,#007aff2e,#007aff80);border-radius:999px;outline:none;width:100%;height:6px}.position-slider::-webkit-slider-thumb{appearance:none;background:#fff;border:1px solid #007aff59;border-radius:999px;width:16px;height:16px;box-shadow:0 4px 10px #0000001f}.position-slider::-moz-range-thumb{background:#fff;border:1px solid #007aff59;border-radius:999px;width:16px;height:16px;box-shadow:0 4px 10px #0000001f}.toggle-chip{color:var(--text-sec);background:var(--bg);border:1px solid var(--border);border-radius:999px;justify-content:center;align-items:center;padding:8px 12px;font-size:12px;font-weight:600;transition:all .18s;display:inline-flex}.toggle-chip:hover{border-color:var(--border-hi);background:var(--raised)}.toggle-chip--active{color:var(--accent);background:var(--accent-soft);border-color:#007aff40}.focus-color-group{margin-top:14px}.style-format-row{gap:4px;margin-top:10px;display:flex}.style-format-btn{border-radius:var(--radius-sm);background:var(--bg);border:1.5px solid var(--border);width:34px;height:34px;color:var(--text-sec);justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.style-format-btn:hover{border-color:var(--border-hi);background:var(--raised)}.style-format-btn--active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.color-picker-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:999px;flex-shrink:0;width:26px;height:26px;transition:all .15s;box-shadow:inset 0 0 0 1px #00000014}.color-dot:hover{box-shadow:var(--shadow-sm), inset 0 0 0 1px #00000014;transform:scale(1.15)}.color-dot--active{border-color:var(--text);box-shadow:0 0 0 2px var(--raised), 0 0 0 3.5px var(--text);transform:scale(1.1)}.color-dot--custom{border:2px solid var(--border);position:relative}.color-input-hidden{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.menu-preview{border-radius:var(--radius);border:1px solid var(--border);min-height:48px;box-shadow:var(--shadow-sm);word-wrap:break-word;margin-top:12px;padding:14px 16px;line-height:1.5;transition:all .2s}.editor-hint{color:var(--text-dim);font-size:11px;line-height:1.6}.editor-label-hint{color:var(--text-dim);letter-spacing:0;text-transform:none;margin-left:auto;font-size:10px;font-weight:400}.rich-editor-wrap{position:relative}.rich-editor{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);min-height:88px;color:var(--text);cursor:text;padding:10px 14px;font-size:13px;line-height:1.65;transition:border-color .2s,box-shadow .2s}.rich-editor:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--raised)}.rich-editor .tiptap{outline:none;min-height:64px}.rich-editor .tiptap p{margin:0 0 4px}.rich-editor .tiptap p:last-child{margin-bottom:0}.rich-editor .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-dim);pointer-events:none;float:left;height:0}.bubble-menu{background:var(--text);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:5;align-items:center;gap:2px;padding:4px 5px;display:flex;position:absolute}.bubble-btn{color:#ffffffbf;border-radius:5px;justify-content:center;align-items:center;width:28px;height:26px;font-size:13px;transition:all .12s;display:flex}.bubble-btn:hover{color:#fff;background:#ffffff1f}.bubble-btn--active{color:#fff;background:#ffffff2e}.bubble-divider{background:#ffffff26;width:1px;height:16px;margin:0 2px}.ann-menu-text p{margin:0 0 2px}.ann-menu-text p:last-child{margin-bottom:0}.sidebar-delete-section{border-top:1px solid var(--border)!important;border-bottom:none!important;padding-top:14px!important;padding-bottom:20px!important}.btn-delete-menu{border-radius:var(--radius);width:100%;color:var(--danger);background:var(--danger-soft);border:1px solid #0000;justify-content:center;align-items:center;gap:7px;padding:9px 16px;font-size:13px;font-weight:500;transition:all .18s;display:flex}.btn-delete-menu:hover{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 2px 8px #ff3b304d}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#707f8c;font-style:italic}.token.punctuation{color:#545454}.token.property,.token.tag,.token.boolean,.token.number{color:#1c00cf}.token.selector,.token.attr-name,.token.string,.token.char{color:#c41a16}.token.operator,.token.entity,.token.url,.token.variable{color:#007aff}.token.atrule,.token.attr-value,.token.keyword{color:#aa0d91}.token.function,.token.class-name{color:#3900a0}.token.regex,.token.important{color:#c35900}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.sidebar-item{animation:.2s fadeIn}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;animation:.2s modalFadeIn;display:flex;position:fixed;inset:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--raised);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg), 0 0 0 1px var(--border);flex-direction:column;width:560px;max-width:calc(100vw - 48px);max-height:calc(100vh - 96px);animation:.25s modalSlideIn;display:flex;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{letter-spacing:-.03em;color:var(--text);padding:24px 28px 0;font-size:18px;font-weight:700}.modal-drop-area{border:2px dashed var(--border-hi);border-radius:var(--radius);flex:1;min-height:280px;max-height:420px;margin:20px 28px;transition:all .2s;overflow-y:auto}.modal-drop-area--active{border-color:var(--accent);background:var(--accent-soft)}.modal-empty-state{cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;min-height:280px;padding:40px;transition:all .2s;display:flex}.modal-empty-state:hover{background:var(--hover)}.modal-empty-icon{background:var(--accent-soft);width:64px;height:64px;color:var(--accent);border-radius:16px;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-empty-state:hover .modal-empty-icon{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 16px #007aff4d}.modal-empty-text{color:var(--text-sec);letter-spacing:-.02em;font-size:15px;font-weight:600}.modal-empty-sub{color:var(--text-muted);font-size:12px}.modal-previews{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:16px;display:grid}.modal-preview-item{aspect-ratio:9/16;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg);cursor:grab;transition:all .18s;position:relative;overflow:hidden}.modal-preview-item:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.modal-preview-item--dragging{opacity:.4;transform:scale(.95)}.modal-preview-item--dragover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.modal-preview-img{object-fit:cover;width:100%;height:100%}.modal-preview-num{background:var(--accent);color:#fff;width:22px;height:22px;font-size:11px;font-weight:700;font-family:var(--font-mono);border-radius:999px;justify-content:center;align-items:center;display:flex;position:absolute;top:6px;left:6px;box-shadow:0 1px 4px #0003}.modal-preview-remove{color:#fff;opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;transition:all .15s;display:flex;position:absolute;top:6px;right:6px}.modal-preview-item:hover .modal-preview-remove{opacity:1}.modal-preview-remove:hover{background:var(--danger)}.modal-preview-add{aspect-ratio:9/16;border-radius:var(--radius-sm);border:2px dashed var(--border-hi);cursor:pointer;color:var(--text-dim);background:0 0;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-preview-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.modal-footer{justify-content:space-between;align-items:center;gap:12px;padding:16px 28px 24px;display:flex}.modal-btn{border-radius:var(--radius);letter-spacing:-.01em;padding:10px 28px;font-size:14px;font-weight:600;transition:all .2s}.modal-btn--secondary{color:var(--text-sec);background:var(--bg);border:1px solid var(--border)}.modal-btn--secondary:hover{background:var(--bg-subtle);border-color:var(--border-hi)}.modal-btn--primary{color:#fff;background:var(--accent);border:1px solid var(--accent);box-shadow:0 2px 8px #007aff4d}.modal-btn--primary:hover{background:#0066d6;transform:translateY(-1px);box-shadow:0 4px 16px #007aff66}.modal-btn--primary:active{transform:translateY(0)}.modal-btn--disabled{opacity:.4;pointer-events:none}@media (width<=1100px){.workspace-main--inspector-open .canvas-phone-frame{transform:scale(.93)}.style-drawer-panel{width:min(var(--drawer-w), calc(100% - 24px));top:12px;bottom:12px;right:12px}}@media (width<=820px){.workspace{grid-template-columns:var(--sidebar-rail-w) 1fr}.workspace:not(.workspace--sidebar-collapsed){grid-template-columns:min(220px,42vw) 1fr}.canvas-phone-frame{height:calc(100vh - var(--topbar-h) - 24px)}.workspace-main--inspector-open .canvas-phone-frame{transform:scale(.9)}.style-drawer-panel{width:auto;max-height:min(72vh,620px);inset:auto 10px 10px}.style-drawer .editor,.style-drawer-empty{height:calc(100% - 79px)}}.preview-backdrop{z-index:100;-webkit-backdrop-filter:blur(12px);background:#00000059;justify-content:center;align-items:center;animation:.28s previewFadeIn;display:flex;position:fixed;inset:0}@keyframes previewFadeIn{0%{opacity:0}to{opacity:1}}.preview-container{flex-direction:column;align-items:center;gap:16px;animation:.36s cubic-bezier(.16,1,.3,1) previewSlideIn;display:flex;position:relative}@keyframes previewSlideIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.preview-close{color:#fffc;-webkit-backdrop-filter:blur(8px);z-index:10;background:#ffffff1f;border:1px solid #ffffff26;border-radius:999px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex;position:absolute;top:-8px;right:-52px}.preview-close:hover{color:#fff;background:#fff3;transform:scale(1.08)}.preview-phone-wrap{position:relative}.preview-phone-frame{height:calc(100vh - var(--topbar-h) - 48px);aspect-ratio:421/850;filter:drop-shadow(0 24px 64px #0006);position:relative}.preview-image-layer{z-index:1;background:#000;border-radius:12.267%/5.665%;width:89.074%;height:95.529%;position:absolute;top:2.118%;left:5.225%;overflow:hidden}.preview-annotation-layer{z-index:3;width:89.074%;height:95.529%;position:absolute;top:2.118%;left:5.225%;overflow:visible}.preview-slide-anim{position:absolute;inset:0}.preview-phone-shell{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2;width:100%;height:100%;position:absolute;inset:0}.preview-phone-image{object-fit:cover;object-position:center top;width:100%;height:100%;display:block}.preview-slide-in{animation:.32s cubic-bezier(.16,1,.3,1) previewSlideContentIn}.preview-slide-out-left{animation:.28s cubic-bezier(.4,0,1,1) forwards previewSlideOutLeft}.preview-slide-out-right{animation:.28s cubic-bezier(.4,0,1,1) forwards previewSlideOutRight}@keyframes previewSlideContentIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes previewSlideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-12%)}}@keyframes previewSlideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(12%)}}.preview-hotspot,.preview-focus{pointer-events:none;cursor:default}.preview-menu{cursor:default;animation:.3s cubic-bezier(.16,1,.3,1) previewMenuIn}@keyframes previewMenuIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.preview-menu:hover{transform:translateY(0);box-shadow:0 4px 20px #0000002e,0 1px 4px #0000001a}.preview-menu-btn{letter-spacing:.01em;cursor:pointer;min-width:58px;height:28px;font-size:11px;font-weight:600;font-family:var(--font-ui);border:1px solid #0000;border-radius:7px;transition:all .16s}.preview-menu-btn:disabled{opacity:.4;cursor:not-allowed}.preview-menu-btn--secondary{color:#000000a3;background:#ffffffbd;border-color:#00000014}.preview-menu-btn--secondary:hover:not(:disabled){background:#fffffff2}.preview-menu-btn--primary{color:#fff;background:#007affeb;border-color:#0060d6e6}.preview-menu-btn--primary:hover:not(:disabled){background:#006ce7f2}.preview-dots{align-items:center;gap:8px;display:flex}.preview-dot{cursor:pointer;background:#fff3;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:all .22s cubic-bezier(.16,1,.3,1)}.preview-dot:hover:not(.preview-dot--active){background:#fff6}.preview-dot--active{background:var(--accent);transform:scale(1.35);box-shadow:0 0 8px #007aff80}.publish-modal{width:480px}.publish-modal-header{justify-content:space-between;align-items:flex-start;padding:24px 24px 0;display:flex}.publish-modal-title{letter-spacing:-.03em;color:var(--text);font-size:17px;font-weight:700}.publish-modal-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.publish-modal-close{width:28px;height:28px;color:var(--text-muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.publish-modal-close:hover{background:var(--hover);color:var(--text)}.publish-modal-body{flex-direction:column;gap:0;padding:20px 24px 24px;display:flex}.publish-section{flex-direction:column;gap:8px;display:flex}.publish-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.publish-row{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 12px;display:flex}.publish-row--embed{align-items:flex-start}.publish-value{color:var(--text-sec);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:12.5px;overflow:hidden}.publish-value--mono{font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;color:var(--text-sec);padding-top:1px;font-size:11px;overflow:hidden}.publish-copy-btn{color:var(--accent);background:var(--accent-soft);border-radius:6px;flex-shrink:0;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.publish-copy-btn:hover{background:var(--accent-glow)}.publish-copy-btn--done{color:var(--success);background:#34c7591a}.publish-cloud-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.publish-cloud-btn:hover{opacity:.88}.publish-cloud-btn:disabled{opacity:.5;cursor:default}.publish-divider{background:var(--border);height:1px;margin:16px 0}.publish-hint{color:var(--text-muted);font-size:11px;line-height:1.5}.publish-view-picker{grid-template-columns:1fr 1fr;gap:10px;display:grid}.publish-view-card{background:var(--bg-subtle);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;flex-direction:column;align-items:stretch;transition:border-color .15s,box-shadow .15s,background .15s;display:flex;overflow:hidden}.publish-view-card:hover{border-color:var(--border-hi);background:var(--bg)}.publish-view-card--active{border-color:var(--accent);background:var(--bg);box-shadow:0 0 0 3px #007aff1a}.publish-view-card-illustration{border-bottom:1px solid var(--border);background:#00000008;justify-content:center;align-items:center;padding:16px 20px 12px;display:flex}.publish-view-card--active .publish-view-card-illustration{background:#007aff0a;border-bottom-color:#007aff1f}.publish-view-card-illustration svg{filter:drop-shadow(0 4px 12px #0000002e);width:auto;height:80px}.publish-view-card-body{padding:10px 12px 12px}.publish-view-card-title{color:var(--text);align-items:center;gap:5px;margin-bottom:3px;font-size:12.5px;font-weight:600;display:flex}.publish-view-card-desc{color:var(--text-muted);font-size:11px;line-height:1.45}.home{background:var(--bg);flex-direction:column;height:100%;display:flex}.home-header{height:var(--topbar-h);background:var(--panel);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(24px)saturate(1.8);backdrop-filter:blur(24px)saturate(1.8);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 28px;display:flex}.home-header-logo-img{width:auto;height:22px;display:block}.home-header-logo{color:var(--text);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.home-new-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;height:32px;padding:0 16px;font-size:13px;font-weight:500;transition:opacity .15s}.home-new-btn:hover{opacity:.88}.home-content{flex:1;padding:40px 48px;overflow-y:auto}.home-section-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px;font-size:11px;font-weight:600}.home-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.home-card{background:var(--raised);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:box-shadow .18s,transform .18s,border-color .18s;position:relative;overflow:hidden}.home-card:hover{box-shadow:var(--shadow);border-color:var(--border-hi);transform:translateY(-2px)}.home-card-thumb{aspect-ratio:16/10;background:var(--bg-subtle);width:100%;position:relative;overflow:hidden}.home-card-thumb-img{object-fit:cover;width:100%;height:100%;display:block}.home-card-thumb-placeholder{width:100%;height:100%;color:var(--text-dim);justify-content:center;align-items:center;display:flex}.home-card-delete{color:#ffffffd9;cursor:pointer;opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;transition:opacity .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.home-card:hover .home-card-delete{opacity:1}.home-card-delete:hover{color:#fff;background:#ff3b30cc}.home-card-delete--confirm{color:#fff;opacity:1;background:#ff3b30e6}.home-card-info{padding:12px 14px}.home-card-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:5px;font-size:13px;font-weight:600;overflow:hidden}.home-card-meta{color:var(--text-muted);align-items:center;gap:6px;font-size:11.5px;display:flex}.home-card-badge{background:var(--bg-subtle);color:var(--text-sec);border-radius:999px;padding:2px 7px;font-size:11px;font-weight:500}.home-card-dot{background:var(--text-dim);border-radius:50%;flex-shrink:0;width:3px;height:3px}.home-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;min-height:320px;display:flex}.home-empty-icon{color:var(--text-dim)}.home-empty-title{color:var(--text);font-size:17px;font-weight:600}.home-empty-sub{color:var(--text-muted);max-width:280px;font-size:13px;line-height:1.5}.new-project-modal{width:480px}.new-project-field{margin-bottom:20px;padding:0 28px}.new-project-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11.5px;font-weight:600;display:block}.new-project-input{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;height:38px;font-size:14px;font-family:var(--font-ui);color:var(--text);outline:none;padding:0 12px;transition:border-color .15s}.new-project-input:focus{border-color:var(--accent)}.new-project-device-picker{gap:12px;display:flex}.device-card{border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:12px;padding:20px 16px 14px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex;position:relative}.device-card--active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}.device-card--disabled{cursor:not-allowed;opacity:.5}.device-card-label{color:var(--text-sec);font-size:12.5px;font-weight:600}.device-card--active .device-card-label{color:var(--accent)}.device-card-badge{background:var(--bg-subtle);color:var(--text-muted);letter-spacing:.02em;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:600;position:absolute;top:8px;right:8px}.topbar-logo--clickable{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 6px;transition:background .15s}.topbar-logo--clickable:hover{background:var(--hover)}.topbar-history-btns{align-items:center;gap:4px;display:flex}.topbar-icon-btn{gap:0!important;padding:5px 7px!important}.modal-btn--ghost{color:var(--text-muted);box-shadow:none;background:0 0;border:none}.modal-btn--ghost:hover{color:var(--text);background:var(--hover)}.canvas-phone-frame[data-device=android]{aspect-ratio:995/2048}.canvas-phone-frame[data-device=android] .canvas-phone-inner{z-index:3;border-radius:10.467%/4.865%;width:92.791%;height:96.987%;top:1.506%;left:3.101%}.preview-phone-frame[data-device=android]{aspect-ratio:995/2048}.preview-phone-frame[data-device=android] .preview-image-layer{z-index:3;border-radius:10.467%/4.865%;width:92.791%;height:96.987%;top:1.506%;left:3.101%}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100%;display:flex}.login-card{background:var(--raised);border-radius:var(--radius-lg);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:40px 32px}.login-logo{justify-content:center;margin-bottom:24px;display:flex}.login-logo-img{width:auto;height:28px}.login-title{text-align:center;color:var(--text);margin-bottom:24px;font-size:20px;font-weight:600}.login-oauth{flex-direction:column;gap:10px;display:flex}.login-oauth-btn{border-radius:var(--radius-sm);border:1px solid var(--border-hi);background:var(--raised);height:40px;color:var(--text);justify-content:center;align-items:center;gap:10px;padding:0 16px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.login-oauth-btn:hover{background:var(--hover);border-color:var(--border-hi)}.login-divider{color:var(--text-muted);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-form{flex-direction:column;gap:10px;display:flex}.login-input{border-radius:var(--radius-sm);border:1px solid var(--border-hi);background:var(--bg);height:40px;color:var(--text);padding:0 14px;font-size:13px;transition:border-color .15s}.login-input:focus{border-color:var(--accent);outline:none}.login-input::placeholder{color:var(--text-muted)}.login-error{color:var(--danger);padding:4px 0;font-size:12px}.login-submit{border-radius:var(--radius-sm);background:var(--accent);color:#fff;border:none;height:40px;margin-top:4px;font-size:13px;font-weight:600;transition:opacity .15s}.login-submit:hover{opacity:.9}.login-submit:disabled{opacity:.5}.login-switch{text-align:center;color:var(--text-muted);margin-top:20px;font-size:12px}.login-switch button{color:var(--accent);font-weight:500;text-decoration:none}.login-switch button:hover{text-decoration:underline}.home-header-actions{align-items:center;gap:10px;display:flex}.home-user-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.home-user-btn:hover{background:var(--hover);color:var(--text)}.publish-cloud-btn--danger{background:var(--danger-soft);color:var(--danger)}.publish-cloud-btn--danger:hover{background:#ff3b3024}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
