:root{--cream: #f7f1e8;--cream-deep: #efe6d8;--paper: #ffffff;--ink: #2e2a26;--ink-soft: #6f665c;--rouge: #a8524c;--gold: #bfa15f;--blush: #e7c9c2;--line: #e4d8c7;--shadow: 0 18px 50px -28px rgba(46, 42, 38, .45)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--cream);color:var(--ink);font-family:Jost,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}h1,h2,h3,h4,.display{font-family:Cormorant Garamond,Times New Roman,serif;letter-spacing:.2px;font-weight:600}.app-shell{height:100dvh;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 22px;background:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);flex:none}.brand{display:flex;align-items:baseline;gap:10px}.brand .mark{font-family:Cormorant Garamond,serif;font-size:26px;font-weight:600;color:var(--ink);line-height:1}.brand .sub{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--ink-soft)}.studio{flex:1;min-height:0;display:grid;grid-template-columns:300px 1fr 320px;gap:0}.panel{min-height:0;overflow:auto;padding:18px}.panel--left{border-right:1px solid var(--line);background:#fffdf9}.panel--right{border-left:1px solid var(--line);background:#fffdf9;display:flex;flex-direction:column;overflow:hidden;padding:0}.tray-scroll{flex:1;min-height:0;overflow:auto;padding:18px 18px 8px}.pricebox{flex:none;padding:4px 18px 16px;background:#fffdf9}.stage-wrap{min-height:0;min-width:0;height:100%;flex:1 1 auto;position:relative;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 90% at 50% 0%,#fffdf9 0%,var(--cream) 60%,var(--cream-deep) 100%);overflow:hidden}.eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink-soft);margin:0 0 8px}.section-title{font-size:21px;margin:0 0 14px}.stage{position:relative;touch-action:none;user-select:none;-webkit-user-select:none;filter:drop-shadow(0 30px 40px rgba(46,42,38,.18))}.stage-blank{position:absolute;top:0;right:0;bottom:0;left:0;display:block;pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.charm{position:absolute;touch-action:none;cursor:grab;transform-origin:center center;will-change:transform}.charm img{width:100%;height:100%;display:block;pointer-events:none;-webkit-user-drag:none;filter:drop-shadow(0 3px 4px rgba(46,42,38,.28))}.charm.is-dragging{cursor:grabbing;z-index:50!important}.charm.is-selected{outline:1.5px dashed var(--rouge);outline-offset:3px;border-radius:6px}.charm.is-bad{outline:2px solid #d4380d;outline-offset:3px;border-radius:6px}.charm.is-bad img{filter:drop-shadow(0 0 0 #d4380d) saturate(.6)}.charm-tools{position:absolute;z-index:60;display:flex;gap:6px;padding:6px;background:#fff;border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow)}.tray-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.charm-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;display:flex;flex-direction:column;gap:8px;cursor:grab;transition:transform .12s ease,box-shadow .12s ease,border-color .12s;touch-action:none}.charm-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--blush)}.charm-card .thumb{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,#fff,#faf5ec);border-radius:8px}.charm-card .thumb img{max-width:78%;max-height:78%;-webkit-user-drag:none;filter:drop-shadow(0 4px 6px rgba(46,42,38,.22))}.charm-card .name{font-size:12.5px;line-height:1.25;color:var(--ink)}.charm-card .meta{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--ink-soft)}.tray-grid--compact{grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:8px}.charm-card--compact{padding:5px;gap:4px;border-radius:9px;cursor:pointer}.charm-card--compact .thumb{border-radius:6px}.charm-card--compact .thumb img{max-width:84%;max-height:84%}.charm-card--compact .meta{font-size:10.5px;justify-content:center;gap:5px}.charm-card--compact .meta .ant-tag{margin:0;padding:0 5px;font-size:10px;line-height:16px}.charm-row{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;padding:2px 0 8px;scrollbar-width:thin}.charm-row::-webkit-scrollbar{height:4px}.charm-row::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.charm-card--row{flex:0 0 auto;width:76px;scroll-snap-align:start}.charm-card--compact,.charm-card--row{touch-action:manipulation;cursor:pointer}.charm-card--compact:hover,.charm-card--row:hover{transform:none}.charm-card--compact .thumb,.charm-card--row .thumb{aspect-ratio:1 / 1;width:100%;max-height:72px;overflow:hidden}.charm-card--compact .thumb img,.charm-card--row .thumb img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.ghost-drag{position:fixed;z-index:4000;pointer-events:none;transform:translate(-50%,-50%);filter:drop-shadow(0 8px 10px rgba(46,42,38,.3))}.ghost-drag img{display:block}.pricebar{flex:none;margin-top:auto;border-top:1px solid var(--line);padding-top:14px}.price-row{display:flex;align-items:baseline;justify-content:space-between}.price-row .total{font-family:Cormorant Garamond,serif;font-size:30px;font-weight:600}.hint{font-size:12px;color:var(--ink-soft);line-height:1.4}.mobile-bar{display:none}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500}.pill--ok{background:#eef3ea;color:#4f6b3f}.pill--warn{background:#fdecea;color:#c0392b}.summary-layout{display:grid;grid-template-columns:1fr 1fr 280px;gap:18px}.summary-layout .proof-img{max-height:300px;max-width:100%}@media (max-width: 1080px){.studio{grid-template-columns:260px 1fr}.panel--right{display:none}}@media (max-width: 760px){.studio{grid-template-columns:1fr}.panel--left{display:none}.topbar{padding:10px 14px}.mobile-shell{flex:1;min-height:0;display:flex;flex-direction:column}.mobile-stage{flex:1 1 auto;min-height:0;position:relative;display:flex;overflow:hidden}.mobile-tray{flex:0 0 42%;min-height:0;display:flex;flex-direction:column;background:#fffdf9;border-top:1px solid var(--line);box-shadow:0 -10px 26px #2e2a261a}.mobile-tray-head{flex:none;display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--line);background:#fff}.mobile-base-btn{min-width:0;max-width:42vw}.mobile-base-btn>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-cat-select{flex:none;width:96px}.mobile-hint{margin:0 0 8px;padding:0;font-size:11.5px;line-height:1.35;color:var(--ink-soft)}.mobile-tray-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;padding:8px 12px calc(14px + env(safe-area-inset-bottom))}.mobile-tray-body .charm-collection:last-child{margin-bottom:0}.summary-layout{grid-template-columns:1fr 1fr;gap:12px}.summary-layout .summary-order{grid-column:1 / -1}.summary-layout .proof-img{max-height:190px}}.zoom-dock{position:absolute;right:14px;bottom:14px;display:flex;flex-direction:column;gap:8px;align-items:center;background:#ffffffe6;border:1px solid var(--line);border-radius:999px;padding:8px 6px;box-shadow:var(--shadow)}@media (max-width: 760px){.zoom-dock{bottom:12px}}.dropzone{border:1.5px dashed var(--line);border-radius:14px;background:#fffdf9;padding:26px;text-align:center;transition:border-color .15s,background .15s}.dropzone.drag{border-color:var(--rouge);background:#fdf4ee}.measure-canvas{max-width:100%;border-radius:12px;border:1px solid var(--line);background:#fff}
