@font-face{font-family:DFXingKaiHK;src:url(/assets/fonts/DFXingKaiHK-W5.otf)format("opentype")}@font-face{font-family:Cataneo BT;src:url(/assets/fonts/CataneoBT-Regular.ttf)format("truetype")}@font-face{font-family:MingLiU HKSCS;src:url(/assets/fonts/MingLiU_HKSCS.ttf)format("truetype")}@font-face{font-family:Namecard Arial;src:url(/assets/fonts/Arial.ttf)format("truetype")}@font-face{font-family:Arial Narrow;src:url(/assets/fonts/ArialNarrow.ttf)format("truetype")}:root{--bg:#eef2f6;--panel:#fff;--panel-2:#f8fafc;--ink:#171719;--muted:#626874;--border:#d7dfe8;--accent:#146b63;--accent-dark:#0d4741;--accent-soft:#e4f4f0;--focus:#146b63;--surface-shadow:0 24px 55px #14182024;--control-shadow:0 10px 24px #10182814;color:var(--ink);background:var(--bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,a{font:inherit}button,a{-webkit-tap-highlight-color:transparent}.app-shell{grid-template-columns:320px minmax(0,1fr);min-height:100vh;display:grid}.workspace-panel{color:#fff;background:#1f2528;flex-direction:column;gap:18px;padding:24px 18px;display:flex}.brand-lockup{grid-template-columns:44px 1fr;align-items:center;gap:12px;display:grid}.brand-mark{letter-spacing:0;background:linear-gradient(135deg,#15806f,#365f86);border-radius:8px;place-items:center;width:44px;height:44px;font-weight:800;display:grid}.brand-lockup h1,.topbar h2{margin:0;font-size:18px;line-height:1.15}.brand-lockup p,.topbar p{color:#aeb5c1;margin:4px 0 0;font-size:13px}.primary-action,.save-button,.export-button,.upload-button,.reset-button,.cancel-button,.danger-button,.icon-button{cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:38px;text-decoration:none;transition:background .15s,border-color .15s,color .15s,transform .15s;display:inline-flex}.primary-action{color:#1f2528;width:100%;box-shadow:var(--control-shadow);background:#fff;font-weight:700}.primary-action:hover,.save-button:hover,.export-button:hover,.upload-button:hover,.reset-button:hover,.icon-button:hover{transform:translateY(-1px)}.search-box{color:#c7ccd5;background:#151a1d;border:1px solid #3b3d45;border-radius:8px;align-items:center;gap:9px;height:38px;padding:0 12px;display:flex}.search-box input{color:#fff;background:0 0;border:0;outline:0;width:100%;font-size:14px}.saved-list{flex-direction:column;gap:8px;padding-right:2px;display:flex;overflow:auto}.saved-card{color:#fff;background:#293034;border:1px solid #343741;border-radius:8px;grid-template-columns:minmax(0,1fr) 34px;align-items:center;gap:8px;width:100%;padding:12px;display:grid}.saved-card-select{min-width:0;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;gap:4px;padding:0;display:grid}.saved-card-delete{color:#f5c1c1;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;place-items:center;width:34px;height:34px;transition:background .15s,border-color .15s,color .15s;display:grid}.saved-card-delete:hover{color:#fff;background:#da4c4c38;border-color:#f0a6a6}.saved-card.selected{background:#183a38;border-color:#8ad9c8}.saved-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;overflow:hidden}.saved-meta,.empty-state{color:#b8bec8;font-size:12px}.workbench{min-width:0;padding:22px}.topbar{grid-template-columns:minmax(150px,220px) minmax(0,1fr);align-items:start;gap:16px;margin-bottom:20px;display:grid}.topbar p{color:var(--muted)}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.save-button{background:var(--accent);color:#fff;padding:0 14px;font-weight:700}.save-button:disabled{opacity:.65;cursor:wait}.export-button,.icon-button{border-color:var(--border);color:var(--ink);background:#fff;padding:0 12px}.export-button{white-space:nowrap;min-width:156px}.export-button svg{flex:none}.icon-button{width:40px;padding:0}.export-button.disabled,.export-button:disabled{opacity:.45;cursor:wait}.export-progress{color:#123f39;background:#e9f7f3;border:1px solid #9fcfc4;border-radius:8px;align-items:center;gap:9px;width:100%;min-height:42px;margin:-8px 0 16px;padding:0 14px;font-size:14px;font-weight:800;display:inline-flex}.spin-icon{animation:.9s linear infinite spin}.app-shell.is-exporting{cursor:progress}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f161c8a;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.delete-dialog{border:1px solid var(--border);width:min(420px,100%);color:var(--ink);background:#fff;border-radius:8px;gap:14px;padding:22px;display:grid;position:relative;box-shadow:0 24px 70px #141c233d}.delete-dialog h3,.delete-dialog p{margin:0}.delete-dialog p{color:var(--muted);font-size:13px}.dialog-close{width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;place-items:center;display:grid;position:absolute;top:10px;right:10px}.dialog-close:hover{background:var(--panel-2);color:var(--ink)}.dialog-actions{justify-content:flex-end;gap:8px;display:flex}.cancel-button{border-color:var(--border);background:var(--panel-2);color:var(--ink);padding:0 14px;font-weight:700}.danger-button{color:#fff;background:#c9303a;padding:0 14px;font-weight:800}.cancel-button:disabled,.danger-button:disabled{opacity:.55;cursor:wait}.editor-grid{grid-template-columns:minmax(420px,1fr) 390px;align-items:start;gap:22px;display:grid}.preview-stage,.editor-panel{border:1px solid var(--border);background:var(--panel);border-radius:8px}.preview-stage{background-color:#f7f9fb;background-image:linear-gradient(90deg,#146b630d 1px,#0000 1px),linear-gradient(#146b630d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:28px 28px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;place-items:center;gap:14px;min-height:calc(100vh - 110px);padding:24px;transition:background .2s,padding .2s;display:grid}.preview-stage.focus-preview{background:#dfe7ed}.card-canvas{aspect-ratio:756/1182;width:min(100%,529px);box-shadow:var(--surface-shadow);background:#fff;position:relative;container-type:inline-size}.template-image{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.photo-frame{touch-action:none;-webkit-user-select:none;user-select:none;background:#e1d2ea;border-radius:50%;width:30.29%;height:22.67%;position:absolute;top:60.39%;left:56.75%;overflow:hidden}.photo-frame.has-photo{cursor:grab}.photo-frame.dragging{cursor:grabbing}.photo-frame img{object-fit:cover;transform-origin:50%;will-change:transform, filter;pointer-events:none;width:100%;height:100%;position:absolute;top:50%;left:50%}.photo-guides{pointer-events:none;border-radius:50%;width:30.29%;height:22.67%;position:absolute;top:60.39%;left:56.75%;overflow:hidden}.photo-guides:before,.photo-guides:after,.photo-guides span{content:"";background:#ffffffa3;position:absolute;box-shadow:0 0 0 1px #14182024}.photo-guides:before{width:1px;top:0;bottom:0;left:33.333%}.photo-guides:after{width:1px;top:0;bottom:0;left:66.666%}.photo-guides span:first-child,.photo-guides span:nth-child(2){height:1px;left:0;right:0}.photo-guides span:first-child{top:33.333%}.photo-guides span:nth-child(2){top:66.666%}.photo-guides span:nth-child(3){background:#146b638a;width:1px;top:0;bottom:0;left:50%}.photo-guides span:nth-child(4){background:#146b638a;height:1px;top:50%;left:0;right:0}.overlay{color:#191919;text-align:center;white-space:nowrap;line-height:1;position:absolute;transform:translate(-50%)}.chinese-name{width:46%;font-family:DFXingKaiHK,serif;font-size:8.819cqw;top:31.05%;left:50.57%}.english-name{letter-spacing:-.014cqw;width:56%;font-family:Cataneo BT,Georgia,serif;font-size:6.615cqw;font-weight:400;top:36.65%;left:50.52%}.chinese-title{letter-spacing:.055cqw;width:56%;font-family:MingLiU HKSCS,MingLiU,serif;font-size:3.859cqw;top:43.6%;left:50.27%}.english-title{letter-spacing:-.014cqw;justify-items:center;gap:.551cqw;width:60%;font-family:Cataneo BT,Georgia,serif;font-size:3.859cqw;font-style:italic;font-weight:400;line-height:1.14;display:grid;top:46.89%;left:50.6%}.mobile-number,.email-address{letter-spacing:.006cqw;text-align:left;transform-origin:0 0;font-family:Namecard Arial,Arial,sans-serif;font-size:3.307cqw;transform:scaleX(.85)}.email-address{transform:scaleX(.8668)}.mobile-number{top:78.55%;left:40.51%}.email-address{top:83.49%;left:32.99%}.preview-footer{color:var(--muted);align-items:center;gap:8px;font-size:13px;display:flex}.editor-panel{gap:0;display:grid;overflow:hidden}.panel-section{border-bottom:1px solid var(--border);gap:13px;padding:18px;display:grid}.panel-section:last-child{border-bottom:0}.panel-section h3{margin:0 0 2px;font-size:15px}.section-heading{justify-content:space-between;align-items:end;gap:12px;display:flex}.section-heading h3{margin:0}.section-heading span{color:var(--muted);text-align:right;font-size:12px;font-weight:700}.field{gap:6px;display:grid}.field span,.slider-row span{color:var(--muted);font-size:12px;font-weight:700}.field input,.field textarea{border:1px solid var(--border);background:#fff;border-radius:6px;outline:none;width:100%}.field input{height:36px;padding:0 10px}.field textarea{resize:vertical;min-height:58px;padding:8px 10px;line-height:1.25}.field small{color:#6d7685;font-size:11px;font-weight:700;line-height:1.25}.field input:focus,.field textarea:focus,.search-box:focus-within{border-color:var(--focus);box-shadow:0 0 0 3px #1e7f7129}.upload-button,.reset-button{border-color:var(--border);background:var(--panel-2);width:100%;color:var(--ink);font-weight:700}.tool-strip,.preset-row,.toggle-row{gap:8px;display:grid}.tool-strip,.tool-strip.compact{grid-template-columns:repeat(6,minmax(0,1fr))}.tool-button,.toggle-button,.preset-row button{border:1px solid var(--border);color:var(--ink);cursor:pointer;background:#fff;border-radius:8px;transition:background .15s,border-color .15s,color .15s,transform .15s}.tool-button{place-items:center;height:36px;padding:0;display:grid}.tool-button:hover,.toggle-button:hover,.preset-row button:hover{border-color:#9fb1c1;transform:translateY(-1px)}.tool-button.pressed,.toggle-button.active{background:var(--accent-soft);color:var(--accent-dark);border-color:#7fcdbf}.tool-button:disabled,.preset-row button:disabled,.checkbox-row input:disabled+span{opacity:.45;cursor:not-allowed}.preset-row{grid-template-columns:repeat(4,minmax(0,1fr))}.preset-row button{min-height:34px;padding:0 10px;font-size:12px;font-weight:800}.toggle-row{grid-template-columns:repeat(2,minmax(0,1fr))}.toggle-button{justify-content:center;align-items:center;gap:7px;min-height:34px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.reset-button{color:var(--muted);background:#fff}.control-group{gap:11px;display:grid}.slider-row{grid-template-columns:104px minmax(0,1fr) 44px;align-items:center;gap:9px;display:grid}.slider-row span{align-items:center;gap:6px;display:inline-flex}.slider-row input{width:100%;accent-color:var(--accent)}.slider-row output{color:var(--muted);text-align:right;font-size:12px}.checkbox-row{color:var(--muted);align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.checkbox-row input{width:16px;height:16px;accent-color:var(--accent)}.compact-note{background:var(--accent-soft);color:var(--accent-dark);grid-template-columns:18px 1fr;align-items:start}.compact-note p{margin:0;font-size:13px;line-height:1.45}@media (width<=1080px){.app-shell{grid-template-columns:1fr}.workspace-panel{min-height:auto}.saved-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));max-height:220px;display:grid}.editor-grid{grid-template-columns:1fr}}@media (width<=640px){.workbench,.workspace-panel{padding:16px}.topbar{grid-template-columns:1fr;align-items:stretch}.topbar-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.export-button{min-width:0}.preview-stage{min-height:auto;padding:12px}.editor-grid{gap:14px}.section-heading{flex-direction:column;align-items:start;gap:4px}.section-heading span{text-align:left}.tool-strip,.tool-strip.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.slider-row{grid-template-columns:1fr 52px;gap:7px 9px}.slider-row span{grid-column:1/-1}}
