/* Reset e Utilitários Tailwind CSS (Conteúdo original que você forneceu) */
*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.relative{position:relative}.right-1{right:.25rem}.right-2{right:.5rem}.top-1{top:.25rem}.top-2{top:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-10{margin-bottom:2.5rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.ml-1{margin-left:.25rem}.ml-3{margin-left:.75rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.hidden{display:none}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-20{height:5rem}.h-24{height:6rem}.h-\[50px\]{height:50px}.h-full{height:100%}.w-1\/3{width:33.333333%}.w-1\/4{width:25%}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-auto{width:auto}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-lg{max-width:32rem}.flex-1{flex:1 1 0%}.flex-grow{flex-grow:1}.shrink-0{flex-shrink:0}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem*var(--tw-space-x-reverse));margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem*var(--tw-space-x-reverse));margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.self-center{align-self:center}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-full{border-radius:9999px}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[\#009d68\]{--tw-border-opacity:1;border-color:rgb(0 157 104/var(--tw-border-opacity,1))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-red-300{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-red-400{--tw-border-opacity:1;border-color:rgb(248 113 113/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.bg-\[\#008256\]{--tw-bg-opacity:1;background-color:rgb(0 130 86/var(--tw-bg-opacity,1))}.bg-\[\#009d68\]{--tw-bg-opacity:1;background-color:rgb(0 157 104/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-red-400{--tw-bg-opacity:1;background-color:rgb(248 113 113/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0\.5{padding:.125rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-center{text-align:center}.text-right{text-align:right}.font-\[\'Roboto\'\]{font-family:Roboto}.text-\[20\.8px\]{font-size:20.8px}.text-base{font-size:1rem;line-height:1.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-md{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.text-\[\#009d68\]{--tw-text-opacity:1;color:rgb(0 157 104/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hover\:bg-\[\#008256\]:hover{--tw-bg-opacity:1;background-color:rgb(0 130 86/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.focus\:border-\[\#009d68\]:focus{--tw-border-opacity:1;border-color:rgb(0 157 104/var(--tw-border-opacity,1))}.focus\:ring-\[\#009d68\]:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(0 157 104/var(--tw-ring-opacity,1))}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}@media (min-width:640px){.sm\:ml-1{margin-left:.25rem}.sm\:h-10{height:2.5rem}.sm\:h-14{height:3.5rem}.sm\:w-1\/3{width:33.333333%}.sm\:w-1\/4{width:25%}.sm\:flex-row{flex-direction:row}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem*var(--tw-space-x-reverse));margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0px*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px*var(--tw-space-y-reverse))}.sm\:inline{display:inline}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}}


/* Adições e Ajustes Customizados */

body {
  font-family: 'Roboto', ui-sans-serif, system-ui, sans-serif;
}

input[type="text"],
input[type="email"],
input[type="tel"],
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0.375rem; 
  padding: 0.75rem; 
  border: 1px solid #D1D5DB; 
  width: 100%;
  font-size: 0.875rem; 
  color: #374151; 
  transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="tel"]::placeholder {
    color: #6B7280; 
    opacity: 1;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
select:focus {
  outline: none;
  border-color: #009d68; 
  box-shadow: 0 0 0 2px rgba(0, 157, 104, 0.2); 
}

select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem; 
}

.payment-tab.active {
  border-color: #009d68; 
  background-color: #f0fdf4; 
  color: #009d68; 
  font-weight: 600; 
}

.payment-tab.active .check-icon {
  display: flex; 
}

.payment-tab .check-icon {
    display: none; 
}

/* Estilo para os Order Bumps (Revisão Profunda) */
.order-bump-item {
  background-color: #FFFBEB; /* Cor base do order bump, como bg-yellow-100 */
  border: 2px dashed #FCA5A5; /* Borda tracejada rosa/vermelho suave - como border-red-300 */
  border-radius: 0.5rem; 
  overflow: hidden; 
}

.order-bump-item .order-bump-header {
  background-color: #EF4444; /* Header Rosa/Vermelho vibrante - como bg-red-500 */ 
  color: white;
  font-weight: bold;
  padding: 0.75rem 1rem; 
  text-align: center;
  font-size: 1.125rem; 
}

.order-bump-item .order-bump-main-content { /* Conteúdo abaixo do header, com padding */
  padding: 1rem; 
}

.order-bump-item .order-bump-selection-area { /* Div que agrupa seta, checkbox, imagem, detalhes */
  display: flex;
  align-items: center; 
  background-color: #FFFFFF; /* MODIFICADO PARA BRANCO PURO */
  padding: 0.75rem; /* Padding interno para esta caixa */
  border-radius: 0.375rem; 
}

.order-bump-arrow {
  color: #EF4444; /* Vermelho da seta, como text-red-500 */
  font-size: 1.75rem; /* Tamanho da seta */
  line-height: 1; /* Alinhamento vertical */
  margin-right: 0.75rem; /* Espaço à direita da seta */
}

.order-bump-checkbox-custom {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 1.5rem;  /* w-6 */
  height: 1.5rem; /* h-6 */
  border: 2px solid #9CA3AF; /* borda cinza mais proeminente, como border-gray-400 */
  border-radius: 0.25rem; 
  display: inline-block;
  position: relative;
  cursor: pointer;
  flex-shrink: 0; 
  margin-right: 0.75rem; 
}

.order-bump-checkbox-custom:checked {
  background-color: #3B82F6; /* Azul da referência - como bg-blue-500 */
  border-color: #2563EB; /* Azul um pouco mais escuro para a borda quando checado - como border-blue-600 */
}

.order-bump-checkbox-custom:checked::after {
  content: '';
  position: absolute;
  left: 0.4rem;  
  top: 0.15rem;  
  width: 0.4rem; 
  height: 0.8rem; 
  border: solid white;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}

.order-bump-image-placeholder, 
.order-bump-no-image {
  width: 6rem;  /* w-24 */
  height: 6rem; /* h-24 */
  border-radius: 0.375rem; 
  object-fit: cover;
  flex-shrink: 0;
  margin-right: 0.75rem; 
}
.order-bump-image-placeholder {
  border: 1px solid #E5E7EB; 
}
.order-bump-no-image { 
  background-color: #F3F4F6; 
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9CA3AF; 
  font-size: 0.75rem; 
}

.order-bump-details {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

/* Controle do Spinner */
#submit-button .spinner { display: none; }
#submit-button.button-submitting .spinner { display: inline-block; }
#submit-button.button-submitting .button-text,
#submit-button.button-submitting .checkmark-icon { display: none; }

/* Estilos para o resumo do pedido detalhado */
#order-summary-details { /* A visibilidade é controlada por JS */ }
#summary-items-container .summary-item { display: flex; justify-content: space-between; padding-top: 0.25rem; padding-bottom: 0.25rem; }
#summary-items-container .summary-item-name { padding-right: 0.5rem; }
#summary-items-container .summary-item-price { white-space: nowrap; }
#summary-items-container .summary-item-tag { display: block; font-size: 0.75rem; color: #4f46e5; font-weight: 500; margin-left: 0.25rem; }
#summary-items-container .summary-orderbump-header { font-weight: 600; color: #374151; margin-top: 0.75rem; padding-top: 0.75rem; border-top: 1px solid #e5e7eb; margin-bottom: 0.25rem; }

/* Ajustes para o Order Bump em telas menores (Mobile) */
@media (max-width: 639px) { 
    .order-bump-selection-area {
        display: flex; /* Já é flex, mas para garantir */
        flex-direction: column; /* Empilha os itens principais verticalmente */
        align-items: center;    /* Centraliza os itens empilhados horizontalmente */
    }

    /* Criaremos um "wrapper" conceitual para a primeira linha (seta, checkbox, imagem)
       para que eles possam ser alinhados lado a lado e este wrapper seja centralizado.
       Como não podemos adicionar HTML, vamos fazer os 3 primeiros itens (ordem 1, 2, 3)
       se comportarem como uma linha, e depois os detalhes (ordem 4) como outra linha.
    */

    /* Removendo a ordem anterior para simplificar e controlar com o fluxo natural dentro de um novo contexto */
    .order-bump-arrow,
    .order-bump-checkbox-custom,
    .order-bump-image-placeholder,
    .order-bump-no-image,
    .order-bump-details {
        order: initial; /* Reseta a ordem */
        margin-top: 0;  /* Reseta margens superiores que podem ter sido adicionadas antes */
        margin-left: 0; /* Reseta margens esquerdas */
        margin-right: 0;/* Reseta margens direitas */
        flex-basis: auto; /* Reseta flex-basis */
        flex-grow: 0;   /* Reseta flex-grow */
    }

    /* Nova estrutura:
       1. Div para agrupar seta, checkbox e imagem (não podemos criar, então vamos usar CSS Grid ou um flex aninhado se possível)
          Como não podemos aninhar, vamos fazer a .order-bump-selection-area ser column,
          e o primeiro "item" dessa coluna será uma linha horizontal para seta, checkbox, imagem.
          Para isso, precisamos de um wrapper. Como não temos, vamos posicionar os 3 primeiros
          numa linha e centralizar ESSA LINHA. O text-align: center no pai não funciona para block/flex.
    */

    /* Precisamos de um jeito de agrupar a seta, checkbox e imagem horizontalmente
       e centralizar esse grupo. Então os detalhes vêm abaixo.
       Vamos fazer o .order-bump-selection-area ser flex row com wrap, e centralizar seus itens de linha.
    */
    .order-bump-selection-area {
        flex-direction: row; /* Voltamos para linha */
        flex-wrap: wrap;
        justify-content: center; /* Centraliza as linhas de itens */
        align-items: center;     /* Alinha os itens dentro de suas linhas verticalmente */
        gap: 0.5rem; /* Espaço entre os itens, pode ajustar */
    }
    
    /* Itens da primeira "linha visual" do wrap: seta, checkbox, imagem */
    .order-bump-arrow {
        /* Tamanho da seta */
        font-size: 1.75rem; /* Já definido globalmente, apenas para referência */
    }

    .order-bump-checkbox-custom {
        /* Tamanho do checkbox */
        width: 1.5rem; /* Já definido globalmente */
        height: 1.5rem;
    }

    .order-bump-image-placeholder,
    .order-bump-no-image {
        width: 7rem;  /* AUMENTANDO A IMAGEM (era 6rem) */
        height: 7rem; /* AUMENTANDO A IMAGEM */
        /* Margens laterais são controladas pelo 'gap' no container e pelo 'justify-content: center' */
    }

    /* Detalhes do texto - devem quebrar para a próxima linha e ocupar 100% da largura e centralizar o texto */
    .order-bump-details {
        flex-basis: 100%; /* Ocupa a largura total para formar sua própria linha */
        text-align: center; /* Centraliza o texto dentro dos detalhes */
        margin-top: 0.75rem; /* Espaço acima dos detalhes */
        padding-left: 0.5rem; /* Pequeno padding para não colar nas bordas */
        padding-right: 0.5rem;
    }
}