*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%}.app-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;background:#fff;padding:2rem}.cart-container{max-width:400px;width:100%;margin-top:0;padding-bottom:12rem}.cart-header{font-size:12px;color:#666;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.logo-container{text-align:center;margin-bottom:2rem;padding-top:1rem}.logo{max-width:160px;height:auto}.cart-item{display:flex;gap:.75rem;padding:1rem 0 .25rem;align-items:flex-start}.item-image{position:relative;flex-shrink:0}.placeholder-image{width:80px;height:80px;background:#fff;border-radius:4px;object-fit:contain;transform:translateY(-12px)}.package-icon{display:flex;align-items:center;justify-content:center}.item-quantity{position:absolute;top:-4px;right:-4px;background:#000;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500}.item-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.item-title{font-size:14px;font-weight:400;margin:0;color:#000;line-height:1.3}.item-size{font-size:12px;color:#666;margin:0}.item-description{font-size:14px;color:#666;margin:0}.remove-link{color:#000;text-decoration:underline;font-size:14px;margin-top:.5rem;display:inline-block}.item-price{font-size:14px;font-weight:400;color:#000;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.original-price{text-decoration:line-through;color:#999;font-size:14px}.free-price{color:#2e7d32;font-weight:500}.extra-item{background:#f9fdf9;border-left:3px solid #4caf50;padding-left:.75rem}.discount-tag{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin:.25rem 0;color:#777;font-size:13px;border-radius:4px;border-left:3px solid transparent}.tag-icon{flex-shrink:0;color:#777}.discount-code{color:#777}.discount-tag.rarity-common{background-color:#f5f5f5;border-left-color:#999}.discount-tag.rarity-common .tag-icon,.discount-tag.rarity-common .discount-code{color:#666}.discount-tag.rarity-uncommon{background-color:#e8f5e9;border-left-color:#4caf50}.discount-tag.rarity-uncommon .tag-icon,.discount-tag.rarity-uncommon .discount-code{color:#2e7d32}.discount-tag.rarity-rare{background-color:#e3f2fd;border-left-color:#2196f3}.discount-tag.rarity-rare .tag-icon,.discount-tag.rarity-rare .discount-code{color:#1565c0}.discount-tag.rarity-epic{background-color:#f3e5f5;border-left-color:#9c27b0}.discount-tag.rarity-epic .tag-icon,.discount-tag.rarity-epic .discount-code{color:#7b1fa2}.discount-tag.rarity-legendary{background-color:#f3e5f5;border-left-color:#9c27b0}.discount-tag.rarity-legendary .tag-icon,.discount-tag.rarity-legendary .discount-code{color:#7b1fa2}.section-divider{border-bottom:1px solid #e5e5e5;margin:0 0 1.5rem}.promo-section{display:flex;gap:.75rem;padding:0 0 1.5rem}.promo-section.shake{animation:shake .4s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{0%,to{transform:translate(0)}10%{transform:translate(-5.5px)}20%{transform:translate(5.5px)}30%{transform:translate(-4px)}40%{transform:translate(3px)}50%{transform:translate(-2px)}60%{transform:translate(1px)}70%{transform:translate(0)}80%{transform:translate(-1px)}90%{transform:translate(.5px)}}.promo-input{flex:1;padding:.75rem 1rem;border:1px solid #d0d0d0;border-radius:4px;font-size:16px;font-family:inherit}.promo-input:focus{outline:none}.promo-input.success-flash{animation:greenFlash .5s ease}@keyframes greenFlash{0%,to{border-color:#d0d0d0}50%{border-color:#4caf50;box-shadow:0 0 0 1px #4caf50}}.promo-input::placeholder{color:#999}.promo-input.success-text::placeholder{color:#2e7d32;font-weight:500}.apply-button{padding:.75rem 2rem;background:#e0e0e0;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;letter-spacing:.5px}.apply-button:hover{background:#d0d0d0}.promo-error{color:#d32f2f;font-size:14px;padding:.75rem 0 .5rem}.promo-success{color:#2e7d32;font-size:14px;padding:.5rem 0;margin-top:-1rem}.applied-promos{padding:1rem 0;border-bottom:1px solid #e5e5e5;margin-bottom:1rem}.applied-promos-title{font-size:14px;font-weight:500;margin-bottom:.5rem;color:#333}.applied-promo-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#f5f5f5;border-radius:4px;margin-bottom:.5rem;font-size:13px}.applied-promo-item:last-child{margin-bottom:0}.applied-promo-item.highlight{background-color:#e8f5e9;animation:appliedCodeHighlight 3s ease}@keyframes appliedCodeHighlight{0%{background-color:#e8f5e9}to{background-color:#f5f5f5}}.summary-row.discount,.discount-amount{color:#2e7d32}.package-protect-option{display:flex;justify-content:space-between;align-items:center;padding:2rem 0;border-bottom:1px solid #e5e5e5}.package-protect-info h4{font-size:18px;font-weight:400;margin:0 0 .5rem;color:#000}.info-icon{margin-left:.5rem;color:#666}.package-protect-info p{font-size:16px;color:#666;margin:0}.checkbox{width:28px;height:28px;cursor:pointer;accent-color:black}.summary-fixed{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e5e5;padding:1rem 2rem;box-shadow:0 -2px 10px #0000000d}.summary-container{max-width:400px;margin:0 auto}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:14px}.summary-row span{color:#777}.summary-row.total span{color:#000}.summary-price{font-weight:400;text-align:right}.summary-placeholder{color:#999}.summary-row.total{padding-top:1rem;padding-bottom:2.5rem;font-size:24px;font-weight:500}.total-label,.total-price{font-weight:500}.currency{font-size:14px;color:#666;margin-right:.5rem}.free-money-message{text-align:center;font-size:1.25rem;font-weight:600;color:#2e7d32;margin-top:.5rem;padding-bottom:1rem}.intro-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background:#fffffffa;z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem}.intro-message{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #0000001a;text-align:center;max-width:400px}.intro-title{font-size:1.5rem;margin:0 0 1rem;color:#000}.intro-text{font-size:.9rem;line-height:1.6;color:#333;margin:0 0 1.5rem}.intro-button{background-color:#000;color:#fff;border:none;padding:.75rem 2rem;font-size:.9rem;cursor:pointer;border-radius:4px;font-weight:500}.intro-button:active{transform:scale(.98)}.timer-pill{background:#00000014;color:#333;padding:.5rem 1.25rem;border-radius:50px;font-size:.9rem;font-weight:500;text-align:center;width:fit-content;margin:0 auto .75rem}.endgame-message{background:#fff;padding:2.5rem 2rem;border-radius:12px;box-shadow:0 4px 16px #00000026;text-align:center;max-width:450px;width:100%}.endgame-title{font-size:1.25rem;margin:0 0 1.5rem;color:#000}.endgame-stats{display:flex;flex-direction:column;gap:1.5rem}.endgame-stat-large{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:1.75rem;font-weight:600;color:#000}.endgame-divider{height:1px;background:#e5e5e5;margin:.5rem 0}.endgame-breakdown{text-align:left}.breakdown-title{font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:500;margin-bottom:1rem;text-align:center}.breakdown-items{display:flex;flex-direction:column;gap:.75rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f5f5f5;border-radius:6px}.breakdown-item-common{background-color:#f5f5f5}.breakdown-item-uncommon{background-color:#e8f5e9}.breakdown-item-rare{background-color:#e3f2fd}.breakdown-item-legendary{background-color:#f3e5f5}.breakdown-label{font-size:.9rem;font-weight:500}.breakdown-value{font-size:.9rem;font-weight:600;color:#333}.rarity-common-text{color:#666}.rarity-uncommon-text{color:#2e7d32}.rarity-rare-text{color:#1565c0}.rarity-legendary-text{color:#7b1fa2}.endgame-buttons{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem}.endgame-buttons .intro-button{margin:0;width:100%}.secondary-button{background-color:#fff;color:#000;border:1px solid #d0d0d0}.secondary-button:active{background-color:#f5f5f5}
