.cardstudio-root,.cardstudio-root *{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;margin:0;padding:0}.cardstudio-root input,.cardstudio-root textarea,.cardstudio-root [contenteditable=true]{-webkit-user-select:text;user-select:text}.cardstudio-root{overscroll-behavior:none;-webkit-text-size-adjust:100%;color:#e8e4dc;touch-action:manipulation;background:#1a1a1f;flex-direction:column;height:100dvh;font-family:DM Sans,Noto Sans KR,sans-serif;display:flex;overflow:hidden}.topbar{z-index:100;background:#111114;border-bottom:1px solid #2a2a32;flex-shrink:0;align-items:center;gap:10px;height:52px;padding:0 16px;display:flex}.logo{color:#c9a84c;white-space:nowrap;margin-right:4px;font-family:Playfair Display,serif;font-size:18px}.logo span{color:#e8e4dc;font-style:italic}.divider-v{background:#2a2a32;width:1px;height:28px}.top-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:6px;height:32px;padding:0 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s;display:flex}.top-btn-ghost{color:#9a9490;background:0 0}.top-btn-primary{color:#111;background:#c9a84c}.top-btn-primary:hover{background:#e8cc7a}.top-btn-outline{color:#c9a84c;background:0 0;border:1px solid #c9a84c}.top-btn-outline:hover{background:#c9a84c1a}.top-btn-feature:hover{background:#c9a84c26}.spacer{flex:1}.user-badge{color:#7a7a82;background:#1e1e26;border-radius:14px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;display:flex}.user-badge.admin{color:#c9a84c;background:#c9a84c26}.user-badge .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.page-tabs{background:#1e1e26;border-radius:7px;gap:2px;padding:3px;display:flex}.page-tab{cursor:pointer;color:#7a7a82;background:0 0;border:none;border-radius:5px;padding:5px 14px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;transition:all .15s}.zoom-ctrl{color:#6a6660;align-items:center;gap:6px;font-size:12px;display:flex}.zoom-ctrl button{color:#e8e4dc;cursor:pointer;background:#2a2a32;border:none;border-radius:4px;width:26px;height:26px;font-size:14px}#zoom-label{text-align:center;color:#c9a84c;min-width:40px;font-family:DM Mono;font-size:11px}.main{flex:1;display:flex;overflow:hidden}.sidebar-l{background:#111114;border-right:1px solid #2a2a32;flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow-y:auto}.sidebar-l::-webkit-scrollbar{width:4px}.sidebar-r::-webkit-scrollbar{width:4px}.sidebar-l::-webkit-scrollbar-thumb{background:#2a2a32;border-radius:2px}.sidebar-r::-webkit-scrollbar-thumb{background:#2a2a32;border-radius:2px}.sb-section{border-bottom:1px solid #1e1e24;padding:14px 14px 12px}.sb-label{letter-spacing:1.5px;text-transform:uppercase;color:#5a5a62;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:9px;font-weight:700;display:flex}.sb-label .badge{color:#c9a84c;letter-spacing:0;background:#2a2a32;border-radius:8px;padding:2px 6px;font-size:8px}.field-list{flex-direction:column;gap:8px;display:flex}.field-item{background:#1e1e26;border:1px solid #2a2a32;border-radius:7px;padding:8px 10px;transition:all .15s}.field-item .field-label{color:#7a7a82;text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:9px;display:flex}.field-item .field-label .field-status{color:#c9a84c;font-weight:700}.field-item input{color:#e8e4dc;background:0 0;border:none;outline:none;width:100%;font-family:Noto Sans KR,sans-serif;font-size:13px}.field-item .field-actions{gap:6px;margin-top:6px;display:flex}.field-mini-btn{color:#9a9490;cursor:pointer;background:#111114;border:1px solid #2a2a32;border-radius:4px;flex:1;padding:4px 8px;font-family:DM Sans,sans-serif;font-size:10px;transition:all .15s}.field-mini-btn.danger:hover{color:#e05555;border-color:#e05555}.upload-area{text-align:center;cursor:pointer;background:#c9a84c08;border:1.5px dashed #2a2a32;border-radius:8px;margin-bottom:10px;padding:14px 12px;transition:all .15s}.upload-area:hover,.upload-area.drag-over{background:#c9a84c14;border-color:#c9a84c}.upload-area input{display:none}.upload-area p{color:#7a7a82;margin-top:6px;font-size:11px;line-height:1.5}.upload-area .upload-icon{font-size:24px}.image-lib{grid-template-columns:1fr 1fr;gap:6px;display:grid}.image-lib-item{aspect-ratio:1;cursor:pointer;background:#1e1e26;border:1.5px solid #2a2a32;border-radius:6px;transition:border-color .15s;position:relative;overflow:hidden}.image-lib-item:hover{border-color:#c9a84c}.image-lib-item img{object-fit:contain;pointer-events:none;width:100%;height:100%}.shape-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.shape-item{aspect-ratio:1;cursor:pointer;background:#2a2a32;border-radius:6px;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.shape-item:hover{background:#3a3a42;transform:scale(1.08)}.canvas-wrap{touch-action:pan-x pan-y;background:#16161b;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:auto}.canvas-grid{opacity:.5;pointer-events:none;background-image:radial-gradient(circle,#2a2a32 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0}.canvas-outer{transform-origin:50%;flex-direction:column;align-items:center;gap:14px;transition:transform .2s;display:flex;position:relative}.page-label{color:#5a5a62;letter-spacing:2px;text-transform:uppercase;font-family:DM Mono,monospace;font-size:10px}.card{border-radius:8px;width:340px;height:194px;position:relative;overflow:hidden;box-shadow:0 20px 80px #000000b3,0 0 0 1px #ffffff0d}.card-bg{transition:background .3s;position:absolute;inset:0}.card-content{position:absolute;inset:0}.drop-overlay{pointer-events:none;opacity:0;z-index:50;color:#c9a84c;background:#c9a84c1a;border:3px dashed #c9a84c;border-radius:8px;justify-content:center;align-items:center;font-weight:700;transition:opacity .15s;display:flex;position:absolute;inset:0}.canvas-wrap.dragging .drop-overlay{opacity:1}.card-el{cursor:move;touch-action:none;outline:none;min-width:20px;min-height:16px;position:absolute}.card-el:hover .el-border{opacity:1}.card-el.selected .el-border{opacity:1;border-color:#c9a84c}.el-border{pointer-events:none;opacity:0;border:1.5px dashed #c9a84c80;border-radius:3px;transition:opacity .15s;position:absolute;inset:-3px}.el-text{white-space:pre-wrap;word-break:break-word;outline:none;line-height:1.3}.card-el.selected .resize-handle{display:block}.resize-handle{background:#c9a84c;border:1px solid #111;border-radius:2px;width:8px;height:8px;display:none;position:absolute}.rh-br{cursor:se-resize;bottom:-5px;right:-5px}.rh-bl{cursor:sw-resize;bottom:-5px;left:-5px}.rh-tr{cursor:ne-resize;top:-5px;right:-5px}.rh-tl{cursor:nw-resize;top:-5px;left:-5px}.card-shape{width:100%;height:100%}.card.watermark:after{content:"PREVIEW";color:#c9a84c26;pointer-events:none;letter-spacing:8px;z-index:100;font-family:Playfair Display,serif;font-size:38px;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-30deg)}.sidebar-r{background:#111114;border-left:1px solid #2a2a32;flex-direction:column;flex-shrink:0;width:250px;display:flex;overflow-y:auto}.prop-group{border-bottom:1px solid #1e1e24;padding:14px}.prop-label{letter-spacing:1.5px;text-transform:uppercase;color:#5a5a62;margin-bottom:10px;font-size:9px;font-weight:700}.ctrl-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.ctrl-row label{color:#7a7a82;flex-shrink:0;width:56px;font-size:11px}.ctrl-input{color:#e8e4dc;background:#1e1e26;border:1px solid #2a2a32;border-radius:5px;outline:none;flex:1;min-width:0;padding:5px 8px;font-family:DM Sans,sans-serif;font-size:12px;transition:border-color .15s}select.ctrl-input{cursor:pointer}.color-grid{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.col-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:22px;height:22px;transition:all .15s}.col-swatch:hover{transform:scale(1.15)}.btn-row{gap:6px;display:flex}.prop-btn{color:#c8c4bc;cursor:pointer;background:#1e1e26;border:1px solid #2a2a32;border-radius:5px;flex:1;height:30px;font-family:DM Sans,sans-serif;font-size:11px;transition:all .15s}.prop-btn:hover{color:#e8e4dc;background:#2a2a32;border-color:#3a3a42}.align-btns{gap:4px;display:flex}.align-btn{cursor:pointer;background:#1e1e26;border:1px solid #2a2a32;border-radius:5px;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;transition:all .15s;display:flex}.align-btn:hover{background:#2a2a32}.font-search{color:#e8e4dc;background:#1e1e26;border:1px solid #2a2a32;border-radius:5px;outline:none;width:100%;margin-bottom:8px;padding:6px 10px;font-size:12px}.font-search:focus{border-color:#c9a84c}.font-list{flex-direction:column;gap:2px;max-height:200px;display:flex;overflow-y:auto}.font-list::-webkit-scrollbar{width:4px}.font-list::-webkit-scrollbar-thumb{background:#2a2a32;border-radius:2px}.font-item{cursor:pointer;color:#c8c4bc;border-radius:5px;flex-direction:column;padding:6px 10px;font-size:13px;transition:background .15s;display:flex}.font-item.active{color:#c9a84c;background:#2a2a32}.font-item .font-tag{color:#5a5a62;letter-spacing:1px;margin-top:1px;font-family:DM Mono,monospace;font-size:8px}.bg-swatches{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.bg-swatch{cursor:pointer;border:2px solid #0000;border-radius:5px;width:28px;height:28px;transition:all .15s}.bg-swatch:hover{transform:scale(1.1)}.bg-swatch.active{border-color:#c9a84c}.gradient-btns{flex-direction:column;gap:5px;display:flex}.grad-btn{cursor:pointer;color:#fff;border:2px solid #0000;border-radius:5px;align-items:center;height:28px;padding:0 8px;font-size:10px;font-weight:600;transition:border-color .15s;display:flex}.grad-btn:hover,.grad-btn.active{border-color:#c9a84c}.statusbar{color:#3a3a42;background:#0d0d10;border-top:1px solid #1e1e24;flex-shrink:0;align-items:center;gap:14px;height:24px;padding:0 16px;font-family:DM Mono,monospace;font-size:10px;display:flex}.statusbar span{color:#5a5a62}.modal-overlay{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal-box{background:#1a1a1f;border:1px solid #2a2a32;border-radius:16px;flex-direction:column;width:100%;max-height:90vh;display:flex;overflow:hidden}.modal-head{border-bottom:1px solid #2a2a32;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-head h2{color:#c9a84c;font-family:Playfair Display,serif;font-size:22px}.modal-head .modal-sub{color:#7a7a82;margin-top:3px;font-size:12px}.modal-close-btn{color:#9a9490;cursor:pointer;background:#0006;border:none;border-radius:50%;width:32px;height:32px;font-size:16px}.modal-close-btn:hover{color:#e8e4dc;background:#0009}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-foot{border-top:1px solid #2a2a32;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.btn{cursor:pointer;border:none;border-radius:7px;padding:10px 22px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.btn-primary{color:#111;background:#c9a84c}.btn-primary:hover{background:#e8cc7a}.btn-secondary{color:#7a7a82;background:0 0;border:1px solid #2a2a32}.btn-secondary:hover{color:#e8e4dc;border-color:#3a3a42}.btn-danger{color:#fff;background:#e05555}.btn-danger:hover{background:#f06868}.modal-template{width:100%;max-width:880px}.tpl-tabs{background:#111114;border-bottom:1px solid #2a2a32;gap:4px;padding:0 24px;display:flex}.tpl-tab{cursor:pointer;color:#7a7a82;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 18px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.tpl-tab.active{color:#c9a84c;border-bottom-color:#c9a84c}.tpl-tab .lock-icon{opacity:.7;margin-left:4px}.tpl-grid-modal{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.tpl-card{cursor:pointer;background:#1e1e26;border:2px solid #2a2a32;border-radius:10px;padding:12px;transition:all .15s;position:relative}.tpl-card:hover{border-color:#c9a84c;transform:translateY(-2px)}.tpl-card.locked{opacity:.6}.tpl-card.locked:before{content:"🔒";background:#000000b3;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;display:flex;position:absolute;top:10px;right:10px}.tpl-preview{aspect-ratio:1.75;color:#fffc;text-transform:uppercase;letter-spacing:1px;border-radius:6px;justify-content:center;align-items:center;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.tpl-card .tpl-title{color:#e8e4dc;font-size:13px;font-weight:700}.tpl-card .tpl-meta{color:#7a7a82;margin-top:2px;font-size:10px}.tpl-admin-bar{border-top:1px solid #2a2a32;gap:4px;margin-top:8px;padding-top:8px;display:flex}.tpl-admin-btn{color:#9a9490;cursor:pointer;background:#2a2a32;border:none;border-radius:4px;flex:1;padding:4px;font-family:DM Sans,sans-serif;font-size:10px}.tpl-admin-btn:hover{color:#c9a84c}.tpl-admin-btn.danger:hover{color:#e05555}.modal-auth{width:100%;max-width:400px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-input{color:#e8e4dc;background:#1e1e26;border:1px solid #2a2a32;border-radius:7px;outline:none;padding:11px 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .15s}.auth-input:focus{border-color:#c9a84c}.auth-input.error{border-color:#e05555}.auth-hint{color:#5a5a62;background:#c9a84c0d;border-left:3px solid #c9a84c;border-radius:6px;padding:10px 12px;font-size:11px;line-height:1.5}.auth-error{color:#e05555;font-size:12px}.add-tpl-form{flex-direction:column;gap:14px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#7a7a82;font-size:11px;font-weight:600}.form-group input,.form-group select{color:#e8e4dc;background:#1e1e26;border:1px solid #2a2a32;border-radius:6px;outline:none;padding:9px 12px;font-family:DM Sans,sans-serif;font-size:13px}.form-group input:focus,.form-group select:focus{border-color:#c9a84c}.modal-pay{width:100%;max-width:480px}.pay-summary{background:#1e1e26;border:1px solid #2a2a32;border-radius:10px;margin-bottom:18px;padding:18px}.pay-row{justify-content:space-between;padding:7px 0;font-size:13px;display:flex}.pay-row .lbl{color:#7a7a82}.pay-row .val{color:#e8e4dc;font-weight:600}.pay-total{border-top:1.5px solid #2a2a32;justify-content:space-between;align-items:baseline;margin-top:12px;padding-top:14px;display:flex}.pay-total .lbl{color:#7a7a82;font-size:13px}.pay-total .val{color:#c9a84c;font-family:Playfair Display,serif;font-size:26px}.pay-options{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.pay-option{cursor:pointer;background:#1e1e26;border:1.5px solid #2a2a32;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;transition:all .15s;display:flex}.pay-option:hover{border-color:#c9a84c}.pay-option.active{background:#c9a84c0d;border-color:#c9a84c}.pay-icon{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:28px;font-size:11px;font-weight:700;display:flex}.pay-name{color:#e8e4dc;flex:1;font-size:13px;font-weight:600}.pay-meta{color:#7a7a82;font-size:11px}.success-panel{text-align:center;padding:20px 0}.success-icon-big{color:#111;background:#c9a84c;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 14px;font-size:30px;display:flex}.mobile-only{display:none!important}@media (max-width:768px){.mobile-only{display:flex!important}span.mobile-only,.btn-text-long.mobile-only{display:inline!important}}.hamburger-btn{color:#e8e4dc;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:none}.hamburger-btn:active{background:#2a2a32}.mobile-drawer{z-index:200;width:84%;max-width:320px;padding-top:env(safe-area-inset-top);background:#111114;border-right:1px solid #2a2a32;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.mobile-drawer.open{transform:translate(0)}.mobile-drawer-backdrop{z-index:199;opacity:0;pointer-events:none;background:#0009;transition:opacity .25s;position:fixed;inset:0}.mobile-drawer-backdrop.open{opacity:1;pointer-events:auto}.mobile-drawer-head{z-index:1;background:#111114;border-bottom:1px solid #2a2a32;justify-content:space-between;align-items:center;padding:16px 18px;display:flex;position:sticky;top:0}.mobile-drawer-head h3{color:#c9a84c;font-family:Playfair Display,serif;font-size:18px;font-weight:400}.bottom-sheet{z-index:150;max-height:75dvh;padding-bottom:env(safe-area-inset-bottom);background:#111114;border-top:1px solid #2a2a32;border-radius:18px 18px 0 0;flex-direction:column;transition:transform .28s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -10px 40px #00000080}.bottom-sheet.open{transform:translateY(0)}.bottom-sheet-handle{touch-action:none;cursor:grab;box-sizing:content-box;background:#3a3a42;border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:4px auto;padding:8px 30px}.bottom-sheet-tabs{scrollbar-width:none;border-bottom:1px solid #1e1e24;flex-shrink:0;gap:0;padding:8px 12px 0;display:flex;overflow-x:auto}.bottom-sheet-tabs::-webkit-scrollbar{display:none}.bs-tab{cursor:pointer;color:#7a7a82;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.bs-tab.active{color:#c9a84c;border-bottom-color:#c9a84c}.bs-close-btn{color:#7a7a82;cursor:pointer;background:0 0;border:none;border-radius:50%;width:30px;height:30px;font-size:20px;line-height:1;position:absolute;top:8px;right:12px}.bs-close-btn:active{color:#e8e4dc;background:#2a2a32}.bottom-sheet-body{-webkit-overflow-scrolling:touch;flex:1;padding:12px 14px 18px;overflow-y:auto}.bottom-sheet-body::-webkit-scrollbar{width:4px}.bottom-sheet-body::-webkit-scrollbar-thumb{background:#2a2a32;border-radius:2px}.mobile-fab{right:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:90;flex-direction:column;gap:8px;display:none;position:fixed}.fab-btn{color:#111;cursor:pointer;background:#c9a84c;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 16px #0006}.fab-btn.secondary{color:#c9a84c;background:#2a2a32;border:1px solid #c9a84c}.fab-btn:active{transform:scale(.94)}@media (max-width:1024px) and (min-width:769px){.sidebar-l{width:200px}.sidebar-r{width:220px}.top-btn{padding:0 8px;font-size:11px}.top-btn span.btn-text-long{display:none}}@media (max-width:768px){.desktop-only{display:none!important}.topbar{height:52px;padding:env(safe-area-inset-top) 8px 0;height:calc(52px + env(safe-area-inset-top));gap:4px}.logo{margin-right:0;font-size:16px}.topbar .divider-v{display:none}.topbar .top-btn{height:34px;padding:0 8px;font-size:11px}.topbar .top-btn span.btn-text-long{display:none}.hamburger-btn{display:flex}.sidebar-l,.sidebar-r,.zoom-ctrl,.user-badge,#auth-btn,.page-tabs.desktop-only{display:none}.main{flex-direction:column}.canvas-wrap{padding:12px 6px 80px}.canvas-outer{gap:8px}.topbar .page-tabs.mobile-only{gap:1px;padding:2px;display:flex}.topbar .page-tabs.mobile-only .page-tab{padding:4px 10px;font-size:10px}.statusbar{display:none}.modal-overlay{align-items:stretch;padding:0}.modal-box{border-radius:0;width:100%;height:100dvh;max-height:100dvh;max-width:none!important}.modal-head{padding:14px 16px;padding-top:calc(14px + env(safe-area-inset-top))}.modal-head h2{font-size:17px}.modal-body{padding:16px}.modal-foot{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.btn{flex:1;padding:12px 18px;font-size:13px}.tpl-grid-modal{grid-template-columns:repeat(2,1fr);gap:10px}.tpl-card{padding:8px}.tpl-card .tpl-title{font-size:12px}.tpl-tabs{scrollbar-width:none;padding:0 12px;overflow-x:auto}.tpl-tabs::-webkit-scrollbar{display:none}.tpl-tab{white-space:nowrap;padding:12px;font-size:11px}.card{box-shadow:0 8px 24px #00000080,0 0 0 1px #ffffff0d}.resize-handle{width:14px;height:14px}.rh-br{bottom:-8px;right:-8px}.rh-bl{bottom:-8px;left:-8px}.rh-tr{top:-8px;right:-8px}.rh-tl{top:-8px;left:-8px}.mobile-fab{display:flex}.bottom-sheet-body .sb-section,.bottom-sheet-body .prop-group{border:none;border-bottom:1px solid #1e1e24;padding:10px 0}.bottom-sheet-body .sb-section:last-child,.bottom-sheet-body .prop-group:last-child{border-bottom:none}.mobile-zoom-indicator{color:#c9a84c;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;background:#111114d9;border:1px solid #2a2a32;border-radius:14px;padding:4px 10px;font-family:DM Mono,monospace;font-size:11px;transition:opacity .3s;position:absolute;top:12px;right:12px}.mobile-zoom-indicator.visible{opacity:1}.card.watermark:after{letter-spacing:5px;font-size:28px}.modal-auth,.modal-pay{margin-top:auto}}@media (max-width:380px){.topbar .top-btn{padding:0 6px;font-size:10px}.logo{font-size:14px}.topbar .page-tabs.mobile-only .page-tab{padding:3px 8px}}.mobile-zoom-controls{left:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:90;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#111114e6;border:1px solid #2a2a32;border-radius:24px;align-items:center;gap:6px;padding:4px;display:none;position:fixed}@media (max-width:768px){.mobile-zoom-controls{display:flex}}.mobile-zoom-controls button{color:#e8e4dc;cursor:pointer;background:0 0;border:none;border-radius:50%;width:36px;height:36px;font-size:18px}.mobile-zoom-controls button:active{background:#2a2a32}.mobile-zoom-controls .zoom-val{text-align:center;color:#c9a84c;min-width:42px;font-family:DM Mono,monospace;font-size:11px}.cardstudio-root{flex:1;width:100%;min-height:0;position:relative;color:#111!important;background:#fff!important}.topbar{color:#111!important;background:#fff!important;border-bottom:1px solid #e5e7eb!important}.logo span{color:#111!important}.divider-v{background:#e5e7eb!important}.top-btn-ghost{color:#4b5563!important}.top-btn-ghost:hover{color:#111!important;background:#f3f4f6!important}.top-btn-feature{color:#c9a84c!important;background:#fff!important;border:1px solid #c9a84c!important}.user-badge{color:#6b7280!important;background:#f9fafb!important}.page-tabs{background:#f3f4f6!important}.page-tab{color:#6b7280!important}.page-tab.active{color:#111!important;background:#c9a84c!important}.zoom-ctrl{color:#6b7280!important}.zoom-ctrl button{color:#111!important;background:#f3f4f6!important}#zoom-label{color:#c9a84c!important}.sidebar-l,.sidebar-r{color:#111!important;background:#f9fafb!important;border-color:#e5e7eb!important}.sidebar-l::-webkit-scrollbar-thumb{background:#d1d5db!important}.sidebar-r::-webkit-scrollbar-thumb{background:#d1d5db!important}.sb-section{border-bottom-color:#f3f4f6!important}.sb-label{color:#9ca3af!important}.sb-label .badge{background:#f3f4f6!important}.field-item{background:#fff!important;border-color:#e5e7eb!important}.field-item.on-card{border-color:#c9a84c!important}.field-item .field-label{color:#6b7280!important}.field-item input{color:#111!important}.field-item input::placeholder{color:#9ca3af!important}.field-mini-btn{color:#6b7280!important;background:#f9fafb!important;border-color:#e5e7eb!important}.field-mini-btn:hover{color:#c9a84c!important;border-color:#c9a84c!important}.upload-area{background:#f9fafb!important;border-color:#e5e7eb!important}.upload-area p{color:#6b7280!important}.image-lib-item{background:#f3f4f6!important;border-color:#e5e7eb!important}.shape-item{background:#f3f4f6!important}.prop-group{border-bottom-color:#f3f4f6!important}.prop-label,.ctrl-row label{color:#6b7280!important}.ctrl-input{color:#111!important;background:#fff!important;border:1px solid #e5e7eb!important}.ctrl-input:focus{border-color:#c9a84c!important}.col-swatch.active{border-color:#111!important}.prop-input,.prop-select,.prop-textarea{color:#111!important;background:#fff!important;border:1px solid #e5e7eb!important}.prop-btn{color:#4b5563!important;background:#f9fafb!important;border-color:#e5e7eb!important}.prop-btn:hover{color:#111!important;background:#f3f4f6!important}.prop-btn.active{color:#c9a84c!important;background:#fef3c7!important;border-color:#c9a84c!important}.align-btn{color:#4b5563!important;background:#fff!important;border:1px solid #e5e7eb!important}.align-btn:hover{color:#111!important;background:#f3f4f6!important}.align-btn.active{color:#c9a84c!important;background:#fef3c7!important;border-color:#c9a84c!important}.font-search{color:#111!important;background:#fff!important;border:1px solid #e5e7eb!important}.font-search::placeholder{color:#9ca3af!important}.font-item{color:#111!important;background:#fff!important;border-color:#e5e7eb!important}.font-item:hover{background:#f3f4f6!important}.font-item.active{background:#fef3c7!important;border-color:#c9a84c!important}input[type=color],.color-swatch{border:1px solid #e5e7eb!important}input[type=range]{accent-color:#c9a84c}.canvas-wrap{background:#f3f4f6!important}.statusbar{color:#6b7280!important;background:#fff!important;border-top-color:#e5e7eb!important}.page-label{color:#9ca3af!important}.modal-box{color:#111!important;background:#fff!important;border-color:#e5e7eb!important}.modal-head{border-bottom-color:#f3f4f6!important}.modal-foot{border-top-color:#f3f4f6!important}.modal-sub{color:#6b7280!important}.btn-secondary{color:#4b5563!important;background:#f3f4f6!important}.btn-secondary:hover{background:#e5e7eb!important}.card{border-radius:0!important;width:650px!important;height:372px!important;box-shadow:0 8px 28px #0000001f,0 0 0 1px #0000000f!important}.canvas-wrap{align-items:flex-start!important;padding-top:130px!important}.canvas-outer{gap:4px!important}.page-label{margin-bottom:2px!important;font-size:9px!important}.card-bg{background:#fff}.el-text{color:#111;white-space:pre;word-break:normal;overflow-wrap:normal}@media (max-width:640px){#cmyk-panel>div[style*=grid]{grid-template-columns:14px 1fr 40px!important;gap:4px!important}.locked-banner{flex-wrap:wrap!important;gap:6px!important;padding:8px 10px!important}.locked-banner-text{white-space:normal!important;flex:100%!important;font-size:11px!important}.locked-banner-bulk{padding:4px 8px!important;font-size:10px!important}.font-list{max-height:180px!important}.color-grid{flex-wrap:wrap!important}}.multi-group-bbox>div[data-dir]{touch-action:none}@media (pointer:coarse){.multi-group-bbox>div[data-dir]{width:22px!important;height:22px!important}}.font-list{display:none!important}.font-list.open{display:flex!important}.canvas-wrap{display:block!important;position:relative!important;overflow:hidden!important}.canvas-outer{transform-origin:50%!important;position:absolute!important;top:50%!important;left:50%!important}@media (max-width:1100px){.guide-legend{display:none!important}}body.has-group-bbox .card-el .resize-handle{display:none!important}body.has-group-bbox .card-el.selected .el-border{opacity:.3}.card{outline-offset:22px!important;outline:2px dashed #3b82f6!important}.card:before{content:"";pointer-events:none;z-index:50;border:1.5px solid #00000073;position:absolute;inset:0}.card:after{content:"";pointer-events:none;z-index:50;border:2px dashed #dc2626;position:absolute;inset:11px}.card-edge-labels{pointer-events:none;z-index:60;letter-spacing:.3px;flex-direction:column;align-items:flex-end;gap:2px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:10px;font-weight:700;display:flex;position:absolute;top:-42px;right:-28px}.card-edge-labels .lbl{white-space:nowrap;background:#fff;border:1px solid;border-radius:3px;padding:1px 6px;line-height:1.5}.card-edge-labels .lbl-bleed{color:#3b82f6}.card-edge-labels .lbl-trim{color:#0009}.card-edge-labels .lbl-safe{color:#dc2626}.canvas-outer{position:relative}.canvas-outer:after{content:none;color:#3b82f6;letter-spacing:.3px;pointer-events:none;z-index:5;background:#fff;border:1.5px solid #3b82f6;border-radius:4px;padding:2px 8px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:11px;font-weight:700;display:none;position:absolute;top:calc(50% - 200px);left:50%;transform:translate(-50%,-100%);box-shadow:0 1px 3px #0000001a}.guide-legend{pointer-events:none;z-index:5;white-space:nowrap;background:#fff;border-radius:6px;gap:16px;padding:8px 14px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:12px;font-weight:700;display:flex;position:absolute;top:12px;left:12px;box-shadow:0 2px 6px #0000001f,0 0 0 1px #0000000d}.guide-legend-item{align-items:center;gap:6px;display:inline-flex}.guide-legend-item.bleed{color:#3b82f6}.guide-legend-item.trim{color:#0009}.guide-legend-item.safe{color:#dc2626}.guide-legend-mark{width:20px;font-size:14px;font-weight:900;line-height:1;display:inline-block}@media (max-width:768px){.guide-legend{display:none}.card{outline-offset:12px!important}.card:after{inset:12px}.card:before,.card:after{padding:1px 3px;font-size:8px}.canvas-outer:after{font-size:8px}}.exporting .card:before,.exporting .card:after,.exporting .guide-legend,.exporting .canvas-outer:after{display:none!important}.exporting .card:before,.exporting .card:after{content:""}.exporting .card{outline:none!important}.card-el.multi-selected{outline-offset:2px;background-color:#5dade214;outline:2px solid #5dade2!important}.card-el[data-locked=true]{position:relative}.card-el[data-locked=true]:after{content:"🔒";pointer-events:none;z-index:60;background:#ffffffd9;border-radius:3px;padding:1px 3px;font-size:11px;position:absolute;top:2px;right:2px}.rubber-band{pointer-events:none;background:#5dade226;border:1px dashed #5dade2;position:absolute}.align-toolbar{z-index:100;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:4px;padding:6px 8px;font-family:DM Sans,Noto Sans KR,sans-serif;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000a}.align-toolbar .align-count{color:#5dade2;padding:0 6px;font-size:12px;font-weight:700}.align-toolbar .align-divider{background:#e5e7eb;width:1px;height:18px}.align-toolbar button{cursor:pointer;color:#4b5563;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:background .12s;display:inline-flex}.align-toolbar button:hover{color:#111;background:#f3f4f6}.align-toolbar button:active{background:#e5e7eb}.align-toolbar .align-danger{color:#dc2626}.align-toolbar .align-danger:hover{color:#b91c1c;background:#fee2e2}.align-toolbar .align-close{color:#9ca3af;font-size:12px}@media (max-width:768px){.align-toolbar{border-radius:24px;gap:2px;padding:4px 6px;top:auto;bottom:80px;left:50%;transform:translate(-50%)}.align-toolbar .align-count{padding:0 4px;font-size:11px}.align-toolbar button{width:36px;height:36px;font-size:14px}}.modal-preview{max-width:720px}.preview-body{background:#f3f4f6;min-height:200px;padding:30px 20px!important}.preview-loading{text-align:center;color:#6b7280;padding:40px 20px;font-size:13px}.preview-cards{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.preview-card-wrap{flex-direction:column;align-items:center;gap:8px;display:flex}.preview-label{color:#6b7280;letter-spacing:1px;text-transform:uppercase;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600}.preview-card{background:#fff;width:90mm;height:50mm;position:relative;overflow:hidden;box-shadow:0 4px 14px #0000002e,0 0 0 1px #0000000f}.preview-card img{display:block}@media (max-width:768px){.preview-cards{gap:16px}.preview-card{transform-origin:50%;transform:scale(.95)}}@media (max-width:380px){.preview-card{transform:scale(.85)}}.admin-save-btn{margin-left:8px;color:#fff!important;background:#2563eb!important}.admin-save-btn:hover{background:#1d4ed8!important}.company-bulk-panel{margin-bottom:12px}.company-bulk-hint{color:#5b4d1a;background:#fef9e9;border:1px solid #f0e0a8;border-radius:6px;padding:10px 14px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:12px;line-height:1.5}.company-bulk-hint b{color:#111}.locked-banner{z-index:90;color:#fff;background:#1e3a8a;border-radius:8px;align-items:center;gap:10px;max-width:calc(100vw - 24px);padding:8px 8px 8px 14px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:12px;display:inline-flex;position:fixed;top:60px;left:50%;transform:translate(-50%);box-shadow:0 4px 14px #1e3a8a66}.locked-banner-icon{flex-shrink:0;font-size:14px}.locked-banner-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.locked-banner-bulk{color:#111;cursor:pointer;white-space:nowrap;background:#c9a84c;border:none;border-radius:5px;flex-shrink:0;padding:6px 10px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:11.5px;font-weight:700;transition:background .12s}.locked-banner-bulk:hover{background:#e8cc7a}.cardstudio-root.locked-layout .card-el{cursor:default!important}.cardstudio-root.locked-layout .card-el .resize-handle,.cardstudio-root.locked-layout .sidebar-r{display:none!important}.cardstudio-root.locked-layout .main{padding-right:0}.cardstudio-root.locked-layout #shape-btn,.cardstudio-root.locked-layout button[onclick*=addImage],.cardstudio-root.locked-layout button[onclick*=undo],.cardstudio-root.locked-layout button[onclick*=deleteSelected],:is(.cardstudio-root.locked-layout .sb-section:has(.upload-area),.cardstudio-root.locked-layout .sb-section:has(.image-lib)){display:none!important}.cardstudio-root.locked-layout .card-el .el-text{-webkit-user-modify:read-only;-webkit-user-select:none!important;user-select:none!important}@media (max-width:768px){.locked-banner{flex-wrap:wrap;gap:6px;max-width:calc(100vw - 16px);padding:6px 6px 6px 10px;font-size:11px;top:56px}.locked-banner-text{white-space:normal;flex-basis:100%;order:1;line-height:1.3}.locked-banner-bulk{order:2;padding:5px 8px;font-size:10.5px}.locked-banner-icon{order:0}}.shape-popover{z-index:200;background:#fff;border:1px solid #e5e7eb;border-radius:10px;width:320px;max-width:calc(100vw - 24px);padding:12px;font-family:DM Sans,Noto Sans KR,sans-serif;animation:.12s ease-out shapePopoverIn;display:none;position:fixed;top:0;left:0;box-shadow:0 10px 28px #00000026,0 0 0 1px #0000000a}.shape-popover.open{display:block}@keyframes shapePopoverIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.shape-popover-section{margin-bottom:12px}.shape-popover-section:last-child{margin-bottom:0}@media (max-width:768px){.shape-popover{width:100%;max-width:100%;padding:14px 14px calc(14px + env(safe-area-inset-bottom));border-radius:14px 14px 0 0;animation:.18s ease-out shapePopoverInMobile;bottom:0;top:auto!important;left:0!important}@keyframes shapePopoverInMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.shape-picker-section{margin-bottom:18px}.shape-picker-section:last-child{margin-bottom:0}.shape-picker-label{letter-spacing:.8px;color:#6b7280;text-transform:uppercase;margin-bottom:8px;font-size:10px;font-weight:700}.shape-picker-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.shape-picker-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:8px 2px;font-family:DM Sans,Noto Sans KR,sans-serif;transition:all .12s;display:flex}.shape-picker-item:hover{background:#fef9e9;border-color:#c9a84c}.shape-picker-item span{color:#111;font-size:18px;line-height:1}.shape-picker-item em{color:#6b7280;font-size:9px;font-style:normal;font-weight:500}.logo-becopy{white-space:nowrap;align-items:center;gap:10px;color:inherit!important;font-family:Noto Sans KR,sans-serif!important;font-size:inherit!important;line-height:1!important;text-decoration:none!important;display:inline-flex!important}.logo-becopy .logo-mark{width:32px;height:24px;display:inline-flex}.logo-becopy .logo-mark svg{width:100%;height:100%}.logo-becopy .logo-text{flex-direction:column;gap:1px;line-height:1;display:inline-flex}.logo-becopy .logo-tag{letter-spacing:.5px;text-transform:uppercase;font-family:DM Sans,sans-serif;font-size:8px;font-weight:600;color:#5dade2!important}.logo-becopy .logo-name{letter-spacing:-.3px;font-size:17px;font-weight:700;color:#5dade2!important}@media (max-width:768px){.logo-becopy .logo-mark{width:26px;height:20px}.logo-becopy .logo-tag{font-size:7px}.logo-becopy .logo-name{font-size:14px}}.order-cta{z-index:100;color:#111;cursor:pointer;background:#c9a84c;border:none;border-radius:28px;align-items:center;gap:12px;min-width:160px;height:56px;padding:0 22px;font-family:DM Sans,Noto Sans KR,sans-serif;font-size:15px;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;position:fixed;bottom:24px;right:24px;box-shadow:0 6px 20px #c9a84c59,0 2px 6px #0003}.order-cta:hover{background:#e8cc7a;transform:translateY(-1px);box-shadow:0 8px 24px #c9a84c73,0 3px 8px #00000040}.order-cta:active{transform:translateY(0)}.order-cta-label{font-size:15px;font-weight:700}.order-cta-arrow{font-size:18px;font-weight:700;line-height:1}@media (max-width:768px){.order-cta{left:14px;right:auto;bottom:calc(14px + env(safe-area-inset-bottom));gap:8px;min-width:0;height:48px;padding:0 18px;font-size:13px}.order-cta-label{font-size:13px}.order-cta-arrow{font-size:16px}}.autosave-pill{z-index:9999;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.85;background:#fffffff0;border:1px solid #00000014;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;transition:opacity .2s;position:fixed;top:12px;right:12px;box-shadow:0 1px 3px #00000014}.autosave-pill[data-status=saving]{color:#6b7280}.autosave-pill[data-status=saved]{color:#15803d}.autosave-pill[data-status=idle]{color:#6b7280;opacity:.6}.autosave-pill[data-status=error]{color:#b91c1c}@media (max-width:768px){.autosave-pill{padding:4px 9px;font-size:11px;top:8px;right:8px}}
