/* ================================================================
   GLM Designer V4 — CSS scoped to #glm-v4-wrapper
   Extracted from GLM_Designer_Tool_v4.html and scoped so that
   WordPress theme styles cannot interfere with the designer layout.
   ================================================================ */

/* Load Jost font (used throughout V4 designer) */
@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

#glm-v4-wrapper *{box-sizing:border-box;margin:0;padding:0;}
:root{ --copper:#c8922a; --copper-lt:#e8b84b; --black:#111; --gray:#6b6b6b; --lgray:#f0ede8; --border:#e0dcd6; --white:#fff; --accent:#111; --radius:12px; }
#glm-v4-wrapper{font-family:'Jost',sans-serif;background:var(--lgray);color:var(--black);height:100%;overflow:hidden;display:flex;flex-direction:column;}
#glm-v4-wrapper header{background:#fff;border-bottom:1px solid var(--border);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;flex-shrink:0;z-index:200;}
#glm-v4-wrapper .logo-wrap{display:flex;align-items:center;gap:12px;}
#glm-v4-wrapper .logo-img{height:28px;object-fit:contain;}
#glm-v4-wrapper .logo-name{font-size:15px;font-weight:600;letter-spacing:0.5px;color:var(--black);}
#glm-v4-wrapper .logo-sub{font-size:12px;color:var(--gray);margin-left:4px;}
#glm-v4-wrapper .header-right{display:flex;align-items:center;gap:12px;}
#glm-v4-wrapper .hbtn{background:transparent;border:1px solid #d0ccc8;color:var(--gray);font-family:'Jost',sans-serif;font-size:13px;font-weight:500;padding:8px 18px;border-radius:6px;cursor:pointer;transition:all .15s;}
#glm-v4-wrapper .hbtn:hover{border-color:#999;color:var(--black);}
#glm-v4-wrapper .hbtn.pri{background:var(--black);border-color:var(--black);color:#fff;}
#glm-v4-wrapper .hbtn.pri:hover{background:#333;}
#glm-v4-wrapper .hbtn.gold{background:var(--copper);border-color:var(--copper);color:#fff;font-weight:600;}
#glm-v4-wrapper .hbtn.gold:hover{background:var(--copper-lt);}
#glm-v4-wrapper .app{display:grid;grid-template-columns:0px 1fr 420px;flex:1;min-height:0;transition:grid-template-columns .35s cubic-bezier(.4,0,.2,1);}
#glm-v4-wrapper .app.drawer-open{grid-template-columns:340px 1fr 420px;}
#glm-v4-wrapper .drawer{background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transform:translateX(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
#glm-v4-wrapper .app.drawer-open .drawer{transform:translateX(0);}
#glm-v4-wrapper .drawer-header{padding:20px 20px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0;}
#glm-v4-wrapper .drawer-title{font-size:16px;font-weight:600;}
#glm-v4-wrapper .drawer-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--gray);padding:0 4px;line-height:1;}
#glm-v4-wrapper .drawer-search{padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
#glm-v4-wrapper .drawer-search input{width:100%;border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-family:'Jost',sans-serif;font-size:14px;outline:none;background:#f8f7f5;}
#glm-v4-wrapper .drawer-search input:focus{border-color:#999;}
#glm-v4-wrapper .drawer-cats{display:flex;gap:0;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;}
#glm-v4-wrapper .dcat{flex:1;min-width:fit-content;padding:10px 8px;border:none;background:none;font-family:'Jost',sans-serif;font-size:12px;font-weight:500;color:var(--gray);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;}
#glm-v4-wrapper .dcat.on{color:var(--black);border-bottom-color:var(--black);}
#glm-v4-wrapper .drawer-count{padding:8px 16px;font-size:12px;color:var(--gray);border-bottom:1px solid var(--border);flex-shrink:0;}
#glm-v4-wrapper .stamp-grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-content:start;}
#glm-v4-wrapper .stamp-grid::-webkit-scrollbar{width:4px;}
#glm-v4-wrapper .stamp-grid::-webkit-scrollbar-thumb{background:#e0dcd6;border-radius:2px;}
#glm-v4-wrapper .stamp-tile{border:1.5px solid var(--border);border-radius:8px;padding:8px 4px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;aspect-ratio:1;transition:all .15s;background:#fff;position:relative;}
#glm-v4-wrapper .stamp-tile:hover{border-color:#999;transform:scale(1.04);}
#glm-v4-wrapper .stamp-tile.sel{border-color:var(--black);border-width:2px;background:#f8f7f5;}
#glm-v4-wrapper .stamp-tile img{width:100%;flex:1;object-fit:contain;min-height:0;}
#glm-v4-wrapper .stamp-tile canvas{width:100%;flex:1;}
#glm-v4-wrapper .stamp-tile .sn{font-size:7px;color:var(--gray);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;}
#glm-v4-wrapper .stamp-tile .sz{position:absolute;top:3px;right:3px;font-size:6px;background:#f0ede8;color:#888;padding:1px 3px;border-radius:2px;}
#glm-v4-wrapper .no-results{grid-column:span 4;text-align:center;padding:24px 12px;font-size:13px;color:var(--gray);}
#glm-v4-wrapper .canvas-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--lgray);position:relative;overflow:hidden;}
#glm-v4-wrapper .canvas-area::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 48%,rgba(255,255,255,0.6) 0%,transparent 100%);pointer-events:none;}
#glm-v4-wrapper .canvas-badge{background:#fff;border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:11px;color:var(--gray);font-weight:500;z-index:2;}
#glm-v4-wrapper #cvwrap{position:relative;z-index:2;filter:drop-shadow(0 4px 32px rgba(0,0,0,0.12));}
#glm-v4-wrapper #mc{display:block;border-radius:50%;}
#glm-v4-wrapper .canvas-caption{font-size:11px;color:#aaa;letter-spacing:1px;z-index:2;}
#glm-v4-wrapper .canvas-undo{display:flex;gap:8px;z-index:2;}
#glm-v4-wrapper .undo-btn{background:#fff;border:1px solid var(--border);border-radius:6px;padding:7px 16px;font-family:'Jost',sans-serif;font-size:12px;font-weight:500;color:var(--gray);cursor:pointer;transition:all .15s;}
#glm-v4-wrapper .undo-btn:hover{border-color:#999;color:var(--black);}
#glm-v4-wrapper .el-toolbar{position:absolute;background:#fff;border:1px solid var(--border);border-radius:8px;padding:7px 10px;display:none;gap:8px;align-items:center;z-index:50;box-shadow:0 4px 16px rgba(0,0,0,0.12);white-space:nowrap;}
#glm-v4-wrapper .el-toolbar.vis{display:flex;}
#glm-v4-wrapper .et-chip{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;flex-shrink:0;transition:all .12s;}
#glm-v4-wrapper .et-chip:hover{transform:scale(1.15);}
#glm-v4-wrapper .et-chip.on{border-color:var(--black);transform:scale(1.1);}
#glm-v4-wrapper .color-popover{position:absolute;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,0.15);display:none;width:220px;}
#glm-v4-wrapper .color-popover.vis{display:block;}
#glm-v4-wrapper .color-popover-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:10px;}
#glm-v4-wrapper .cp-chip{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all .12s;}
#glm-v4-wrapper .cp-chip:hover{transform:scale(1.12);}
#glm-v4-wrapper .cp-chip.on{border-color:var(--black);}
#glm-v4-wrapper .cp-apply{width:100%;padding:8px;background:var(--black);color:#fff;border:none;border-radius:6px;font-family:'Jost',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;}
#glm-v4-wrapper .cp-apply:hover{background:#333;}
#glm-v4-wrapper .et-sep{width:1px;height:18px;background:var(--border);}
#glm-v4-wrapper .et-btn{background:none;border:none;font-size:14px;cursor:pointer;color:var(--gray);padding:2px 4px;border-radius:4px;transition:all .12s;}
#glm-v4-wrapper .et-btn:hover{background:#f0ede8;color:var(--black);}
#glm-v4-wrapper .et-btn.del{color:#cc3333;}
#glm-v4-wrapper .et-btn.del:hover{background:#fde8e0;}
#glm-v4-wrapper .et-rot{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--gray);}
#glm-v4-wrapper .et-rot input[type=range]{width:60px;-webkit-appearance:none;height:2px;background:#e0dcd6;border-radius:1px;outline:none;}
#glm-v4-wrapper .et-rot input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--black);border-radius:50%;cursor:pointer;}
#glm-v4-wrapper .config{background:#fff;border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
#glm-v4-wrapper .config-scroll{flex:1;overflow-y:auto;padding-bottom:20px;}
#glm-v4-wrapper .config-scroll::-webkit-scrollbar{width:4px;}
#glm-v4-wrapper .config-scroll::-webkit-scrollbar-thumb{background:#e0dcd6;}
#glm-v4-wrapper .step{border-bottom:1px solid var(--border);}
#glm-v4-wrapper .step-header{padding:20px 28px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none;}
#glm-v4-wrapper .step-header:hover .step-num{background:#f0ede8;}
#glm-v4-wrapper .step-num{width:28px;height:28px;border-radius:50%;border:1.5px solid #d0ccc8;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--gray);flex-shrink:0;transition:all .2s;margin-right:14px;}
#glm-v4-wrapper .step-num.done{background:var(--black);border-color:var(--black);color:#fff;}
#glm-v4-wrapper .step-label{font-size:16px;font-weight:600;color:var(--black);flex:1;}
#glm-v4-wrapper .step-summary{font-size:13px;color:var(--gray);margin-left:8px;}
#glm-v4-wrapper .step-chev{font-size:11px;color:#bbb;transition:transform .2s;}
#glm-v4-wrapper .step.open .step-chev{transform:rotate(180deg);}
#glm-v4-wrapper .step-body{padding:0 28px 20px;display:none;}
#glm-v4-wrapper .step.open .step-body{display:block;}
#glm-v4-wrapper .finish-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px;}
#glm-v4-wrapper .finish-card{border:2px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;}
#glm-v4-wrapper .finish-card:hover{border-color:#999;}
#glm-v4-wrapper .finish-card.sel{border-color:var(--black);}
#glm-v4-wrapper .finish-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
#glm-v4-wrapper .finish-card-label{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;}
#glm-v4-wrapper .finish-card-name{font-size:14px;font-weight:600;}
#glm-v4-wrapper .finish-card-price{font-size:12px;color:var(--gray);}
#glm-v4-wrapper .finish-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;}
#glm-v4-wrapper .finish-card.sel .finish-check{background:var(--black);border-color:var(--black);color:#fff;}
#glm-v4-wrapper .opt-rows{display:flex;flex-direction:column;gap:8px;}
#glm-v4-wrapper .opt-row{border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:space-between;}
#glm-v4-wrapper .opt-row:hover{border-color:#999;}
#glm-v4-wrapper .opt-row.sel{border-color:var(--black);border-width:2px;}
#glm-v4-wrapper .opt-row-left{display:flex;flex-direction:column;gap:2px;}
#glm-v4-wrapper .opt-row-name{font-size:15px;font-weight:500;}
#glm-v4-wrapper .opt-row-desc{font-size:12px;color:var(--gray);}
#glm-v4-wrapper .opt-row-right{display:flex;align-items:center;gap:10px;}
#glm-v4-wrapper .opt-price{font-size:15px;font-weight:600;}
#glm-v4-wrapper .opt-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;}
#glm-v4-wrapper .opt-row.sel .opt-check{background:var(--black);border-color:var(--black);color:#fff;}
#glm-v4-wrapper .add-section{margin-top:16px;}
#glm-v4-wrapper .add-btn{width:100%;border:1.5px dashed #d0ccc8;border-radius:10px;padding:14px;background:transparent;font-family:'Jost',sans-serif;font-size:14px;font-weight:500;color:var(--gray);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;}
#glm-v4-wrapper .add-btn:hover{border-color:#999;color:var(--black);background:#f8f7f5;}
#glm-v4-wrapper .add-btn.active{border-style:solid;border-color:var(--black);color:var(--black);background:#f8f7f5;}
#glm-v4-wrapper .text-panel{background:#f8f7f5;border-radius:10px;padding:16px;margin-top:12px;display:none;}
#glm-v4-wrapper .text-panel.vis{display:block;}
#glm-v4-wrapper .tp-field{margin-bottom:14px;}
#glm-v4-wrapper .tp-field:last-child{margin-bottom:0;}
#glm-v4-wrapper .tp-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gray);margin-bottom:6px;display:block;}
#glm-v4-wrapper .tp-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-family:'Jost',sans-serif;font-size:15px;outline:none;background:#fff;}
#glm-v4-wrapper .tp-input:focus{border-color:#999;}
#glm-v4-wrapper .font-btns{display:flex;gap:6px;}
#glm-v4-wrapper .font-btn{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:10px 6px;cursor:pointer;text-align:center;background:#fff;transition:all .15s;}
#glm-v4-wrapper .font-btn:hover{border-color:#999;}
#glm-v4-wrapper .font-btn.on{border-color:var(--black);border-width:2px;background:#fff;}
#glm-v4-wrapper .font-btn-s{font-size:22px;line-height:1.3;height:30px;display:flex;align-items:center;justify-content:center;}
#glm-v4-wrapper .font-btn-n{font-size:10px;color:var(--gray);margin-top:4px;font-weight:500;}
#glm-v4-wrapper .color-chips{display:flex;gap:6px;flex-wrap:wrap;}
#glm-v4-wrapper .cc{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all .12s;flex-shrink:0;}
#glm-v4-wrapper .cc.on{border-color:var(--black);}
#glm-v4-wrapper .size-row{display:flex;align-items:center;gap:10px;}
#glm-v4-wrapper .size-row input[type=range]{flex:1;-webkit-appearance:none;height:3px;background:#e0dcd6;border-radius:2px;outline:none;}
#glm-v4-wrapper .size-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--black);border-radius:50%;cursor:pointer;}
#glm-v4-wrapper .size-val{font-size:13px;font-weight:500;min-width:24px;text-align:right;}
#glm-v4-wrapper .place-btns{display:flex;gap:6px;}
#glm-v4-wrapper .place-btn{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:9px 4px;background:#fff;font-family:'Jost',sans-serif;font-size:12px;font-weight:500;color:var(--gray);cursor:pointer;transition:all .15s;text-align:center;}
#glm-v4-wrapper .place-btn:hover{border-color:#999;color:var(--black);}
#glm-v4-wrapper .stamp-color-panel{background:#f8f7f5;border-radius:10px;padding:14px 16px;margin-top:10px;display:none;}
#glm-v4-wrapper .stamp-color-panel.vis{display:block;}
#glm-v4-wrapper .order-bar{padding:20px 28px;border-top:1px solid var(--border);background:#fff;flex-shrink:0;}
#glm-v4-wrapper .price-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;}
#glm-v4-wrapper .price-label{font-size:13px;color:var(--gray);}
#glm-v4-wrapper .price-val{font-size:32px;font-weight:700;color:var(--black);}
#glm-v4-wrapper .price-note{font-size:11px;color:var(--copper);font-weight:500;}
#glm-v4-wrapper .order-btns{display:flex;gap:10px;}
#glm-v4-wrapper .order-btn{flex:1;padding:14px;border-radius:10px;font-family:'Jost',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none;text-align:center;}
#glm-v4-wrapper .order-btn.secondary{background:#f0ede8;color:var(--black);}
#glm-v4-wrapper .order-btn.secondary:hover{background:#e8e4de;}
#glm-v4-wrapper .order-btn.primary{background:var(--black);color:#fff;}
#glm-v4-wrapper .order-btn.primary:hover{background:#333;}
#glm-v4-wrapper .moverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:1000;align-items:center;justify-content:center;}
#glm-v4-wrapper .moverlay.show{display:flex;}
#glm-v4-wrapper .modal{background:#fff;width:500px;max-width:92vw;border-radius:16px;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,0.2);}
#glm-v4-wrapper .modal h3{font-size:22px;font-weight:700;margin-bottom:6px;}
#glm-v4-wrapper .modal p{font-size:14px;color:var(--gray);margin-bottom:24px;line-height:1.6;}
#glm-v4-wrapper .modal-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;}
#glm-v4-wrapper .modal-step{background:#f8f7f5;border-radius:10px;padding:16px 18px;display:flex;gap:14px;align-items:flex-start;}
#glm-v4-wrapper .modal-step-num{width:28px;height:28px;border-radius:50%;background:var(--black);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
#glm-v4-wrapper .modal-step-title{font-size:13px;font-weight:600;margin-bottom:3px;}
#glm-v4-wrapper .modal-step-desc{font-size:12px;color:var(--gray);line-height:1.5;}
#glm-v4-wrapper .woo-btn{width:100%;padding:14px;background:var(--black);color:#fff;border:none;border-radius:10px;font-family:'Jost',sans-serif;font-size:15px;font-weight:600;cursor:pointer;margin-bottom:8px;transition:all .2s;}
#glm-v4-wrapper .woo-btn:hover{background:#333;}
#glm-v4-wrapper .modal-footer{display:flex;gap:8px;}
#glm-v4-wrapper .modal-footer button{flex:1;padding:11px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:'Jost',sans-serif;font-size:13px;font-weight:500;cursor:pointer;color:var(--gray);transition:all .15s;}
#glm-v4-wrapper .modal-footer button:hover{border-color:#999;color:var(--black);}
#glm-v4-wrapper .modal-contact{text-align:center;font-size:12px;color:var(--gray);margin-top:14px;}
#glm-v4-wrapper .modal-contact a{color:var(--black);font-weight:600;text-decoration:none;}
@media (max-width: 768px) {
#glm-v4-wrapper{overflow:auto;}
#glm-v4-wrapper header{padding:0 16px;height:50px;}
#glm-v4-wrapper .logo-name{font-size:13px;}
#glm-v4-wrapper .logo-sub{display:none;}
#glm-v4-wrapper .logo-img{height:24px;}
#glm-v4-wrapper .header-right .hbtn:not(.gold){display:none;}
#glm-v4-wrapper .hbtn.gold{font-size:12px;padding:7px 14px;}
#glm-v4-wrapper .app{display:flex;flex-direction:column;overflow:hidden;height:auto;}
#glm-v4-wrapper .app.drawer-open{grid-template-columns:unset;}
#glm-v4-wrapper .drawer{display:none !important;}
#glm-v4-wrapper .canvas-area{width:100%;min-height:0;padding:12px 0 8px;flex-shrink:0;order:1;overflow:hidden;}
#glm-v4-wrapper #mc{max-width:calc(100vw - 32px) !important;max-height:calc(100vw - 32px) !important;}
#glm-v4-wrapper .canvas-badge{font-size:11px;padding:4px 12px;}
#glm-v4-wrapper .canvas-undo{gap:6px;}
#glm-v4-wrapper .undo-btn{font-size:12px;padding:6px 14px;}
#glm-v4-wrapper .canvas-caption{font-size:10px;}
#glm-v4-wrapper .config{width:100%;border-left:none;border-top:1px solid var(--border);order:2;overflow:visible;max-height:none;}
#glm-v4-wrapper .config-scroll{overflow:visible;padding-bottom:180px;}
#glm-v4-wrapper .step-header{padding:16px 20px 12px;}
#glm-v4-wrapper .step-label{font-size:15px;}
#glm-v4-wrapper .step-body{padding:0 20px 16px;}
#glm-v4-wrapper .opt-row{padding:12px 14px;}
#glm-v4-wrapper .opt-row-name{font-size:14px;}
#glm-v4-wrapper .finish-cards{grid-template-columns:1fr 1fr;gap:10px;}
#glm-v4-wrapper .text-panel{padding:14px;}
#glm-v4-wrapper .tp-input{font-size:16px;}
#glm-v4-wrapper .order-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:12px 16px;box-shadow:0 -4px 20px rgba(0,0,0,0.1);}
#glm-v4-wrapper .price-val{font-size:22px;}
#glm-v4-wrapper .order-btns{gap:8px;}
#glm-v4-wrapper .order-btn{padding:12px;font-size:13px;}
#glm-v4-wrapper .mobile-drawer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -8px 32px rgba(0,0,0,0.15);z-index:300;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);max-height:55vh;display:flex;flex-direction:column;}
#glm-v4-wrapper .mobile-drawer.open{transform:translateY(0);}
#glm-v4-wrapper .mobile-drawer-handle{width:40px;height:4px;background:#d0ccc8;border-radius:2px;margin:12px auto 8px;flex-shrink:0;}
#glm-v4-wrapper .mobile-drawer-header{padding:0 16px 10px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
#glm-v4-wrapper .mobile-drawer-title{font-size:16px;font-weight:600;}
#glm-v4-wrapper .mobile-drawer-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--gray);padding:0;}
#glm-v4-wrapper .mobile-drawer-search{padding:0 16px 10px;flex-shrink:0;}
#glm-v4-wrapper .mobile-drawer-search input{width:100%;border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-size:16px;outline:none;background:#f8f7f5;}
#glm-v4-wrapper .mobile-drawer-cats{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;padding:0 16px;}
#glm-v4-wrapper .mobile-drawer-content{flex:1;overflow-y:auto;padding:12px 16px;}
#glm-v4-wrapper .mobile-stamp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;}
#glm-v4-wrapper .mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:299;}
#glm-v4-wrapper .mobile-overlay.show{display:block;}
#glm-v4-wrapper .el-toolbar{padding:8px 12px;gap:10px;}
#glm-v4-wrapper .et-btn{font-size:18px;padding:4px 6px;}
#glm-v4-wrapper .color-popover{left:16px !important;right:16px !important;width:auto !important;}
#glm-v4-wrapper .color-popover-grid{grid-template-columns:repeat(6,1fr);}
#glm-v4-wrapper .modal{padding:24px 20px;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;}
#glm-v4-wrapper .moverlay{align-items:flex-end;}
}
@media (max-width: 380px) {
#glm-v4-wrapper .mobile-stamp-grid{grid-template-columns:repeat(4,1fr);}
#glm-v4-wrapper .finish-cards{grid-template-columns:1fr 1fr;}
}
#glm-v4-wrapper .qcp{position:fixed;background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;z-index:2000;box-shadow:0 8px 32px rgba(0,0,0,0.18);width:240px;}
#glm-v4-wrapper .qcp-title{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gray);margin-bottom:10px;}
#glm-v4-wrapper .qcp-main{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:8px;}
#glm-v4-wrapper .qcp-chip{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all .12s;flex-shrink:0;}
#glm-v4-wrapper .qcp-chip:hover{transform:scale(1.15);}
#glm-v4-wrapper .qcp-chip.on{border-color:var(--black);transform:scale(1.1);}
#glm-v4-wrapper .qcp-more{font-size:11px;color:var(--copper);cursor:pointer;text-decoration:underline;margin-bottom:10px;display:block;background:none;border:none;font-family:'Jost',sans-serif;padding:0;}
#glm-v4-wrapper .qcp-more:hover{color:var(--black);}
#glm-v4-wrapper .qcp-all{display:none;flex-wrap:wrap;gap:5px;margin-bottom:10px;}
#glm-v4-wrapper .qcp-all.show{display:flex;}
#glm-v4-wrapper .qcp-apply{width:100%;padding:9px;background:var(--black);color:#fff;border:none;border-radius:7px;font-family:'Jost',sans-serif;font-size:13px;font-weight:600;cursor:pointer;}
#glm-v4-wrapper .qcp-apply:hover{background:#333;}

/* ── CANVAS AREA: constrain properly so canvas stays ~520px ── */
#glm-v4-wrapper .canvas-area {
    max-width: calc(100vw - 420px) !important; /* leave room for config panel */
    /* Constrain height so canvas calc gets a reasonable number */
    max-height: calc(100vh - 56px) !important;
    overflow: hidden !important;
}
#glm-v4-wrapper .app.drawer-open .canvas-area {
    max-width: calc(100vw - 420px - 340px) !important;
}

/* ── MOBILE DRAWER: keep inside wrapper, hide when not open ── */
#glm-v4-wrapper .mobile-drawer {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 500 !important;
    transform: translateY(100%) !important;
    transition: transform 0.3s ease !important;
}
#glm-v4-wrapper .mobile-drawer.open {
    transform: translateY(0) !important;
}

/* ── COMPLEXITY opt-row styles (from V4) ── */
#glm-v4-wrapper .opt-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 14px 16px !important;
    border: 1.5px solid var(--border) !important;
    border-radius: var(--radius) !important;
    margin-bottom: 8px !important;
    cursor: pointer !important;
    transition: border-color .15s, background .15s !important;
    background: #fff !important;
}
#glm-v4-wrapper .opt-row:hover { border-color: #bbb !important; }
#glm-v4-wrapper .opt-row.sel {
    border-color: var(--black) !important;
    background: var(--black) !important;
    color: #fff !important;
}
#glm-v4-wrapper .opt-row-left { flex: 1 !important; }
#glm-v4-wrapper .opt-row-name { font-size: 14px !important; font-weight: 600 !important; }
#glm-v4-wrapper .opt-row-desc { font-size: 12px !important; color: var(--gray) !important; margin-top: 2px !important; }
#glm-v4-wrapper .opt-row.sel .opt-row-desc { color: #bbb !important; }
#glm-v4-wrapper .opt-row-right { display: flex !important; align-items: center !important; gap: 10px !important; }
#glm-v4-wrapper .opt-price { font-size: 16px !important; font-weight: 700 !important; }
#glm-v4-wrapper .opt-check { width: 20px !important; height: 20px !important; border-radius: 50% !important; background: rgba(255,255,255,0.2) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 12px !important; }

/* ── V4 HEADER: always visible inside wrapper ── */
#glm-v4-wrapper header {
    display: flex !important;
    flex-shrink: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: 56px !important;
}

/* ── CANVAS WRAPPER: contain the canvas so it never overflows ── */
#glm-v4-wrapper #glmCvWrap {
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
}

/* ── CANVAS AREA: always overflow:hidden, proper flex sizing ── */
#glm-v4-wrapper .canvas-area {
    overflow: hidden !important;
    flex: 1 !important;
    min-height: 0 !important;
}

/* ── SIDE SWITCHER: fixed position above canvas, never cut off ── */
#glm-v4-wrapper #glmSideSwitcher {
    flex-shrink: 0 !important;
    z-index: 10 !important;
}

/* ── APP GRID: ensure proper column layout on desktop ── */
#glm-v4-wrapper .app {
    overflow: hidden !important;
    min-height: 0 !important;
}
