/* Receipt */
.receipt{padding-top:40px!important;padding-bottom:80px!important;overflow:hidden}
.receipt__content{background-color:var(--secondary-color)!important;padding:40px 20px!important;border-radius:20px!important;border:solid 8px #CCE7D3!important;max-width:1020px!important;margin-left:auto!important;margin-right:auto!important;position:relative;text-align:center;overflow:visible;display:grid;grid-template-columns:1fr;gap:32px;box-sizing:border-box!important}
.receipt__form--title{font-size:30px!important;color:var(--primary-color)!important;margin-bottom:16px;text-transform:uppercase;font-weight:600;line-height:32px;letter-spacing:0.9px}
.receipt__form--subtitle{color:#000!important;font-size:18px!important;letter-spacing:0.64px;font-weight:400!important;margin-bottom:16px;line-height:22px}
.receipt p{font-size:16px!important;color:#000;line-height:20px}
.receipt__img-wrapper,.receipt__dropzone-wrapper{position:relative;display:flex;align-items:center;justify-content:center;grid-column:1;grid-row:1}
.receipt__img-wrapper{margin-bottom:0}
.receipt__img{position:relative;z-index:1;margin-left:auto;margin-right:auto;object-fit:contain}
.receipt__form{display:grid;grid-template-rows:1fr auto}
.receipt__step{grid-row:1;grid-column:1;display:none;flex-direction:column;justify-content:center}
.receipt__step.active{display:flex}
.retailer-roll__logo.desktop {margin: auto;}
.receipt__field{text-align:left;margin-top:32px;position:relative}
.receipt__label{position:absolute;top:-6px;left:12px;font-size:11px!important;font-weight:600;color:#000;background-color:var(--secondary-color);padding:0 4px;z-index:1;line-height:1}
.receipt__label span{color:#E53935}
.receipt__select-wrapper{position:relative}
.receipt__select{width:100%;padding:14px 40px 14px 16px!important;border:1px solid #000!important;border-radius:8px!important;font-size:20px!important;font-family:var(--font);color:rgba(0,0,0,0.4);outline:none;transition:border-color 0.3s;background-color:var(--secondary-color);appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;box-sizing:border-box!important}
.receipt__select:focus{border-color:var(--primary-color);color:#333}
.receipt__select--error{border-color:#E53935!important}
.receipt__error{display:none;color:#E53935;font-size:13px!important;font-weight:600;text-align:left;margin-top:6px}
.receipt__error--visible{display:block!important}
#file-error{background-color:#FF4150;color:#fff!important;font-size:14px!important;border-radius:8px;padding:8px 10px;letter-spacing:0.28px;line-height:14.7px}
.receipt__select option:not(:first-child){color:#333}
.receipt__select-wrapper::after{content:"";position:absolute;right:14px;top:50%;width:10px;height:10px;border-right:2px solid #858C94;border-bottom:2px solid #858C94;transform:translateY(-60%) rotate(45deg);pointer-events:none}
.receipt__upload-input{display:none}
.receipt__dropzone-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.receipt__howto-link{font-size:16px;color:var(--primary-color);text-decoration:underline;font-weight:400;width:238px;max-width:100%;text-align:right;margin-bottom:4px}
.receipt__dropzone{position:relative;width:100%;aspect-ratio:1/1;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color 0.3s,background-color 0.3s;overflow:hidden}
.receipt__dropzone.dragover{border-color:var(--primary-color);background-color:#2a1540}
.receipt__dropzone-content{background-color: #442778;display: flex;align-items: center;justify-content: center;width: 100%;max-width: 100%;aspect-ratio: 1 / 1; border-radius: 12px;padding: 16px;
  box-sizing: border-box;position: relative;overflow: hidden;}
.receipt__dropzone-icon{color:rgba(255,255,255,0.6);width:50px;height:50px}
.receipt__dropzone-preview{width:100%;height:100%;display:none;position:absolute;left:0;top:0;object-fit:cover;z-index:1}
.receipt__dropzone-frame{display:block;max-width:100%;z-index:2;pointer-events:none;object-fit:fill;border-radius:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.receipt__dropzone-pdf{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;overflow:hidden}
.receipt__dropzone-pdf-canvas{position:relative;z-index:1;max-width:100%;max-height:100%;width:auto;height:auto;display:block}
.receipt__dropzone-pdf-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:rgba(68,39,120,0.7);background:#fff;z-index:0;pointer-events:none}
.receipt__dropzone-pdf-fallback svg{width:48px;height:48px}
.receipt__dropzone-pdf-fallback span{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--primary-color)}
.receipt__dropzone-text{font-size:16px;color:#000;font-weight:600;margin-top:8px}
.receipt__dropzone-upload{color:#000;font-weight:600;text-decoration:underline;cursor:pointer}
.receipt__dropzone-formats{font-size:16px;color:#000}
.receipt__file-info{display:none;align-items:center;justify-content:space-between;width:85%;margin-top:10px;gap:12px}
.receipt__file-info.receipt__file-info--visible{display:flex !important}
.receipt__file-name{font-size:14px;color:#000;font-weight:500;font-family:var(--font);overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.receipt__file-delete{background:none;border:none;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.receipt__file-delete svg{width:20px;height:20px;display:block}
.receipt__form__footer{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:24px}
.receipt__form__nav{display:flex;align-items:center;justify-content:center;width:47px!important;height:47px!important;border-radius:50%;border:none;cursor:pointer}
.receipt__form__nav--prev{background:var(--primary-color)}
.receipt__form__nav--prev:not([disabled]) path{fill-opacity:1}
.receipt__form__nav--next{background:var(--primary-color)}
.receipt__form__nav--next[disabled] path{fill-opacity:0.6}
.receipt__form__count{font-size:18px!important;color:#000;font-family:var(--font);font-weight:600;letter-spacing:1.44px}
.receipt__form__nav[disabled]{background:#A3A3A3;cursor:not-allowed;pointer-events:none}
.receipt__store-info{margin-top:12px}
.receipt__store-hint{font-size:12px;color:#000;margin-bottom:10px;line-height:1.4}
.receipt__reminder{display:none;color:#E53935!important;font-size:13px!important;font-weight:500;line-height:1.4;margin:6px 0 4px;text-align:left}
.receipt__checkbox{text-align:left}
.receipt__checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.receipt__checkbox-input{display:none}
.receipt__checkbox-box{width:20px!important;height:20px!important;min-width:20px;border:1px solid #000;border-radius:4px;display:inline-block;position:relative;margin-top:0}
.receipt__checkbox-input:checked + .receipt__checkbox-box::after{content:""!important;position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid var(--primary-color);border-width:0 2px 2px 0;transform:rotate(45deg)}
.receipt__checkbox-text{font-size:13px!important;color:#000;line-height:1.4}
.receipt__terms-link{color:#000;text-transform:uppercase}
.receipt__store-name{font-weight:600}
.receipt__required{color:#E53935}
p.receipt__terms{font-size:11px!important;color:#fff!important;line-height:1.5;margin-top:24px;text-align:left;font-weight:400;padding:0 4px}
.receipt__loading{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;z-index:9999;display:flex;align-items:center;justify-content:center;background:#290743CC;padding:2rem}
.loading-wrapper{max-width:1080px;width:100%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,1);border-radius:30px}
.receipt__loading-box{text-align:center;padding:40px 24px;max-width:460px}
.receipt__loading-spinner{animation:receipt-spin 1s linear infinite;margin-bottom:24px;width:48px;height:48px}
@keyframes receipt-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.receipt__loading-text{font-size:16px;color:#1a0a30;font-weight:500;line-height:1.5}
.receipt__boost{position:absolute;top:-30px;left:0;width:25%;max-width:120px;z-index:2}
.receipt__crunchie{position:absolute;top:-30px;right:-10px;width:25%;max-width:120px}

/* Gateway Screens */
.gateway{padding-top:24px!important;padding-bottom:48px!important;overflow:hidden}
.gateway__content{background-color:var(--secondary-color)!important;padding:24px 20px!important;border-radius:20px!important;border:solid 8px #CCE7D3!important;max-width:1020px!important;margin-left:auto!important;margin-right:auto!important;position:relative;text-align:center;overflow:visible;display:grid;grid-template-columns:1fr;box-sizing:border-box!important;gap:30px}
.gateway__img-wrapper{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:0}
.gateway__img{position:relative;z-index:1;margin-left:auto;margin-right:auto;object-fit:contain}
.gateway__info{text-align:center}
.gateway__title{color:var(--primary-color)!important;margin-bottom:8px;text-transform:uppercase;line-height;font-size:48px!important;font-weight:600}
.gateway__subtitle{color:#000!important;font-size:14px!important;letter-spacing:0.64px;font-weight:400!important;margin-bottom:6px;line-height:1.5}
.gateway__text{font-size:12px!important;color:#000;line-height:1.5;margin-top:8px}
.gateway__cta{display:inline-flex!important;align-items:center;justify-content:center;background-color:var(--primary-color)!important;color:var(--secondary)!important;font-size:16px!important;font-weight:600!important;text-transform:uppercase;text-decoration:none!important;border-radius:100px!important;padding:14px 24px!important;margin-top:20px!important;letter-spacing:1px;transition:background-color 0.3s;width:100%;max-width:100%;box-sizing:border-box!important;border:none;cursor:pointer;font-family:var(--font)}
.gateway__cta:hover{background-color:#7846a2!important}
.gateway__link{display:block;font-size:13px;color:#000;margin-top:16px;line-height:1.5}
.gateway__link a{color:var(--primary-color);font-weight:600;text-decoration:underline}
.gateway__crunchie{position:absolute;top:-30px;right:-10px;width:25%;max-width:120px}
.gateway__boost{display:none}
.receipt__store-hint {text-align: left;color: #09101D;opacity: 0.6;padding: 0 16px;margin-bottom: 15px;}

/* Receipt How-to Modal */
.receipt-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}
.receipt-modal__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(26,10,48,0.92)}
.receipt-modal__content{position:relative;background:#fff;border-radius:20px;max-width:820px;width:100%;display:flex;flex-direction:column;overflow:hidden;padding:32px 24px;gap:24px;z-index:1}
.receipt-modal__img-wrapper{flex-shrink:0;display:flex;align-items:center;justify-content:center}
.receipt-modal__img{max-width:200px;width:100%;display:block;margin:0 auto}
.receipt-modal__info{text-align:left}
.receipt-modal__title{color:var(--primary-color);text-transform:uppercase;margin-bottom:16px;font-family:var(--font)}
.receipt-modal__list{list-style:disc;padding-left:20px;margin-bottom:24px}
.receipt-modal__list li{color:#000;font-size:14px;line-height:1.7;margin-bottom:2px;list-style-type:disc}
.receipt-modal__btn{display:inline-flex;align-items:center;justify-content:center;background-color:var(--primary-color);color:var(--secondary);font-size:18px;font-weight:600;text-transform:uppercase;border:none;border-radius:100px;padding:14px 60px;cursor:pointer;font-family:var(--font);letter-spacing:1px;transition:background-color 0.3s;width:100%}
.receipt-modal__btn:hover{background-color:#7846a2}

/* Delete Modal */
.delete-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}
.delete-modal__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(26,10,48,0.92)}
.delete-modal__content{position:relative;background:#fff;border:3px dashed #56CBF9;border-radius:16px;max-width:1080px;width:100%;padding:40px 32px;text-align:center;z-index:1}
.delete-modal__title{color:var(--primary-color);text-transform:uppercase;margin-bottom:16px;font-family:var(--font)}
.delete-modal__text{color:#000;font-size:16px;line-height:1.5;margin-bottom:24px;font-family:var(--font)}
.delete-modal__btn{display:inline-flex;align-items:center;justify-content:center;background-color:var(--primary-color);color:var(--secondary);font-size:18px;font-weight:600;text-transform:uppercase;border:none;border-radius:100px;padding:14px 48px;cursor:pointer;font-family:var(--font);letter-spacing:1px;transition:background-color 0.3s;margin-bottom:12px}
.delete-modal__btn:hover{background-color:#7846a2}
.delete-modal__link{display:block;color:var(--primary-color);font-size:14px;text-decoration:underline;font-weight:400;font-family:var(--font);margin-top:16px}

/* Dice Modal */
.dice-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:3000;display:flex;align-items:center;justify-content:center;padding:0}
.dice-modal__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.95)}
.dice-modal__content{position:relative;max-width:90vw;max-height:90vh;z-index:1;display:flex;align-items:center;justify-content:center}
.dice-modal__video{max-width:100%;max-height:90vh;display:block;background:#000;border-radius:8px}
.dice-modal__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border:4px solid rgba(255,255,255,0.25);border-top-color:#FFCC1F;border-radius:50%;animation:dice-spin 0.8s linear infinite;z-index:2;pointer-events:none}
@keyframes dice-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.dice-modal__close{position:absolute;top:-44px;right:-4px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:8px 12px;line-height:1;font-family:var(--font)}
.dice-modal__close:hover{opacity:0.7}

/* Promo Result */
.promo-result{padding-top:24px;padding-bottom:48px;overflow:hidden}
.promo-result__header{text-align:center;margin-bottom:16px;position:relative;z-index:2}
.promo-result__cadbury-logo{max-width:160px;height:auto;display:inline-block}
.promo-result__card{background:radial-gradient(ellipse at top,#5A3490 0%,#442778 55%,#2D1957 100%);padding:40px 24px 48px!important;border-radius:24px!important;max-width:1020px!important;margin:0 auto;position:relative;text-align:center;overflow:hidden;box-sizing:border-box;color:#fff;box-shadow:0 12px 60px rgba(0,0,0,0.35),0 0 80px rgba(255,204,31,0.12) inset}
.promo-result__card::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 12% 18%,#FFCC1F 0,transparent 2.5px),radial-gradient(circle at 88% 12%,#FFE680 0,transparent 3px),radial-gradient(circle at 22% 78%,#FFCC1F 0,transparent 2px),radial-gradient(circle at 78% 70%,#FFE680 0,transparent 2.5px),radial-gradient(circle at 50% 8%,#FFCC1F 0,transparent 2px),radial-gradient(circle at 8% 50%,#FFE680 0,transparent 2px),radial-gradient(circle at 95% 45%,#FFCC1F 0,transparent 3px),radial-gradient(circle at 40% 92%,#FFCC1F 0,transparent 2px),radial-gradient(circle at 65% 30%,#FFE680 0,transparent 2px),radial-gradient(circle at 32% 40%,#FFCC1F 0,transparent 1.5px),radial-gradient(circle at 72% 88%,#FFE680 0,transparent 2.5px),radial-gradient(circle at 18% 60%,#FFCC1F 0,transparent 1.5px);background-size:100% 100%;background-repeat:no-repeat;pointer-events:none;opacity:0.55;z-index:1}
.promo-result__inner{position:relative;z-index:3;padding:0 12px}
.promo-result__crunchie{position:absolute;top:-28px;right:-30px;width:160px;height:auto;z-index:4;pointer-events:none;transform:rotate(8deg);filter:drop-shadow(0 8px 16px rgba(0,0,0,0.35))}
.promo-result__boost{position:absolute;bottom:60px;left:-30px;width:130px;height:auto;z-index:4;pointer-events:none;transform:rotate(-14deg);filter:drop-shadow(0 8px 16px rgba(0,0,0,0.35))}
.promo-result__monopoly{position:absolute;bottom:-8px;right:10px;width:160px;height:auto;z-index:5;pointer-events:none;filter:drop-shadow(0 6px 16px rgba(0,0,0,0.4))}
.promo-result__retailer-badge{width:96px;height:96px;border-radius:50%;background:#fff;display:inline-flex;align-items:center;justify-content:center;margin:0 auto 14px;padding:10px;box-sizing:border-box;box-shadow:0 6px 20px rgba(0,0,0,0.25)}
.promo-result__retailer-badge img{max-width:100%;max-height:100%;object-fit:contain}
.promo-result__egift{display:block;margin:0 auto 18px;max-width:240px;width:100%;height:auto;border-radius:12px;box-shadow:0 10px 28px rgba(0,0,0,0.3)}
.promo-result__topline{color:#FFCC1F!important;font-size:24px!important;font-weight:900;text-transform:uppercase;letter-spacing:2px;margin:0 0 4px;line-height:1;font-family:var(--font)}
.promo-result__prehero{color:#fff!important;font-size:16px!important;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin:0 0 4px;font-family:var(--font)}
.promo-result__hero{color:#FFCC1F!important;font-size:72px!important;font-weight:900;text-transform:uppercase;letter-spacing:2px;margin:0 0 12px;line-height:1;font-family:var(--font);text-shadow:0 4px 0 rgba(0,0,0,0.18),0 6px 14px rgba(0,0,0,0.3)}
.promo-result__subhero{color:#fff!important;font-size:18px!important;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;margin:0 auto 16px;line-height:1.2;font-family:var(--font);max-width:520px}
.promo-result__prize{color:#FFCC1F!important;font-size:18px!important;font-weight:700;margin:0 0 10px;line-height:1.3;font-family:var(--font)}
.promo-result__unique-id{color:#fff!important;font-size:13px!important;font-weight:600;letter-spacing:1px;margin:0 0 18px;font-family:var(--font)}
.promo-result__unique-id span{font-weight:700;color:#FFCC1F}
.promo-result__info{color:#fff!important;font-size:14px!important;line-height:1.5;margin:0 auto 22px;font-family:var(--font);max-width:540px}
.promo-result__actions{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:18px;position:relative;z-index:6}
.promo-result__cta{display:inline-flex;align-items:center;justify-content:center;background:#FFCC1F;color:var(--primary-color);font-size:16px;font-weight:700;text-transform:uppercase;text-decoration:none;border-radius:100px;padding:14px 40px;letter-spacing:1px;transition:opacity 0.3s;font-family:var(--font);min-width:200px;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.promo-result__cta:hover{opacity:0.85}
.promo-result__cta--secondary{background:transparent;color:#fff;border:2px solid #fff;box-shadow:none}
.promo-result__disclaimer{color:#fff!important;font-size:11px!important;opacity:0.65;line-height:1.4;margin:0 auto;font-family:var(--font);max-width:600px}

/* National Success */
.national-success{padding-top:48px;padding-bottom:48px;overflow:hidden}
.national-success__card{background-color:var(--secondary-color)!important;padding:40px 20px!important;border-radius:20px!important;border:8px solid #CCE7D3!important;max-width:1020px!important;margin-left:auto!important;margin-right:auto!important;position:relative;text-align:center;overflow:visible;box-sizing:border-box!important}
.national-success__img-wrapper{display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative}
.national-success__img{position:relative;z-index:1}
.national-success__right{text-align:center}
.national-success__title{color:var(--primary-color)!important;text-transform:uppercase;margin-bottom:16px;line-height:1.1}
.national-success__subtitle{color:#000!important;font-size:14px!important;font-family:var(--font)!important;font-weight:400;margin-bottom:12px;line-height:1.3;margin-bottom:16px}
.national-success__info{color:#000!important;font-size:14px!important;font-family:var(--font)!important;font-weight:400;margin-bottom:12px;line-height:1.3}
.national-success__cta{display:inline-flex;align-items:center;justify-content:center;background-color:var(--primary-color);color:var(--secondary);font-size:18px;font-weight:600;text-transform:uppercase;text-decoration:none;border-radius:100px;padding:14px 40px;margin-top:24px;letter-spacing:1px;transition:background-color 0.3s;font-family:var(--font)}
.national-success__cta:hover{background-color:#7846a2}
.national-success__crunchie{position:absolute;bottom:-30px;right:-20px;width:120px;pointer-events:none}
.national-success__boost{display:none}

/* Error Screen */
.error-screen{padding:80px 0}
.error-screen__card{max-width:680px;margin:0 auto;padding:40px 24px;text-align:center}
.error-screen__img-wrapper{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.error-screen__img{position:relative;z-index:1;width:auto;display:block;margin:0 auto}
.error-screen__title{line-height:1.1;margin-bottom:16px;}
.error-screen__message{color:var(--secondary);font-size:18px;line-height:1.5;margin-bottom:18px}
.error-screen__submessage{color:var(--secondary);font-size:18px;font-weight:400;line-height:1.5;margin-bottom:24px}
.error-screen__retailer-select{max-width:380px;margin:8px auto 24px;text-align:left}
.error-screen__retailer-select .receipt__label{display:block;color:var(--secondary);font-size:14px;font-weight:600;margin-bottom:8px;font-family:var(--font)}
.error-screen__retailer-select .receipt__label span{color:#FFCC1F}
.error-screen__retailer-select .receipt__error{display:none;color:#FFB4A8;font-size:13px;margin-top:6px;font-family:var(--font)}
.error-screen__retailer-select .receipt__error--visible{display:block}
.error-screen__btn{display:inline-block;padding:14px 60px;font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border:0;cursor:pointer;border-radius:100px;font-family:var(--font);min-width:260px}
.error-screen__btn--purple{background-color:var(--primary-color);color:var(--secondary);transition:background-color 0.3s}
.error-screen__btn--purple:hover{background-color:#7846a2}
.error-screen__terms{font-size:14px;color:var(--secondary);line-height:1.5;margin-bottom:16px}
.error-screen__terms-link{color:inherit;text-decoration:underline;font-weight:600}
.error-screen__contact{display:block;margin-top:16px;color:var(--secondary);font-size:13px;text-decoration:none}
.error-screen__contact:hover{opacity:0.8}
.error-screen__card--white{background-color:#ffffff;border-radius:20px!important;border:solid 8px #CCE7D3!important;max-width:1020px!important;position:relative;overflow:visible;padding:40px 20px!important;box-sizing:border-box!important}
.error-screen__card--white .error-screen__title{background:none;-webkit-text-fill-color:var(--primary-color);color:var(--primary-color);-webkit-background-clip:unset}
.error-screen__card--white .error-screen__message{color:#000}
.error-screen__card--white .error-screen__submessage{color:#000}
.error-screen__card--white .error-screen__contact{color:var(--primary-color)}
.error-screen__card--white #error-screen-review a,
.error-screen__card--white #error-screen-contact a{color:var(--primary-color);text-decoration:underline}
.error-screen__card--white .error-screen__terms{color:#000}
.error-screen__card--white .error-screen__terms-link{color:#000}

/* Ready to Roll */
.ready-roll{padding-top:48px;padding-bottom:48px;position:relative;overflow:hidden}
.ready-roll__card{background-color:#fff;padding:40px 24px;border-radius:24px;max-width:1080px;margin:0 auto;position:relative;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,0.18)}
.ready-roll__mono-wrap{margin:0 auto 24px;display:flex;align-items:center;justify-content:center;position:relative}
.ready-roll__right{text-align:center}
.ready-roll__title{color:var(--primary-color);font-family:var(--font);text-transform:uppercase;margin:0 0 14px;line-height:1.05;text-align:center}
.ready-roll__subtitle{color:#000;font-family:var(--font);font-weight:400;font-size:20px;line-height:1.5;margin:0 0 14px;text-align:center}
.ready-roll__cta{display:inline-block;background:none;border:none;padding:0;margin-top:6px;cursor:pointer;line-height:0;border-radius:100px;overflow:hidden;transition:opacity 0.3s}
.ready-roll__cta img{display:block;max-width:240px;width:100%;height:auto}
.ready-roll__cta:hover{opacity:0.9}
.ready-roll__resend{display:block;margin-top:16px;font-family:var(--font);font-size:12px;color:#000;opacity:0.7}
.ready-roll__resend a{color:var(--primary-color);text-decoration:underline}
.ready-roll__boost{position:absolute;top:20px;left:-10px;width:140px;height:auto;pointer-events:none;transform:rotate(-12deg);filter:drop-shadow(0 8px 16px rgba(0,0,0,0.25));z-index:2}
.ready-roll__crunchie{position:absolute;bottom:-10px;right:-10px;width:160px;height:auto;pointer-events:none;transform:rotate(10deg);filter:drop-shadow(0 8px 16px rgba(0,0,0,0.25));z-index:2}

/* Retailer Roll */
.retailer-roll{padding-top:48px;padding-bottom:48px}
.retailer-roll__card{background-color:var(--secondary-color)!important;padding:40px 20px!important;border-radius:20px!important;border:8px solid #CCE7D3!important;max-width:1020px!important;margin-left:auto!important;margin-right:auto!important;position:relative;text-align:center;overflow:visible;box-sizing:border-box!important}
.retailer-roll__left{display:flex;align-items:center;justify-content:center;margin-bottom:32px;flex-direction: column;}
.retailer-roll__chance{width:200px;height:auto;max-height:280px;object-fit:contain;display:block;border-radius:12px}
.retailer-roll__right{text-align:center}
.retailer-roll__logo{max-width:140px;max-height:60px;object-fit:contain;margin:0 auto 16px;display:block}
.retailer-roll__title{color:var(--primary-color);margin-bottom:12px;text-transform:uppercase;line-height:1.1;margin-top:25px}
.retailer-roll__subtitle{font-size:20px;color:var(--primary-color);font-weight:500;margin-bottom:12px;line-height:1.4}
.retailer-roll__prize{font-size:13px;color:#000;line-height:1.5;margin-bottom:0}
.retailer-roll__cta{display:inline-flex;align-items:center;justify-content:center;background-color:var(--primary-color);color:var(--secondary);font-size:18px;font-weight:600;text-transform:uppercase;text-decoration:none;border-radius:100px;padding:14px 40px;margin-top:24px;letter-spacing:1px;transition:background-color 0.3s;font-family:var(--font)}
.retailer-roll__cta:hover{background-color:#7846a2}
.retailer-roll__crunchie{position:absolute;top:-30px;right:-10px;width:25%;max-width:100px}
.retailer-roll__boost{display:none}

.desktop{display:none}
/* ===== max-width:768px ===== */
@media(max-width:768px){

  .error-screen{padding:40px 16px}
  .error-screen__btn{min-width:220px;width:100%;max-width:300px}
}

/* ===== min-width:576px ===== */
@media(min-width:576px){
  .receipt__boost{top:-40px;max-width:140px}
  .receipt__crunchie{top:-50px;max-width:140px}
  .gateway__crunchie{top:-50px;max-width:140px}
  .retailer-roll__crunchie{top:-50px;max-width:140px}
}

/* ===== min-width:768px ===== */
@media(min-width:768px){
  .mobile{display:none}
  .desktop{display:block}
  /* Receipt */
  .receipt{padding-top:120px!important;padding-bottom:120px!important}
  .receipt__content{padding:48px 40px!important;align-items:stretch!important;gap:40px!important;grid-template-columns:1fr 1fr!important}
  .receipt__form{grid-column:2;grid-row:1}
  .receipt__form--title{font-size:28px!important}
  .receipt__form--subtitle{font-size:16px!important;margin-bottom:10px!important}
  .receipt p{font-size:14px!important}
  .receipt__label{font-size:12px!important;background-color:var(--secondary-color)}
  .receipt__select{font-size:16px!important;padding:14px 40px 14px 16px!important}
  .receipt__field{margin-top:20px}
  .receipt__form__footer{margin-top:32px}
  .receipt__form__nav{width:47px!important;height:47px!important}
  .receipt__form__count{font-size:18px!important}
  .receipt__store-hint{font-size:13px}
  .receipt__reminder{font-size:14px}
  .receipt__checkbox-text{font-size:14px!important}
  p.receipt__terms{font-size:12px!important;margin-top:32px;padding:0}
  .receipt__file-name{font-size:16px}
  .receipt__file-delete svg{width:22px;height:22px}
  .receipt__dropzone-wrapper{gap:12px}
  .receipt__howto-link{width:289px}
  .receipt__dropzone{aspect-ratio:auto;border-width:3px;border-radius:16px;width:auto}
  .receipt__dropzone-content{width:289px;height:289px}
  .receipt__dropzone-frame{width:289px;height:289px}
  .receipt__dropzone-icon{width:50px;height:50px}
  .receipt__dropzone-text{font-size:16px;margin-top:12px}
  .receipt__dropzone-formats{font-size:16px}
  .receipt__boost{top:-20px;left:-40px;width:24%;max-width:none}
  .receipt__crunchie{right:-40px;bottom:-60px;top:auto;width:24%;max-width:none}
  /* Gateway */
  .gateway{padding-top:80px!important;padding-bottom:80px!important}
  .gateway__content{padding:48px 40px!important;gap:40px!important;grid-template-columns:1fr 1fr!important;align-items:center}
  .gateway__subtitle{font-size:16px!important}
  .gateway__cta{max-width:400px;font-size:18px!important;padding:16px 32px!important}
  .gateway__boost{display:block;max-width:300px;position:absolute;top:0;left:-90px}
  .retailer-roll__boost{display:block;max-width:300px;position:absolute;top:0;left:-90px}
  /* Receipt Modal */
  .receipt-modal__content{flex-direction:row;gap:40px;padding:48px 56px}
  .receipt-modal__img{max-width:260px}
  .receipt-modal__list li{font-size:15px}
  .receipt-modal__btn{width:auto;min-width:260px}
  /* Delete Modal */
  .delete-modal__content{padding:48px 126px}
  .delete-modal__text{font-size:24px}
  /* Dice Modal */
  .dice-modal__close{top:-48px;right:0;font-size:36px}
  /* Promo Result */
  .promo-result__card{padding:56px 80px 64px!important}
  .promo-result__cadbury-logo{max-width:200px}
  .promo-result__topline{font-size:32px!important}
  .promo-result__prehero{font-size:20px!important}
  .promo-result__hero{font-size:108px!important}
  .promo-result__subhero{font-size:24px!important}
  .promo-result__prize{font-size:22px!important}
  .promo-result__info{font-size:15px!important}
  .promo-result__actions{flex-direction:row;gap:16px;justify-content:center}
  .promo-result__crunchie{width:220px;top:-50px;right:-50px}
  .promo-result__boost{width:180px;bottom:80px;left:-50px}
  .promo-result__monopoly{width:240px;right:40px}
  .promo-result__egift{max-width:320px}
  .promo-result__retailer-badge{width:120px;height:120px}
  /* National Success */
  .national-success{padding-top:120px;padding-bottom:120px}
  .national-success__card{padding:48px 40px!important;display:grid!important;grid-template-columns:360px 1fr!important;align-items:center!important;gap:40px!important;text-align:left}
  .national-success__img-wrapper{margin-bottom:0}
  .national-success__subtitle{font-size:24px!important}
  .national-success__info{font-size:24px!important}
  .national-success__crunchie{width:160px;bottom:-40px;right:-40px}
  .national-success__boost{display:block;max-width:300px;position:absolute;top:0;left:-90px}
  /* Error Screen */
  .error-screen__btn{min-width:300px}
  .error-screen__card--white{padding:48px 40px!important;display:grid!important;grid-template-columns:1fr 1fr!important;align-items:center!important;gap:0 40px!important;text-align:center}
  .error-screen__card--white .error-screen__img-wrapper{grid-column:1;grid-row:1/-1;margin-bottom:0}
  .error-screen__card--white .error-screen__title{grid-column:2}
  .error-screen__card--white .error-screen__message{grid-column:2}
  .error-screen__message{font-size:22px}
  .error-screen__submessage{font-size:22px}

  .error-screen__card--white .error-screen__submessage{grid-column:2}
  .error-screen__card--white .error-screen__btn{grid-column:2}
  .error-screen__card--white .error-screen__terms{grid-column:2}
  .error-screen__card--white .error-screen__contact{grid-column:2}
  /* Ready to Roll */
  .ready-roll{padding-top:96px;padding-bottom:96px}
  .ready-roll__card{padding:80px;display:grid;grid-template-columns:360px 1fr;gap:48px;align-items:center;text-align:left}
  .ready-roll__mono-wrap{margin:0;width:280px;height:280px}
  .ready-roll__mono{max-width:220px}
  .ready-roll__right{text-align:left}
  .ready-roll__subtitle{font-size:15px}
  .ready-roll__boost{top:30px;left:-60px;width:180px}
  .ready-roll__crunchie{bottom:-30px;right:-60px;width:200px}
  /* Retailer Roll */
  .retailer-roll{padding-top:120px;padding-bottom:120px}
  .retailer-roll__card{padding:80px!important;display:grid!important;grid-template-columns:1fr 1fr!important;align-items:center!important;gap:40px!important;text-align:left}
  .retailer-roll__left{margin-bottom:0}
  .retailer-roll__chance{width:260px;max-height:360px;border-radius:16px}
  .retailer-roll__logo{margin:0 0 20px;max-width:180px;max-height:80px}
  .retailer-roll__subtitle{font-size:24px}
  .retailer-roll__prize{font-size: 16px;margin: auto;}
  .retailer-roll__crunchie{right:-12px;bottom:-112px;top:auto;width:24%;max-width:none}
}

/* ===== min-width:1024px ===== */
@media(min-width:1024px){
  .receipt__content{padding:56px 48px!important;gap:48px!important}
  .receipt__form--title{font-size:32px!important}
  .receipt__form--subtitle{font-size:18px!important}
  .receipt p{font-size:15px!important}
  .receipt__boost{left:-100px;top:-10px}
  .receipt__crunchie{right:-100px}
  .gateway__content{padding:56px 48px!important}
  .gateway__crunchie{right:-100px}
  .national-success__card{padding:80px!important;gap:60px!important}
}

/* ===== min-width:1200px ===== */
@media(min-width:1200px){
  .receipt__content{padding:80px!important;gap:64px!important;grid-template-columns:6fr 7fr!important;border-width:10px!important}
  .receipt__form--title{font-size:48px!important;line-height:42px;margin-bottom:16px;letter-spacing:2px}
  .receipt__form--subtitle{font-size:24px!important;line-height:28px;margin-bottom:16px}
  .receipt p{font-size:16px!important;line-height:20px}
  .receipt__field{margin-top:32px}
  .receipt__select{font-size:20px!important}
  .receipt__boost{left:-173px;top:0}
  .receipt__crunchie{right:-180px}
  .gateway__content{padding:80px!important}
  .gateway__crunchie{right:-180px;bottom:-60px;top:auto;width:24%;max-width:none}
  .gateway__boost{max-width:544px;left:-150px}
  .retailer-roll__boost{max-width:544px;left:-150px}
  .ready-roll__boost{width:100%;max-width:467px;left:-310px;top:-56px;}
  .ready-roll__crunchie{right:-120px;width:220px}
  .retailer-roll__crunchie{right:-80px}
  .national-success__subtitle{font-size:24px}
  .national-success__info{font-size:24px}
  .error-screen__card--white{padding:80px!important;display:grid!important;grid-template-columns:360px 1fr!important;align-items:center!important;gap:0 20px!important;text-align:center}
  .national-success__crunchie{right: -226px;top: 55%; bottom: auto;width: 30%;}
  .national-success__boost{max-width:544px;left:-150px}
}

/* ===== min-width:1400px ===== */
@media(min-width:1400px){
  .receipt__boost{left:-221px;top:0;width:30%}
  .receipt__crunchie{right:-221px;bottom:-8px;top:auto;width:30%}
  .retailer-roll__crunchie{right:-245px;bottom:-115px;top:auto;width:32%}
}
.text-16{font-size:16px}

@media(max-width:767px){
  .receipt-modal__content{height: 100%;overflow-y:scroll;}
}