*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif}img{display:block;max-width:none}.app{display:flex;min-height:100vh}.app-left{flex:1;position:relative;background:#fff;overflow:hidden}.app-right{width:540px;background:#fff;padding:16px;overflow-y:auto;box-shadow:-2px 0 20px #0000001f;border-left:1px solid #e5e5e5}.app-right .control-card{padding:0!important}.app-panel{position:fixed;top:0;left:0;width:360px;height:100vh;background:#fff;box-shadow:4px 0 20px #00000026;z-index:1000;transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column}.app-panel--open{transform:translate(0)}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e5e5}.panel-title{font-size:20px;font-weight:700;margin:0}.panel-close{width:40px;height:40px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.panel-close:hover{background:#f5f5f5}.panel-close svg{width:24px;height:24px}.panel-content{flex:1;overflow-y:auto;padding:24px}.panel-overlay{position:fixed;inset:0;background:#0006;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.canvas-info{position:absolute;top:20px;right:20px;background:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;border-radius:999px;display:flex;align-items:center;gap:12px;font-size:14px;box-shadow:0 4px 12px #0000001a;z-index:100;border:2px solid transparent;cursor:pointer;transition:all .2s ease}.canvas-info:hover{border-color:#0d1220;transform:translateY(-2px);box-shadow:0 6px 16px #00000026;background:#fff}.canvas-info:active{transform:translateY(0);background:#fff}.canvas-info__model{font-weight:600;color:#0d1220}.canvas-info__color{color:#666}.canvas-info__arrow{width:18px;height:18px;color:#0d1220;margin-left:4px;transition:transform .2s ease}.canvas-info:hover .canvas-info__arrow{transform:translateY(2px)}.zoom-controls{position:absolute;top:80px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100}.zoom-btn{width:48px;height:48px;border-radius:50%;border:2px solid #0d1220;background:#fff;box-shadow:0 4px 12px #00000040;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#0d1220}.zoom-btn:hover:not(:disabled){background:#f5f5f5;transform:scale(1.1);box-shadow:0 6px 16px #0000004d}.zoom-btn:active:not(:disabled){transform:scale(.95)}.zoom-btn:disabled{opacity:.3;cursor:not-allowed;border-color:#ccc}.phone-case-wrapper{position:absolute;top:50%;left:50%;transform-origin:center center;cursor:grab;transition:cursor .2s;touch-action:none;max-width:calc(95vh - 240px);max-height:calc(95vh - 240px);width:100%;height:100%;aspect-ratio:.52 / 1}.phone-case{position:relative;width:100%;height:100%;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:transparent}.phone-case--placeholder{background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;color:#999;font-size:18px;font-weight:600}.phone-case__camera{position:absolute;border-radius:16px;background:#0003;pointer-events:none}.placed-charm{position:absolute;cursor:move;touch-action:none;transition:filter .2s}.placed-charm:hover{filter:brightness(1.1)}.placed-charm--active{filter:brightness(1.15)}.placed-charm__centering-wrapper{position:relative;display:inline-block}.placed-charm__image-wrapper{position:relative;display:inline-block;transform-origin:center center}.placed-charm__img{pointer-events:none;-webkit-user-select:none;user-select:none;display:block}.placed-charm__selection{position:absolute;width:85%;height:85%;border:1px solid #666666;border-radius:0;pointer-events:none;top:50%;left:50%;transform-origin:center center;margin-left:-42.5%;margin-top:-42.5%}.placed-charm__selection--rotating{border-style:dashed}.placed-charm__content{position:relative;display:inline-flex;align-items:center;justify-content:center}.placed-charm__line{position:absolute;width:1px;background:#d0d0d0;pointer-events:none;left:50%;margin-left:-.5px}.placed-charm__line--top{bottom:50%;height:40px;margin-bottom:calc(42.5% - 1px);transform-origin:.5px 142.5%}.placed-charm__line--bottom{top:50%;height:40px;margin-top:calc(42.5% - 1px);transform-origin:.5px -42.5%}.placed-charm__btn{position:absolute;width:32px;height:32px;min-width:32px;min-height:32px;max-width:32px;max-height:32px;background:#000!important;border:none;border-radius:50%;color:#fff!important;box-shadow:0 2px 8px #00000040;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10;opacity:1!important;font-size:20px;font-weight:400;line-height:1;flex-shrink:0;box-sizing:border-box}.placed-charm__btn svg{display:block;flex-shrink:0}.placed-charm__btn:hover{background:#333!important}.placed-charm__btn:active{background:#1a1a1a!important}.placed-charm__btn--delete{background:pink!important;border:1px solid #000000!important}.placed-charm__btn--delete:hover{background:#ffaab8!important}.placed-charm__btn--delete:active{background:#ff94a5!important}.control-card{background:#fff;border-radius:24px}.control-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.control-card__label{font-size:14px;color:#666;margin-bottom:4px}.control-card__total{font-size:36px;font-weight:700;line-height:1}.control-card__breakdown{font-size:12px;color:#999;margin-top:4px}.control-card__free{font-size:14px;color:#0d1220;margin-top:6px;font-weight:600;background:#f5f5f5;padding:6px 12px;border-radius:999px;display:inline-block;border:1px solid #e5e5e5}.control-card__free span{margin-left:4px;font-weight:400}.control-card__chip{padding:8px 16px;border-radius:999px;background:#eee8ff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:16px}.control-card__chip-count{flex-shrink:0}.control-card__chip-btn{padding:8px 20px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:#0d1220;color:#fff;transition:all .2s;white-space:nowrap}.control-card__chip-btn:disabled{opacity:.5;cursor:not-allowed}.control-card__chip-btn:not(:disabled):hover{background:#1a1f2e;transform:translateY(-1px)}.control-card__chip-btn:not(:disabled):active{transform:translateY(0)}.category-tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 0 16px;margin-bottom:16px;-webkit-overflow-scrolling:touch}.category-tabs::-webkit-scrollbar{height:4px}.category-tabs::-webkit-scrollbar-track{background:#f5f5f5;border-radius:2px}.category-tabs::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.category-tab{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;border:2px solid #e5e5e5;background:#fff;border-radius:16px;cursor:pointer;transition:all .2s;flex-shrink:0;min-width:85px}.category-tab:hover{border-color:#666;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a;background:#fff}.category-tab--active{border-color:#0d1220;background:#f5f5f5}.category-tab--active:hover{background:#f5f5f5}.category-tab__emoji{font-size:28px;line-height:1}.category-tab__label{font-size:13px;font-weight:600;white-space:nowrap;color:#333}.form-select{width:100%;padding:14px 40px 14px 14px;border-radius:14px;border:1px solid #ddd;font-size:16px;margin-bottom:16px;background:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:border-color .2s}.form-select:hover{border-color:#bbb}.form-select:focus{outline:none;border-color:#0d1220}.form-section{margin-bottom:16px}.form-label{font-size:14px;font-weight:600;margin-bottom:8px;display:block;color:#333}.color-row{display:flex;gap:12px;flex-wrap:wrap}.color-dot{width:44px;height:44px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s;position:relative}.color-dot:hover{transform:scale(1.1)}.color-dot--selected{border-color:#0d1220;box-shadow:0 0 0 2px #fff,0 0 0 4px #0d1220}.case-color-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px;border:none;background:transparent;border-radius:16px;cursor:pointer;transition:all .2s;width:100px}.case-color-option:hover{transform:scale(1.05);background:transparent}.case-color-option--selected{background:transparent}.case-color-option__img{width:80px;height:80px;object-fit:contain;border-radius:8px}.case-color-option__label{font-size:12px;font-weight:600;color:#333;text-align:center}.filter-row{display:flex;gap:12px;margin-bottom:16px}.filter-row .form-select{margin-bottom:0}.charm-list{overflow-y:visible;padding:4px;margin-bottom:16px}.charm-list::-webkit-scrollbar{width:8px}.charm-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}.charm-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.charm-list::-webkit-scrollbar-thumb:hover{background:#aaa}.charm-list--grid{display:grid;grid-template-columns:repeat(4,110px);gap:12px;justify-content:start;max-height:60vh;overflow-y:auto;overflow-x:hidden;padding-right:5px;contain:layout}.charm-list--grid::-webkit-scrollbar{width:8px}.charm-list--grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.charm-list--grid::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.charm-list--grid::-webkit-scrollbar-thumb:hover{background:#555}.charm-pill{width:110px;height:110px;padding:5px;border:none;background:transparent;border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s;flex-shrink:0;will-change:transform;position:relative;overflow:visible}.charm-pill:hover{transform:scale(1.1);background:transparent!important;background-color:transparent!important;box-shadow:none!important;border:none!important;z-index:10;overflow:visible}.charm-pill:active{transform:scale(.95)}.charm-pill:focus,.charm-pill:focus-visible{background:transparent!important;background-color:transparent!important;outline:none!important;box-shadow:none!important;border:none!important}.charm-pill__img{width:80px;height:80px;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;display:block}.action-buttons{margin-top:16px;padding-top:16px;border-top:1px solid #e5e5e5;display:flex;flex-direction:column;gap:12px}.button-row{display:flex;gap:12px}.button-row .btn{flex:1}.btn{padding:16px 24px;border-radius:999px;font-size:16px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-align:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn:not(:disabled):active{transform:translateY(0)}.btn--primary{background:#0d1220;color:#fff}.btn--primary:not(:disabled):hover{background:#1a1f2e}.btn--secondary{background:transparent;border:2px solid #ddd;color:#333}.btn--secondary:not(:disabled):hover{border-color:#0d1220;background:#f8f8f8}.btn--load-more{width:100%;margin-top:8px}@media(max-width:1024px){.app-right{width:400px}.charm-list--grid{grid-template-columns:repeat(3,110px)}.app-panel{width:320px}}@media(max-width:768px){.app{flex-direction:column}.app-left{height:50vh}.app-right{width:100%;height:50vh}.app-panel{width:280px}.canvas-info{font-size:12px;padding:8px 16px;top:10px;right:10px}.charm-list--grid{grid-template-columns:repeat(4,110px)}.charm-pill__img{width:100px;height:100px}}.cart-panel{position:fixed;top:0;right:0;width:500px;height:100vh;background:#fff;box-shadow:-2px 0 10px #0000001a;transform:translate(100%);transition:transform .3s ease-in-out;z-index:1001;display:flex;flex-direction:column}.cart-panel--open{transform:translate(0)}.cart-panel__header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.cart-panel__header h2{margin:0;font-size:24px;font-weight:600}.cart-panel__close{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.cart-panel__close:hover{background:#f0f0f0}.cart-panel__content{flex:1;overflow-y:auto;padding:20px}.cart-panel__empty{text-align:center;color:#999;padding:40px 20px}.cart-item{display:flex;gap:15px;padding:15px 0;border-bottom:1px solid #f0f0f0;position:relative}.cart-item:last-child{border-bottom:none}.cart-panel .cart-item__image,.cart-panel .cart-item .cart-item__image,.cart-item__image{width:80px!important;height:80px!important;min-width:80px!important;min-height:80px!important;max-width:80px!important;max-height:80px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;background:transparent!important;border-radius:0!important;padding:0!important;overflow:visible!important}.cart-panel .cart-item__image img,.cart-item__image img{width:100%!important;height:100%!important;object-fit:contain!important}.cart-panel .cart-item__image--case,.cart-panel .cart-item .cart-item__image--case,.cart-item__image--case{width:80px!important;height:80px!important;min-width:80px!important;min-height:80px!important;max-width:80px!important;max-height:80px!important}.cart-panel .cart-item__image img,.cart-item__image img{max-width:100%!important;max-height:100%!important;width:auto!important;height:auto!important;object-fit:contain!important}.wc-block-components-order-summary-item{container-type:normal!important;display:flex!important;gap:16px!important}.woocommerce-cart-form__cart-item .product-thumbnail,.woocommerce-checkout .product-thumbnail,.wc-block-components-order-summary-item__image,.wc-block-cart-item__image,.wc-block-components-totals-item__image{width:150px!important;height:150px!important;min-width:150px!important;min-height:150px!important;max-width:150px!important;max-height:150px!important;flex-shrink:0!important;flex-grow:0!important}div.wc-block-components-order-summary-item__image,.wc-block-components-order-summary-item>.wc-block-components-order-summary-item__image{width:150px!important;height:150px!important;min-width:150px!important;min-height:150px!important;max-width:none!important;max-height:none!important;flex:0 0 150px!important}.woocommerce-cart-form__cart-item .product-thumbnail img,.woocommerce-checkout .product-thumbnail img,.wc-block-components-order-summary-item__image img,.wc-block-cart-item__image img,.wc-block-components-totals-item__image img,img.attachment-full.phonecase-cart-image{width:150px!important;height:150px!important;min-width:150px!important;min-height:150px!important;max-width:150px!important;max-height:150px!important;object-fit:contain!important}.woocommerce-cart-form__cart-item .product-thumbnail[class*=phone],.woocommerce-checkout .product-thumbnail[class*=phone],.wc-block-components-order-summary-item__image[class*=phone],.wc-block-cart-item__image[class*=phone]{width:60px!important;height:60px!important;min-width:60px!important;min-height:60px!important;max-width:60px!important;max-height:60px!important;flex:0 0 60px!important}.woocommerce-cart-form__cart-item .product-thumbnail img[src*=phone],.woocommerce-checkout .product-thumbnail img[src*=phone],.wc-block-components-order-summary-item__image img[src*=phone],.wc-block-cart-item__image img[src*=phone],img.attachment-full.phonecase-cart-image[src*=phone]{width:60px!important;height:60px!important;min-width:60px!important;min-height:60px!important;max-width:60px!important;max-height:60px!important}.cart-item__details{flex:1;padding-right:30px}.cart-item__name{margin:0 0 8px;font-size:16px;font-weight:600}.cart-item__meta{margin:8px 0;font-size:13px;color:#666}.cart-item__meta-item{margin:4px 0}.cart-item__price{margin-top:8px;font-weight:400;color:#666;font-size:14px}.cart-item__price strong{color:#333;font-size:15px}.cart-item__remove{position:absolute;top:15px;right:0;background:none;border:none;font-size:20px;color:#999;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.cart-item__remove:hover{background:#ffebee;color:#d32f2f}.cart-panel__footer{padding:20px;border-top:1px solid #e0e0e0;background:#f9f9f9}.cart-panel__total{display:flex;justify-content:space-between;margin-bottom:15px;font-size:18px;font-weight:600}.btn--full{width:100%}@media(max-width:768px){.cart-panel{width:100%;max-width:450px}}
