:host { /* breakpoints: not-implemented / reference only */ /* --wrapped-breakpoint-xs: 320px; */ /* --wrapped-breakpoint-sm: 490px; */ /* --wrapped-breakpoint-md: 768px; */ /* --wrapped-breakpoint-lg: 1040px; */ /* --wrapped-breakpoint-xl: 1440px; */ --wrapped-thumbnail-position-start: "media gift-dialog-header" "media content" "media gift-dialog-actions"; --wrapped-thumbnail-position-end: "gift-dialog-header media" "content media" "gift-dialog-actions media"; --shadow-grid-template-areas: var(--wrapped-thumbnail-position-start); /* border radius */ --shadow-border-radius-scale: 60; --shadow-border-radius-xs: calc(var(--shadow-border-radius-scale, 65) / 100 * 1rem); --shadow-border-radius-sm: calc(var(--shadow-border-radius-scale, 65) / 100 * 1.5rem); --shadow-border-radius-base: calc(var(--shadow-border-radius-scale, 65) / 100 * 2.5rem); --shadow-dialog-border-surface: rgba(0,0,0,0); --shadow-border-width: 1px; --shadow-outline-width: calc(var(--shadow-border-width) + 0.5px); /* buttons */ --wrapped-hover-style-light: #ffffff; --wrapped-hover-style-dark: #000000; --shadow-hover-style: var(--wrapped-hover-style-light, --wrapped-hover-style-light); --shadow-primary-button-surface: #000000; --shadow-primary-button-surface--active: color-mix(in srgb, var(--shadow-primary-button-surface), var(--shadow-hover-style) 20%); --shadow-primary-button-surface--hover: color-mix(in srgb, var(--shadow-primary-button-surface), var(--shadow-hover-style) 16%); --shadow-primary-button-text-color: #ffffff; --shadow-primary-button-text-color--active: color-mix(in srgb, var(--shadow-primary-button-text-color), var(--shadow-hover-style) 20%); --shadow-primary-button-text-color--hover: color-mix(in srgb, var(--shadow-primary-button-text-color), var(--shadow-hover-style) 16%); --shadow-primary-button-border-surface: rgba(0,0,0,0); --shadow-primary-button-border-surface--active: transparent; --shadow-primary-button-border-surface--hover: transparent; --shadow-secondary-button-surface: #0000000f; --shadow-secondary-button-surface--active: color-mix(in srgb, var(--shadow-secondary-button-surface), var(--shadow-hover-style) 20%); --shadow-secondary-button-surface--hover: color-mix(in srgb, var(--shadow-secondary-button-surface), var(--shadow-hover-style) 16%); --shadow-secondary-button-text-color: #333333; --shadow-secondary-button-text-color--active: color-mix(in srgb, var(--shadow-secondary-button-text-color), var(--shadow-hover-style) 20%); --shadow-secondary-button-text-color--hover: color-mix(in srgb, var(--shadow-secondary-button-text-color), var(--shadow-hover-style) 16%); --shadow-secondary-button-border-surface: rgba(0,0,0,0); --shadow-secondary-button-border-surface--active: transparent; --shadow-secondary-button-border-surface--hover: transparent; /* do not change the root text size */ --shadow-font-size: 16px; /* text and fonts */ --shadow-font-family: var(--wrapped-font-family, inherit); --shadow-font-scale: calc(100 / 100); --shadow-font-size-sm: clamp(12px, calc(14px * var(--shadow-font-scale)), 16px); --shadow-font-size-base: clamp(12px, calc(16px * var(--shadow-font-scale)), 20px); --shadow-font-size-lg: clamp(16px, calc(24px * var(--shadow-font-scale)), 28px); --shadow-font-weight-base: var(--wrapped-font-weight-base, 400); --shadow-font-weight-md: 500; --shadow-font-weight-lg: 600; --shadow-letter-spacing: var(--wrapped-letter-spacing, normal); --shadow-line-height-base: 1.5em; /* transitions */ --shadow-transition-duration: 0.1s; --shadow-spinner-duration: 0.7s; /* disabled */ --shadow-disabled-opacity-sm: 0.16; --shadow-disabled-opacity: 0.32; --shadow-disabled-opacity-md: 0.4; --shadow-disabled-opacity-lg: 0.64; /* precalculated percentages for color-mix */ --shadow-disabled-opacity-percent: 32%; --shadow-disabled-opacity-sm-percent: 16%; --shadow-disabled-opacity-md-percent: 40%; --shadow-disabled-opacity-lg-percent: 64%; --shadow-disabled-cursor: not-allowed; /* form elements */ --shadow-form-element-surface: #ffffff; --shadow-form-element-surface--disabled: color-mix(in srgb, var(--shadow-form-element-surface) var(--shadow-disabled-opacity-percent), var(--shadow-secondary-text-color) 8%); --shadow-form-element-border-color: #0000000f; --shadow-form-element-border-color--active: color-mix(in srgb, var(--shadow-form-element-border-color), white 83%); --shadow-form-element-border-color--disabled: color-mix(in srgb, var(--shadow-form-element-border-color) var(--shadow-disabled-opacity-percent), var(--shadow-secondary-text-color) 8%); --shadow-form-element-text-color: #333333; --shadow-form-element-text-color--disabled: color-mix(in srgb, var(--shadow-form-element-text-color), var(--shadow-secondary-text-color) 8%); --shadow-form-element-placeholder-text-color: color-mix(in srgb, var(--shadow-form-element-text-color) var(--shadow-disabled-opacity-percent), transparent); --shadow-form-element-placeholder-text-color--disabled: color-mix(in srgb, var(--shadow-form-element-text-color) var(--shadow-disabled-opacity-percent), var(--shadow-secondary-text-color) 8%); --shadow-form-element-selection-color: #000000; --shadow-form-element-selection-color--active: color-mix(in srgb, var(--shadow-form-element-selection-color), var(--shadow-hover-style) 40%); --shadow-form-element-selection-color--hover: color-mix(in srgb, var(--shadow-form-element-selection-color), var(--shadow-hover-style) 32%); /* primary colors */ --shadow-primary-surface: #ffffff; --shadow-primary-text-color: #000000; --shadow-primary-text-color--hover: color-mix(in srgb, var(--shadow-primary-text-color), var(--shadow-hover-style) 32%); /* secondary colors */ --shadow-secondary-surface: #f3f3f3; --shadow-secondary-text-color: #333333; --shadow-secondary-text-color--disabled: color-mix(in srgb, var(--shadow-secondary-text-color) var(--shadow-disabled-opacity-lg-percent), var(--shadow-secondary-text-color) 8%); /* Typography customizations */ --shadow-button-text-transform: var(--wrapped-button-text-transform, none); --shadow-button-letter-spacing: var(--wrapped-button-letter-spacing, var(--shadow-letter-spacing, normal)); --shadow-button-font-style: var(--wrapped-button-font-style, normal); /* spacing */ --wrapped-spacing-scale-base: 1; --wrapped-spacing-scale-less: 0.75; --wrapped-spacing-scale-more: 1.166; --shadow-spacing-scale: var(--wrapped-spacing-scale-base, 1); --shadow-spacing-fixed: 4px; --shadow-spacing-base: clamp(12px, calc(16px * var(--shadow-spacing-scale)), 24px); --shadow-spacing-lg: clamp(16px, calc(24px * var(--shadow-spacing-scale)), 28px); --shadow-spacing-sm: clamp(8px, calc(12px * var(--shadow-spacing-scale)), 14px); --shadow-spacing-xs: clamp(6px, calc(8px * var(--shadow-spacing-scale)), 10px); /* shadows */ --shadow-shadow-blur: 1.5rem; --shadow-shadow-color: rgba(0, 0, 0, 0.25); --shadow-shadow-offset: 0.75rem; /* default styles */ all: revert; box-sizing: border-box; cursor: default; display: block; font-family: var(--shadow-font-family); font-size: var(--shadow-font-size); line-height: var(--shadow-line-height-base); letter-spacing: var(--shadow-letter-spacing); margin-block-start: var(--shadow-spacing-xs); margin-block-end: var(--shadow-spacing-xs); text-align: start; width: -webkit-fill-available; white-space: normal; } *, *::before, *::after { box-sizing: inherit; } /* gift block launcher */ gift-block-launcher { display: flex; flex-direction: column; gap: var(--shadow-spacing-xs); & gift-block-visibility-notice { display: block; font-family: var(--shadow-font-family); font-size: smaller; font-weight: var(--shadow-font-weight-base); font-style: var(--shadow-button-font-style); letter-spacing: var(--shadow-button-letter-spacing); padding: 0 var(--shadow-spacing-sm); text-transform: var(--shadow-button-text-transform); width: 100%; } } .gift-block__launcher { background-color: var(--wrapped-launcher-button-surface, var(--shadow-primary-button-surface)); border-color: var(--wrapped-launcher-button-border-surface, var(--shadow-primary-button-border-surface)); border-width: var(--wrapped-launcher-button-border-width, var(--shadow-border-width)); border-radius: var(--wrapped-launcher-button-border-radius, var(--shadow-border-radius-sm)); border-style: solid; color: var(--shadow-primary-button-text-color); padding: var(--shadow-spacing-sm); font-family: var(--shadow-font-family); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-base); font-style: var(--shadow-button-font-style); letter-spacing: var(--shadow-button-letter-spacing); max-width: var(--wrapped-launcher-button-max-width, 500px); text-transform: var(--shadow-button-text-transform); width: 100%; &:hover { cursor: pointer; background-color: var(--shadow-primary-button-surface--hover); border-color: var(--shadow-primary-button-border-surface--hover); } &:active { background-color: var(--shadow-primary-button-surface--active); border-color: var(--shadow-primary-button-border-surface--active); } &:focus, &:focus-visible { outline: none; } &[with-checkmark] { position: relative; display: inline-flex; align-items: center; gap: var(--shadow-spacing-fixed); & .icon-wrapper { display: flex; flex-shrink: 0; } & .button-content { justify-content: var(--wrapped-launcher-button-content-justify-content, space-between); } &[with-gift-options] { .checkmark-icon { display: block; /* animation: unblur calc(var(--shadow-transition-duration) * 3) ease forwards; */ } } } &[variant="link"] { background: none; border: none; color: var(--shadow-primary-text-color); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-base); font-style: var(--shadow-button-font-style); letter-spacing: var(--shadow-button-letter-spacing); text-transform: var(--shadow-button-text-transform); text-decoration: none; margin-inline-start: -0.25rem; padding: 0; width: auto; &:hover { cursor: pointer; color: var(--shadow-primary-text-color--hover); text-decoration: underline; } &[with-checkmark] { padding-left: 0; text-align: start; word-break: keep-all; } & .button-content { flex-direction: row; justify-content: flex-start; } } & .button-content { display: inline-flex; align-items: center; gap: var(--shadow-spacing-fixed); flex-direction: row-reverse; justify-content: var(--wrapped-launcher-button-content-justify-content, center); width: 100%; & .label { text-align: start; } } & .icon-wrapper { display: none; align-items: center; justify-content: center; width: 1.5em; height: 1.5em; svg { fill: currentColor; height: 100%; width: 100%; } .checkmark-icon { display: none; } } } .gift-block__launcher:disabled, .gift-block__launcher[orders-limit-reached] { cursor: var(--shadow-disabled-cursor); opacity: var(--shadow-disabled-opacity); pointer-events: none; &[with-checkmark] { .icon-wrapper { opacity: var(--shadow-disabled-opacity-md); } } } /* gift block modal */ .gift-block-modal { background-color: var(--shadow-primary-surface); border: none; border-radius: var(--shadow-border-radius-base); box-shadow: 0 var(--shadow-shadow-offset) var(--shadow-shadow-blur) var(--shadow-shadow-color); outline: var(--shadow-border-width) solid var(--shadow-dialog-border-surface); padding: 0; } .gift-block-modal::backdrop { background-color: rgba(156, 163, 175, 0.75); } .gift-block-modal:focus, .gift-block-modal:focus-visible { outline: var(--shadow-border-width) solid var(--shadow-dialog-border-surface); } @media (max-width: 768px) { .gift-block-modal { max-height: calc(100% - var(--shadow-spacing-sm)); max-width: calc(100% - var(--shadow-spacing-sm)); overscroll-behavior: contain; } } /* gift block modal layout */ .gift-block-modal-layout { display: grid; grid-template-areas: var(--shadow-grid-template-areas); grid-template-columns: 1fr 1fr; grid-template-rows: auto 1fr auto; max-height: 80dvh; max-width: 80dvw; overflow: hidden; } /* Collapse to 1-column layout if media is hidden */ .gift-block-modal-layout:has(section#media[hidden]), .gift-block-modal-layout:has(section#media.with-media-inline), .gift-block-modal-layout:not(:has(section#media)), .gift-block-modal-layout:not(:has(section#media img)) { grid-template-areas: "gift-dialog-header" "content" "gift-dialog-actions"; grid-template-columns: 1fr; grid-template-rows: auto 1fr auto; section#media { display: none; } } gift-dialog-header { align-items: flex-start; background-color: var(--shadow-primary-surface); display: flex; flex-direction: row; gap: var(--shadow-spacing-fixed); grid-area: gift-dialog-header; justify-content: space-between; padding: var(--shadow-spacing-lg); position: sticky; top: 0; z-index: 1; & h1 { color: var(--shadow-primary-text-color); font-family: var(--wrapped-header-font-family, var(--shadow-font-family)); font-size: var(--shadow-font-size-lg); font-weight: var(--shadow-font-weight-md); line-height: 1.25em; margin: 0; } /* dismiss button styles */ & button { background-color: color-mix(in srgb, var(--shadow-secondary-text-color) 8%, transparent); color: var(--shadow-secondary-text-color); border-radius: var(--shadow-border-radius-xs); font-size: var(--shadow-font-size-sm); font-weight: var(--shadow-font-weight-lg); font-style: var(--shadow-button-font-style); letter-spacing: var(--shadow-button-letter-spacing); text-transform: var(--shadow-button-text-transform); width: 2.25em; height: 2.25em; min-width: 2.25em; min-height: 2.25em; outline: none; border: 0; cursor: pointer; transition: background-color var(--shadow-transition-duration) ease, color var(--shadow-transition-duration) ease; &:hover { background-color: color-mix(in srgb, var(--shadow-secondary-text-color) 6%, var(--shadow-hover-style) 12%); } &:active { background-color: color-mix(in srgb, var(--shadow-secondary-text-color) 16%, var(--shadow-hover-style) 16%); } &:disabled { pointer-events: none; opacity: var(--shadow-disabled-opacity); } } } gift-dialog-actions { align-items: flex-end; background-color: var(--shadow-primary-surface); bottom: 0; display: flex; flex-direction: column; gap: var(--shadow-spacing-sm); grid-area: gift-dialog-actions; overscroll-behavior: contain; position: sticky; padding: var(--shadow-spacing-lg); z-index: 1; & button { border-radius: var(--shadow-border-radius-sm); border-width: var(--shadow-border-width); border-style: solid; cursor: pointer; font-family: var(--wrapped-actions-button-font-family, var(--shadow-font-family)); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-md); font-style: var(--shadow-button-font-style); letter-spacing: var(--shadow-button-letter-spacing); text-transform: var(--shadow-button-text-transform); padding: var(--shadow-spacing-sm); position: relative; width: 100%; transition: background-color var(--shadow-transition-duration) ease, border-color var(--shadow-transition-duration) ease, color var(--shadow-transition-duration) ease, opacity var(--shadow-transition-duration) ease; &.primary { background-color: var(--shadow-primary-button-surface); border-color: var(--shadow-primary-button-border-surface); color: var(--shadow-primary-button-text-color); display: flex; align-items: center; justify-content: center; .button-content { display: flex; align-items: center; justify-content: center; width: 100%; } .label { flex: 0 1 auto; min-width: 0; text-align: center; } .label.out-of-stock { display: none; } .icon-wrapper { width: 0em; height: 1.25em; } &:hover { background-color: var(--shadow-primary-button-surface--hover); border-color: var(--shadow-primary-button-border-surface--hover); color: var(--shadow-primary-button-text-color--hover); } &:active { background-color: var(--shadow-primary-button-surface--active); border-color: var(--shadow-primary-button-border-surface--active); color: var(--shadow-primary-button-text-color--active); } &[loading] { background-color: var(--shadow-primary-button-surface--active); border-color: var(--shadow-primary-button-border-surface--active); color: var(--shadow-primary-button-text-color--active); pointer-events: none; .button-content { opacity: 0; } } } &.secondary { background-color: var(--shadow-secondary-button-surface); border-color: var(--shadow-secondary-button-border-surface); color: var(--shadow-secondary-button-text-color); display: flex; align-items: center; justify-content: center; .button-content { display: flex; align-items: center; justify-content: center; gap: var(--shadow-spacing-fixed); width: 100%; } .label { flex: 0 1 auto; min-width: 0; text-align: center; } .icon-wrapper { --icon-stroke-width: 1.5px; flex: 0 0 auto; display: flex; align-items: center; justify-content: center; svg { width: 1.25em; height: 1.25em; stroke-width: var(--icon-stroke-width); } .remove-icon-top, .remove-icon-bottom { transition: transform var(--shadow-transition-duration) ease-in-out; } } &:hover { background-color: var(--shadow-secondary-button-surface--hover); border-color: var(--shadow-secondary-button-border-surface--hover); color: var(--shadow-secondary-button-text-color--hover); .icon-wrapper { .remove-icon-top { transform: translate(calc(-1 * var(--icon-stroke-width)), var(--icon-stroke-width)) rotate(-15deg); } .remove-icon-bottom { transform: translateY(var(--icon-stroke-width)); } } } &:active { background-color: var(--shadow-secondary-button-surface--active); border-color: var(--shadow-secondary-button-border-surface--active); .icon-wrapper { transition: filter var(--shadow-transition-duration) ease-in-out; } } &[hidden] { display: none; } &[loading] { background-color: var(--shadow-secondary-button-surface--active); border-color: var(--shadow-secondary-button-border-surface--active); color: var(--shadow-secondary-button-text-color--active); pointer-events: none; .button-content { opacity: 0; } .spinner .svg-wrapper svg { fill: var(--shadow-secondary-button-text-color--active); } } } &:disabled { cursor: var(--shadow-disabled-cursor); opacity: var(--shadow-disabled-opacity); pointer-events: none; .button-content { pointer-events: none; opacity: calc(var(--shadow-disabled-opacity) * 1.5); } } /* spinner styles */ .spinner { opacity: 0; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); & .svg-wrapper svg { animation: spin var(--shadow-spinner-duration) cubic-bezier(0, 0, 1, 1) infinite; fill: var(--shadow-primary-button-text-color); height: 1.5em; } & [role="status"] { visibility: hidden; opacity: 0; position: absolute; top: 0; left: 0; width: 100%; height: 100%; } } &[loading] { pointer-events: none; .spinner { opacity: 1; } } } &:has(button[loading]:not([hidden])) { & button { pointer-events: none; opacity: 0.8; } } &:is([out-of-stock]) { & button.primary { pointer-events: none !important; opacity: 0.6 !important; & .label { display: none; } & .label.out-of-stock { display: block; } } } } gift-dialog-content { display: contents; } section#media { align-self: stretch; background-color: var(--shadow-secondary-surface); grid-area: media; grid-row: 1 / 4; height: 100%; padding: var(--shadow-spacing-lg); position: sticky; top: 0; transition: order var(--shadow-transition-duration) ease, width var(--shadow-transition-duration) ease; &.with-media-cover { & img { height: 100%; } } &.with-media-fill { padding: 0; & img { border-radius: 0; height: 100%; } } & shopify-media { & img { border-radius: var(--shadow-border-radius-sm); width: 100%; height: auto; } } } section#content { grid-area: content; background-color: var(--shadow-primary-surface); overflow-y: auto; overscroll-behavior: contain; scrollbar-width: thin; -webkit-overflow-scrolling: touch; padding: var(--shadow-spacing-lg); padding-bottom: 0; padding-top: 0; position: relative; /* important to prevent content shifting when changing variants */ align-items: stretch; display: flex; flex-direction: column; justify-content: flex-start; gap: var(--shadow-spacing-lg); transition: order var(--shadow-transition-duration) ease; @media (max-width: 768px) { & > *:first-child:not(:only-child) { margin-top: unset; } } /* gift product details */ & .gift-product { display: flex; flex-direction: column; gap: var(--shadow-spacing-base); } & .gift-product-header { --wrapped-thumbnail-position-start: row; --wrapped-thumbnail-position-end: row-reverse; align-items: center; display: flex; flex-direction: var(--wrapped-thumbnail-position-start); flex-wrap: wrap; row-gap: var(--shadow-spacing-base); column-gap: var(--shadow-spacing-sm); } & .gift-product-content { display: flex; flex: 1 1 50%; flex-direction: column; gap: var(--shadow-spacing-xs); } & .gift-product-media { display: flex; align-items: center; &:has(shopify-media) { --shadow-inline-media-max-size: 60px; --shadow-inline-media-size: clamp(40px, 60px, var(--shadow-inline-media-max-size)); border-radius: var(--shadow-border-radius-sm); height: var(--shadow-inline-media-size); width: var(--shadow-inline-media-size); overflow: hidden; margin-inline-start: auto; margin-inline-end: auto; } & shopify-media { & img { border-radius: var(--shadow-border-radius-sm); width: 100%; height: auto; } } } & .gift-product-title { color: var(--shadow-primary-text-color); display: var(--wrapped-gift-product-title-display, block); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-md); margin: 0; } & .gift-product-pricing { display: flex; gap: var(--shadow-spacing-xs); margin: 0; font-weight: var(--shadow-font-weight-base); font-size: clamp(12px, calc(var(--shadow-font-size-base) * 0.94), 18px); line-height: 1em; } & .gift-product-price { color: var(--shadow-secondary-text-color); } & .gift-product-price--compare { color: var(--shadow-secondary-text-color); text-decoration: line-through; opacity: var(--shadow-disabled-opacity); } & .gift-product-description { font-weight: var(--shadow-font-weight-base); color: var(--shadow-secondary-text-color); font-size: clamp(12px, calc(var(--shadow-font-size-base) * 0.94), 18px); line-height: 1.5em; & shopify-data { & :first-child { margin-top: 0; } & :last-child { margin-bottom: 0; } & ul { padding-left: var(--shadow-spacing-lg); } } } /* gift messaging fields */ & gift-dialog-message { display: flex; flex-direction: row; flex-wrap: wrap; gap: var(--shadow-spacing-base); } & .option-group { display: flex; flex-direction: column; gap: var(--shadow-spacing-xs); flex: 0 0 100%; @media (min-width: 768px) { &:has(input[id="receiver-input"]), &:has(input[id="sender-input"]) { flex: 1 1 0%; } } &.option-group-disabled { cursor: var(--shadow-disabled-cursor); pointer-events: none; opacity: var(--shadow-disabled-opacity-md); transition: background-color var(--shadow-transition-duration) ease, color var(--shadow-transition-duration) ease; & .message-field { background-color: var(--shadow-form-element-surface--disabled); color: transparent; outline-color: var(--shadow-form-element-border-color--disabled); pointer-events: none; } } &.option-group-hidden { display: none; } & label { font-size: var(--shadow-font-size-sm); font-weight: var(--shadow-font-weight-base); color: var(--shadow-secondary-text-color); line-height: 1em; } & .message-field { background-color: var(--shadow-form-element-surface); color: var(--shadow-form-element-text-color); width: 100%; padding: var(--shadow-spacing-sm); border: none; border-radius: var(--shadow-border-radius-sm); font-family: var(--shadow-font-family); font-size: var(--shadow-font-size-base); outline: var(--shadow-border-width) solid var(--shadow-form-element-border-color); min-height: 42px; } & .message-field:active, & .message-field:focus, & .message-field:focus-within, & .message-field:focus-visible { outline-color: var(--shadow-form-element-selection-color); outline-width: var(--shadow-outline-width); } & .message-field::placeholder { color: var(--shadow-form-element-placeholder-text-color); } & textarea.message-field { min-height: 100px; resize: vertical; } & .counter { color: var(--shadow-secondary-text-color); font-size: var(--shadow-font-size-sm); line-height: normal; } } } /* shopify variant selector */ shopify-variant-selector { font-size: var(--shadow-font-size-sm); width: 100%; &[variants-count="1"] { display: none; } } shopify-variant-selector::part(form) { gap: var(--shadow-spacing-base); } shopify-variant-selector::part(radio) { background-color: var(--shadow-form-element-surface); color: var(--shadow-form-element-text-color); border: none; border-radius: var(--shadow-border-radius-sm); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-base); outline: var(--shadow-border-width) solid var(--shadow-form-element-border-color); padding: calc(var(--shadow-spacing-sm) * 0.5) var(--shadow-spacing-base); transition: color var(--shadow-transition-duration) ease, outline-color var(--shadow-transition-duration) ease, outline-width var(--shadow-transition-duration) ease; } shopify-variant-selector::part(radio):active { outline-color: var(--shadow-form-element-selection-color--active); outline-width: var(--shadow-outline-width); } shopify-variant-selector::part(radio):hover { outline-color: var(--shadow-form-element-selection-color--hover); } shopify-variant-selector::part(radio-disabled) { background-color: var(--shadow-form-element-surface--disabled); color: var(--shadow-form-element-text-color--disabled); opacity: var(--shadow-disabled-opacity); /* do not transition opacity - it causes a flash when changing variants */ outline-color: var(--shadow-form-element-border-color--disabled); pointer-events: none; } shopify-variant-selector::part(radio-selected) { outline-color: var(--shadow-form-element-selection-color); outline-width: var(--shadow-outline-width); pointer-events: none; } shopify-variant-selector::part(select) { color: var(--shadow-form-element-text-color); border: none; border-radius: var(--shadow-border-radius-sm); font-family: var(--shadow-font-family); font-size: var(--shadow-font-size-base); font-weight: var(--shadow-font-weight-base); margin-top: var(--shadow-spacing-xs); width: 100%; max-width: 100%; padding: var(--shadow-spacing-sm); padding-right: calc(var(--shadow-spacing-sm) + 1.5rem); outline: var(--shadow-border-width) solid var(--shadow-form-element-border-color); appearance: none; -webkit-appearance: none; -moz-appearance: none; background-color: var(--shadow-form-element-surface); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='currentColor' fill-rule='evenodd' d='M6.24 8.2a.75.75 0 0 1 1.06.04l2.7 2.908 2.7-2.908a.75.75 0 1 1 1.1 1.02l-3.25 3.5a.75.75 0 0 1-1.1 0l-3.25-3.5a.75.75 0 0 1 .04-1.06Z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.5rem center; background-size: 1em 1em; } shopify-variant-selector::part(select):focus, shopify-variant-selector::part(select):focus-visible { outline-color: var(--shadow-form-element-selection-color); outline-width: var(--shadow-outline-width); } shopify-variant-selector::part(color-swatch) { border: none; outline: var(--shadow-border-width) solid rgba(0, 0, 0, .1); transition: color var(--shadow-transition-duration) ease, outline-color var(--shadow-transition-duration) ease, outline-width var(--shadow-transition-duration) ease; } shopify-variant-selector::part(color-swatch):active { outline-color: var(--shadow-form-element-selection-color--active); outline-width: var(--shadow-outline-width); } shopify-variant-selector::part(color-swatch):hover { outline-color: var(--shadow-form-element-selection-color--hover); } shopify-variant-selector::part(color-swatch-selected) { outline-color: var(--shadow-form-element-selection-color); outline-width: var(--shadow-outline-width); } shopify-variant-selector::part(color-swatch-selected):after { content: unset; } shopify-variant-selector::part(color-swatch-label) { color: var(--shadow-secondary-text-color); } shopify-variant-selector::part(color-swatch-disabled) { opacity: var(--shadow-disabled-opacity); /* do not transition opacity - it causes a flash when changing variants */ pointer-events: none; } shopify-variant-selector::part(label) { color: var(--shadow-secondary-text-color); display: inline-block; font-size: var(--shadow-font-size-sm); font-weight: var(--shadow-font-weight-base); line-height: 1em; margin-bottom: calc(var(--shadow-spacing-sm) - 6px); } /* media queries */ /* md - and above */ @media (min-width: 768px) { :host { --shadow-section-max-width: 420px; } gift-dialog-content > section { min-width: var(--shadow-section-max-width); max-width: var(--shadow-section-max-width); } gift-dialog-header, gift-dialog-actions { min-width: var(--shadow-section-max-width); max-width: var(--shadow-section-max-width); } } /* md - and below */ @media (max-width: 768px) { :host { --shadow-section-max-width: 390px; } gift-dialog-content > section { min-width: var(--shadow-section-max-width); max-width: var(--shadow-section-max-width); } gift-dialog-header, gift-dialog-actions { min-width: var(--shadow-section-max-width); max-width: var(--shadow-section-max-width); padding: var(--shadow-spacing-base); } .gift-block-modal-layout { grid-template-areas: "gift-dialog-header" "media" "content" "gift-dialog-actions"; grid-template-columns: 1fr; grid-template-rows: auto auto 1fr auto; max-height: calc(100dvh - var(--shadow-spacing-base)); max-width: 100dvw; } gift-dialog-content { display: grid; grid-template-areas: "media" "content"; grid-template-columns: 1fr; grid-template-rows: auto 1fr; overflow-y: auto; overscroll-behavior: contain; scrollbar-width: thin; -webkit-overflow-scrolling: touch; } section#media { background: none; grid-row: auto; position: relative; padding: 0; & shopify-media { & img { border-radius: unset; min-height: var(--shadow-section-max-width); max-height: var(--shadow-section-max-width); } } } section#content { overflow-y: unset; padding: var(--shadow-spacing-base); &.with-media-inline { padding-top: 0; } & .gift-product-media { &:has(shopify-media) { --shadow-inline-media-max-size: 330px; } } } } /* sm - and below */ @media (max-width: 480px) { :host { --shadow-section-max-width: 100%; } section#media { & shopify-media { & img { border-radius: unset; min-height: 350px; max-height: 350px; } } } } /* animations for loaders */ @keyframes spin { 100% { transform: rotate(1turn); } } @keyframes unblur { from { filter: blur(2px); } to { filter: blur(0px); } }
Skip to content
Pause slideshow
Play slideshow
FREE delivery on all orders over AED 500
FREE delivery on all orders over AED 500
Currency
United Arab Emirates (AED د.إ)
Åland Islands (AED د.إ)
Albania (AED د.إ)
Andorra (AED د.إ)
Austria (AED د.إ)
Bahrain (AED د.إ)
Belarus (AED د.إ)
Belgium (AED د.إ)
Bosnia & Herzegovina (AED د.إ)
Bulgaria (AED د.إ)
Canada (AED د.إ)
Croatia (AED د.إ)
Czechia (AED د.إ)
Denmark (AED د.إ)
Estonia (AED د.إ)
Faroe Islands (AED د.إ)
Finland (AED د.إ)
France (AED د.إ)
Germany (AED د.إ)
Gibraltar (AED د.إ)
Greece (AED د.إ)
Guernsey (AED د.إ)
Hungary (AED د.إ)
Iceland (AED د.إ)
Ireland (AED د.إ)
Isle of Man (AED د.إ)
Italy (AED د.إ)
Japan (AED د.إ)
Jersey (AED د.إ)
Kosovo (AED د.إ)
Kuwait (AED د.إ)
Latvia (AED د.إ)
Liechtenstein (AED د.إ)
Lithuania (AED د.إ)
Luxembourg (AED د.إ)
Malta (AED د.إ)
Moldova (AED د.إ)
Monaco (AED د.إ)
Montenegro (AED د.إ)
Netherlands (AED د.إ)
North Macedonia (AED د.إ)
Norway (AED د.إ)
Oman (AED د.إ)
Poland (AED د.إ)
Portugal (AED د.إ)
Qatar (AED د.إ)
Romania (AED د.إ)
Russia (AED د.إ)
San Marino (AED د.إ)
Saudi Arabia (AED د.إ)
Serbia (AED د.إ)
Singapore (AED د.إ)
Slovakia (AED د.إ)
Slovenia (AED د.إ)
Spain (AED د.إ)
Svalbard & Jan Mayen (AED د.إ)
Sweden (AED د.إ)
Switzerland (AED د.إ)
Ukraine (AED د.إ)
United Arab Emirates (AED د.إ)
United Kingdom (AED د.إ)
United States (AED د.إ)
Vatican City (AED د.إ)
.
.
.
Site navigation
Search
Emirates Dimlaj Trading LLC
Search
Account
0
Cart
.
.
.
Site navigation
Close
Search
Home
Collections
All collections
Tea Sets
Turkish Coffee Cups
Trays & More
Silverware & Cutlery
Business to Business
Contact us
Blogs and news
Search
Goes great with
Quick shop
Add to cart
Efay Melamine Hana Leaf Plate 20" Ivory
Efay
Dhs. 60.00
Quick shop
Add to cart
Efay Melamine Canon Square Deep Bowl 7" Ivory
Efay
Dhs. 25.00
Quick shop
Add to cart
Efay Melamine Dido Economical Square Plate 16" Ivory
Efay
Dhs. 40.00
Quick shop
Add to cart
Efay Dido Classic Square Plate 9" Ivory
Efay
Dhs. 20.00
Add order note
Close
Your cart is currently empty.
Home
Collections
Expand submenu
Collections
All collections
Tea Sets
Turkish Coffee Cups
Trays & More
Silverware & Cutlery
Business to Business
Contact us
Blogs and news
Home
Collections
NEW
914 products
Free shipping on all orders over AED 500
Shop now
Sort
Featured
Best selling
Alphabetically, A-Z
Alphabetically, Z-A
Price, low to high
Price, high to low
Date, old to new
Date, new to old
Availability
In stock (835)
Out of stock (79)
Price
Product type
Accessories (5)
Arabic Coffee Cups (4)
Ashtray (1)
Ashtrays (14)
Astray (4)
basket (1)
Beer Glass (1)
Bell (1)
Bowl (23)
Bowls (9)
Cake Dome (2)
Cake Stands (1)
Candle Holder (8)
Candle Holders (8)
Candy bowl (1)
Candy Box (7)
Carafe (6)
Cawa Cups (14)
centerpiece (4)
Centerpieces (1)
Chair (2)
Coffee Cups (2)
Coffee Pots (4)
Coffee Sets (13)
Compartment Bowl (1)
Compartment Box (1)
compartment Box (1)
Compartment Tray (6)
Covers (1)
Cutlery (24)
Dame (1)
Decanter (7)
Decanters (3)
decor (6)
Dimlaj Cutlery (1)
Drinkset (12)
Flasks (6)
Flute Stemware (4)
Gift Set (6)
Glass Plates (21)
Goblet Stemware (10)
Ice-cream Cups (3)
Jewely Box (2)
Jug (5)
Jug and Tumbler (6)
Jugs (9)
Mixing Glass (1)
Mugs (26)
Notebook Sets (1)
Oil and Vinegar (1)
PAN (14)
Paperweight (5)
Plate (23)
Plates (8)
Platter (4)
Platters (30)
Porcelain Plates (10)
Pot (1)
ramekin (1)
ramekin Cupcake (2)
Ramekins (9)
Serving Bowls (56)
Short Tumblers (18)
Shots (1)
Stands (17)
Stemware (26)
Storage Basket (5)
Storage Box (5)
Storage Boxes (8)
Sugar Bowls (3)
Table (10)
Table Accessories (46)
Table Lamps (1)
Table lamps (1)
Tea cup (1)
Tea Cups (17)
Tea cups (1)
Tea Glass (1)
Tea Istikans With Handle (7)
Tea Istikans Without Handle (3)
Tea Pot (1)
Tea Pots (5)
Terrarium (2)
Tray (7)
Trays (5)
Trays & Accessories (7)
Trolley (3)
Tumbler (11)
Tumblers (20)
Vase (34)
Vases (21)
Vessel (3)
Votive (1)
Wine Carafe (2)
More filters
arabic shop (6)
Ashtrays (14)
Blue (24)
Bowl (14)
Bowls (17)
Candle Holder (24)
Candle Holders (4)
candy box (7)
Carafe (7)
Cawa Cups (14)
Centerpieces (12)
Charm (7)
Coaster (12)
Coffee Pots (7)
Coffee Sets (10)
Colored Vases (4)
Compartment Tray (7)
Cordoba (53)
Cordoba By Dimlaj (54)
Cutlery (24)
Cutlery pocket (6)
cutlery set (24)
Decanter (4)
Decanters (6)
Dimlaj (272)
Dimlaj Hayat Serving Bowl (4)
dimlaj online shop (5)
Dimlaj Shafa Acrylic Coffee Stand (5)
dimlaj shop (8)
Drinkset (8)
efay (81)
End of Year Sale (32)
Eye (7)
Flask (6)
Gift (14)
Gift Set (23)
Gifts (9)
Glass (7)
Glass Plates (20)
Goblet Stems (9)
Gold (22)
Highball Tumblers (6)
Ivory (6)
Jug (11)
Jugs (9)
Kareem (80)
Kareem By Dimlaj (15)
Leather (30)
Limited Edition (6)
Lowball Tumblers (6)
luxury gifts (10)
Melange (41)
Melange By Dimlaj (17)
Mug (13)
Mugs (13)
Nagham (21)
nagham (6)
Napkin rings (6)
NEW (31)
PAN (9)
Pasabahce (141)
Pink (21)
Placemats (6)
Plate (18)
Plates (9)
Platinum (24)
Platters (27)
Porcelain Plates (12)
PU Leather (9)
pu leather (6)
Ramekins (7)
serving bowl (6)
Serving Bowls (47)
Shafa (6)
Shape_Rectangular (6)
Shape_Round (4)
shop.dimlaj (5)
Short Tumblers (7)
Sola (24)
Stainless Steel (6)
Stands (16)
Stemware (25)
Storage (15)
Sugar Bowls (4)
Table Accessories (39)
Tea Cups (15)
Tea Istikans With Handle (6)
Thuluth (62)
Thuluth By Dimlaj (8)
Thuluth Double Wall (6)
Tray (9)
Trays (8)
Tumbler (16)
Tumblers (17)
Vacuum (6)
Vase (38)
Vases (14)
wedding gifts (10)
Zodiac (12)
Zown (13)
Brand
Charm By Dimlaj (7)
Cordoba By Dimlaj (88)
Dar By Dimlaj (19)
Efay (96)
Emirates Dimlaj Trading LLC (5)
Hayat By Dimlaj (44)
Ivory By Dimlaj (11)
Kareem By Dimlaj (108)
Krosno (1)
Melange By Dimlaj (41)
Nagham By Dimlaj (44)
Nude Glass (110)
Pasabahce (189)
Pasabahce Essentials (2)
Shafa By Dimlaj (12)
Sola (24)
Thuluth By Dimlaj (84)
Zodiac By Dimlaj (12)
Zown (17)
.
.
.
.
Filter
914 products
Sort
Featured
Best selling
Alphabetically, A-Z
Alphabetically, Z-A
Price, low to high
Price, high to low
Date, old to new
Date, new to old
Sort
Large
Small
List
Quick shop
Add to cart
Efay Melamine Hana Leaf Plate 20" Ivory
Efay
Dhs. 60.00
Quick shop
Add to cart
Efay Melamine Canon Square Deep Bowl 7" Ivory
Efay
Dhs. 25.00
Quick shop
Add to cart
Efay Melamine Dido Economical Square Plate 16" Ivory
Efay
Dhs. 40.00
Quick shop
Add to cart
Efay Dido Classic Square Plate 9" Ivory
Efay
Dhs. 20.00
Quick shop
Add to cart
Efay Melamine Dido Rectangular Plate 22" Ivory
Efay
Dhs. 90.00
Quick shop
Add to cart
Efay Dido Classic Rectangular Plate 17.5" Ivory
Efay
Dhs. 55.00
Quick shop
Add to cart
Efay Melamine Gastronorm 1/6 65mm Europe Ivory
Efay
Dhs. 30.00
Quick shop
Add to cart
Efay Melamine Gastronorm 1/2 Square Platter Wide Rim Ivory
Efay
Dhs. 30.00
Quick shop
Add to cart
Efay Melamine Gastronom 1/6 100mm Europe Ivory
Efay
Dhs. 30.00
Quick shop
Add to cart
Efay Melamine Gastronom 1/2 40mm Europe Ivory
Efay
Dhs. 40.00
Quick shop
Add to cart
Efay Melamine Gastronom 1/2 20mm Europe Ivory
Efay
Dhs. 25.00
Quick shop
Add to cart
Efay Melamine Gastronorm 2/4 American Ivory
Efay
Dhs. 55.00
Quick shop
Add to cart
Efay Melamine Gastronorm 2/4 20mm American Ivory
Efay
Dhs. 35.00
Quick shop
Add to cart
Efay Gastronorm 1/6 65mm America Ivory
Efay
Dhs. 30.00
Quick shop
Add to cart
Efay Melamine Gastronorm 1/2 40mm America Ivory
Efay
Dhs. 40.00
Quick shop
Add to cart
Efay Melamine Gastronorm 1/2 20mm American Ivory
Efay
Dhs. 25.00
Quick shop
Add to cart
Nude Essentials Sweets Vase Opal Pink with Glossy White Base Medium 240mm
Pasabahce
Dhs. 1,840.00
Quick shop
Add to cart
Nude Essentials Sweets Vase Opal Pink with Glossy White Base Small 200mm
Pasabahce
Dhs. 1,840.00
Quick shop
Add to cart
Nude Essentials Sweets Vase Opal Pink with White Glossy Base Large 270mm
Pasabahce
Dhs. 1,840.00
Quick shop
Add to cart
Nude Essentials Stem Zero Trio Champagne Glass 285cc Clear
Pasabahce
Dhs. 305.00
Quick shop
Add to cart
Nude Essentials Stem Zero Trio Red Wine Glass 510cc Clear
Pasabahce
Dhs. 305.00
Quick shop
Add to cart
Nude Essentials Stem Zero Master Glass 420cc Clear
Pasabahce
Dhs. 305.00
Quick shop
Add to cart
Nude Essentials Stem Zero Volcano Champagne Glass 300cc Clear
Pasabahce
Dhs. 305.00
Quick shop
Add to cart
Nude Essentials Stem Zero Champagne Grand Cru Glass 450cc Clear
Pasabahce
Dhs. 305.00
Quick shop
Add to cart
Nude Essentials Silhouette Compartment Tray Single Section Short 34mm Clear
Pasabahce
Dhs. 295.00
Quick shop
Add to cart
Nude Essentials Silhouette Compartment Tray Single Section Long 34mm Clear
Pasabahce
Dhs. 370.00
Quick shop
Add to cart
Nude Essentials Silhouette Footed Bowl 45mm Clear
Pasabahce
Dhs. 360.00
Quick shop
Add to cart
Nude Essentials Silhouette Compartment Tray 2 Sections Curved 44mm Clear
Pasabahce
Dhs. 295.00
Quick shop
Add to cart
Nude Essentials Silhouette Compartment Tray 3 Sections Curved 44mm Clear
Pasabahce
Dhs. 370.00
Quick shop
Add to cart
Nude Essentials Silhouette Compartment Tray 32mm Clear
Pasabahce
Dhs. 370.00
Quick shop
Add to cart
Nude Essentials Roots Orchid Pot 1050cc White and Pink
Pasabahce
Dhs. 1,260.00
Quick shop
Add to cart
Nude Essentials Stem Zero Set of 2pcs Tumblers 250cc Clear
Pasabahce
Dhs. 265.00
Quick shop
Add to cart
Nude Essentials Pure Set of 4pcs Tumblers 610cc Clear
Pasabahce
Dhs. 205.00
Quick shop
Sold Out
Nude Poem Water Bottle 700cc Green
Pasabahce
Dhs. 235.00
Quick shop
Add to cart
Nude Essentials Pigmento Storage Box Tall 590cc Pink
Pasabahce
Dhs. 325.00
Quick shop
Add to cart
Nude Essentials Pigmento Storage Box Tall 590cc Yellow
Pasabahce
Dhs. 325.00
Quick shop
Add to cart
Nude Essentials Pigmento Storage Box Short 660cc Beige
Pasabahce
Dhs. 320.00
Quick shop
Add to cart
Nude Essentials Pigmento Serving Dish 278mm Yellow and Grey
Pasabahce
Dhs. 375.00
Quick shop
Add to cart
Nude Essentials Pigmento Cake Dome 300mm Pink
Pasabahce
Dhs. 690.00
Quick shop
Add to cart
Nude Essentials Pigmento Serving Dish 350mm Pink and Grey
Pasabahce
Dhs. 435.00
1
…
9
10
11
12
13
…
23
Recently viewed
Discover New Collections and Exciting Items | Dimlaj Emirates