/* Krispy Kreme storefront – brand palette
   green #006442 / red #E62127 / cream #FBF8F1 / charcoal #1F1F1F */

:root{
  --kk-green:#006442;
  --kk-green-2:#004f34;
  --kk-red:#E62127;
  --kk-red-hover:#c0181d;
  --kk-cream:#FBF8F1;
  --kk-warm:#FFF6E9;
  --kk-ink:#1F1F1F;
  --kk-grey:#5b5b5b;
  --kk-line:#e6e1d8;
  --kk-glaze:#f3e2c4;
  --kk-radius:14px;
  --kk-radius-sm:8px;
  --kk-shadow:0 1px 2px rgba(0,0,0,.08),0 8px 24px rgba(0,0,0,.06);
  --kk-shadow-sm:0 1px 2px rgba(0,0,0,.05),0 2px 6px rgba(0,0,0,.04);
  --kk-font:"Brandon Grotesque","Helvetica Neue",Helvetica,Arial,system-ui,sans-serif;
  --kk-display:"Brandon Text","Helvetica Neue",Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--kk-cream);color:var(--kk-ink);font-family:var(--kk-font);font-size:16px;line-height:1.5}
img{display:block;max-width:100%;height:auto}
a{color:var(--kk-green);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit;cursor:pointer}

/* TOPBAR */
.kk-topbar{background:#fff;border-bottom:1px solid var(--kk-line);position:sticky;top:0;z-index:50}
.kk-topbar__wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:14px 24px}
.kk-brand img{height:46px;width:auto}
.kk-nav{display:flex;gap:24px;justify-self:center}
.kk-nav__link{color:var(--kk-ink);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px}
.kk-nav__link:hover{color:var(--kk-red);text-decoration:none}
.kk-actions{display:flex;gap:6px}
.kk-action{background:none;border:none;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;color:var(--kk-green);font-weight:700;text-transform:uppercase;font-size:13px;position:relative;text-decoration:none}
.kk-action:hover{background:var(--kk-warm)}
.kk-action__text{display:none}
.kk-cart-bubble{background:var(--kk-red);color:#fff;border-radius:999px;font-size:11px;line-height:1;min-width:20px;padding:4px 6px;font-weight:700;text-align:center;margin-left:2px}
.kk-cart-bubble:empty{display:none}

@media(min-width:760px){
  .kk-action__text{display:inline}
}
@media(max-width:760px){
  .kk-topbar__wrap{grid-template-columns:auto 1fr auto;gap:8px;padding:10px 16px}
  .kk-nav{display:none}
}

/* HERO */
.kk-hero{background:linear-gradient(135deg,var(--kk-green) 0%,var(--kk-green-2) 100%);color:#fff;padding:48px 24px}
.kk-hero__wrap{max-width:1200px;margin:0 auto}
.kk-hero__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:700;opacity:.85}
.kk-hero__title{font-family:var(--kk-display);font-size:clamp(36px,5vw,56px);font-weight:900;margin:8px 0 6px;text-transform:uppercase;letter-spacing:.02em}
.kk-hero__tagline{margin:0;font-size:18px;max-width:60ch;opacity:.92}

/* CAT NAV */
.kk-catnav{background:#fff;border-bottom:1px solid var(--kk-line)}
.kk-catnav__wrap{max-width:1200px;margin:0 auto;display:flex;gap:8px;padding:14px 24px;overflow-x:auto}
.kk-catnav__pill{padding:8px 18px;border:1px solid var(--kk-line);border-radius:999px;color:var(--kk-ink);font-weight:700;font-size:14px;white-space:nowrap}
.kk-catnav__pill.is-active{background:var(--kk-green);color:#fff;border-color:var(--kk-green)}

/* SHELL */
.kk-shell{max-width:1200px;margin:0 auto;padding:32px 24px;display:grid;grid-template-columns:1fr;gap:28px}
.kk-shell--product{grid-template-columns:1fr}
.kk-shell--cart,.kk-shell--checkout{grid-template-columns:1fr}

.kk-page-head h1{font-family:var(--kk-display);font-size:36px;margin:0 0 4px;text-transform:uppercase;color:var(--kk-ink)}
.kk-page-head p{color:var(--kk-grey);margin:0}

/* PRODUCT GRID */
.kk-grid--products{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.kk-card{background:#fff;border-radius:var(--kk-radius);box-shadow:var(--kk-shadow-sm);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.kk-card:hover{transform:translateY(-2px);box-shadow:var(--kk-shadow)}
.kk-card__media{display:block;background:var(--kk-glaze);aspect-ratio:4/3;overflow:hidden}
.kk-card__media img{width:100%;height:100%;object-fit:contain;padding:18px;transition:transform .25s}
.kk-card:hover .kk-card__media img{transform:scale(1.04)}
.kk-card__body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.kk-card__title{font-family:var(--kk-display);font-size:18px;font-weight:800;margin:0;color:var(--kk-ink);text-transform:uppercase;letter-spacing:.01em}
.kk-card__title a{color:inherit}
.kk-card__desc{margin:0;color:var(--kk-grey);font-size:14px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.kk-card__row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px}
.kk-price{font-family:var(--kk-display);font-size:20px;font-weight:800;color:var(--kk-green)}

/* PROMO sidebar */
.kk-promo{background:var(--kk-green);color:#fff;padding:24px;border-radius:var(--kk-radius);text-align:center}
.kk-promo h2{font-family:var(--kk-display);text-transform:uppercase;margin:0 0 8px}
.kk-promo p{margin:0 0 16px;opacity:.92}

/* BUTTONS */
.kk-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:999px;padding:11px 22px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:14px;cursor:pointer;text-decoration:none;transition:background .15s,transform .15s,color .15s}
.kk-btn:hover{text-decoration:none}
.kk-btn--primary{background:var(--kk-red);color:#fff}
.kk-btn--primary:hover{background:var(--kk-red-hover)}
.kk-btn--secondary{background:var(--kk-green);color:#fff}
.kk-btn--secondary:hover{background:var(--kk-green-2)}
.kk-btn--ghost{background:transparent;color:#fff;border:2px solid #fff}
.kk-btn--ghost:hover{background:#fff;color:var(--kk-green)}
.kk-btn--lg{padding:14px 28px;font-size:15px}
.kk-btn:disabled{opacity:.5;cursor:not-allowed}

/* FLASH */
.kk-flash{position:fixed;top:80px;right:16px;background:#fff;border:1px solid var(--kk-line);box-shadow:var(--kk-shadow);padding:14px 18px;border-radius:var(--kk-radius);max-width:340px;z-index:60;display:flex;gap:10px;align-items:center;font-weight:600}
.kk-flash::before{content:"✓";width:22px;height:22px;border-radius:50%;background:var(--kk-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900}

/* PRODUCT DETAIL */
.kk-product{display:grid;grid-template-columns:1fr 1fr;gap:36px;background:#fff;border-radius:var(--kk-radius);padding:28px;box-shadow:var(--kk-shadow-sm)}
.kk-product__hero{background:var(--kk-glaze);border-radius:var(--kk-radius-sm);padding:24px;display:flex;align-items:center;justify-content:center}
.kk-product__hero img{max-height:380px;object-fit:contain}
.kk-product__sku{color:var(--kk-grey);font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin:0}
.kk-product__title{font-family:var(--kk-display);font-size:34px;text-transform:uppercase;margin:6px 0 10px}
.kk-product__price{font-family:var(--kk-display);font-size:26px;color:var(--kk-red);margin:0 0 12px;font-weight:800}
.kk-product__desc{color:var(--kk-grey);font-size:16px;margin:0 0 20px}
.kk-product__features{padding-left:18px;color:var(--kk-grey)}
.kk-breadcrumb{margin:0 0 16px;color:var(--kk-grey);font-size:14px}
.kk-breadcrumb a{color:var(--kk-grey)}
.kk-breadcrumb span[aria-hidden]{margin:0 6px}

/* QTY */
.kk-qty{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.kk-qty__group{display:inline-flex;align-items:center;border:1px solid var(--kk-line);border-radius:999px;overflow:hidden}
.kk-qty__group button{background:#fff;border:none;width:36px;height:36px;font-size:20px;color:var(--kk-green);font-weight:900}
.kk-qty__group input{border:none;width:50px;text-align:center;font-size:16px;font-weight:700;-moz-appearance:textfield}
.kk-qty__group input::-webkit-outer-spin-button,.kk-qty__group input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

@media(max-width:760px){
  .kk-product{grid-template-columns:1fr}
}

/* CART */
.kk-cart-grid{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
.kk-cart-list{background:#fff;border-radius:var(--kk-radius);box-shadow:var(--kk-shadow-sm);overflow:hidden}
.kk-line{display:grid;grid-template-columns:100px 1fr 120px;gap:16px;padding:18px;border-bottom:1px solid var(--kk-line);align-items:center}
.kk-line:last-child{border-bottom:none}
.kk-line__media{background:var(--kk-glaze);border-radius:var(--kk-radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6px}
.kk-line__title{font-family:var(--kk-display);font-size:16px;text-transform:uppercase;margin:0 0 4px}
.kk-line__title a{color:var(--kk-ink)}
.kk-line__category{color:var(--kk-grey);font-size:13px;margin:0 0 12px;text-transform:uppercase;letter-spacing:.06em}
.kk-line__remove{background:none;border:none;color:var(--kk-red);font-weight:700;text-transform:uppercase;font-size:12px;padding:0}
.kk-line__remove:hover{text-decoration:underline}
.kk-line__totals{text-align:right}
.kk-line__unit{color:var(--kk-grey);font-size:13px;margin:0}
.kk-line__total{font-family:var(--kk-display);font-size:18px;font-weight:800;margin:4px 0 0;color:var(--kk-ink)}

@media(max-width:880px){
  .kk-cart-grid{grid-template-columns:1fr}
  .kk-line{grid-template-columns:80px 1fr;grid-template-areas:"media body" "totals totals"}
  .kk-line__media{grid-area:media}
  .kk-line__body{grid-area:body}
  .kk-line__totals{grid-area:totals;text-align:left;padding-top:8px;border-top:1px dashed var(--kk-line)}
}

/* SUMMARY */
.kk-summary{background:#fff;border-radius:var(--kk-radius);padding:24px;box-shadow:var(--kk-shadow-sm);position:sticky;top:90px;display:flex;flex-direction:column;gap:12px}
.kk-summary h2{font-family:var(--kk-display);font-size:20px;text-transform:uppercase;margin:0 0 12px}
.kk-summary dl{display:grid;grid-template-columns:1fr auto;gap:8px 12px;margin:0}
.kk-summary dt{color:var(--kk-grey);font-size:14px}
.kk-summary dd{font-weight:700;color:var(--kk-ink);font-size:14px;margin:0;text-align:right}
.kk-summary__grand{font-family:var(--kk-display);font-size:18px !important;color:var(--kk-ink);font-weight:900;border-top:1px solid var(--kk-line);padding-top:10px;margin-top:6px}
.kk-summary__hint{color:var(--kk-grey);font-size:12px;margin:6px 0 0;line-height:1.45}
.kk-summary__handoff{background:var(--kk-warm);padding:10px 12px;border-radius:var(--kk-radius-sm);font-size:13px;color:var(--kk-ink);margin:0 0 6px}

/* CHECKOUT */
.kk-shell--checkout{max-width:1100px}
.kk-checkout-grid{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.kk-checkout-main{background:#fff;border-radius:var(--kk-radius);padding:28px;box-shadow:var(--kk-shadow-sm)}
.kk-checkout-main h2{font-family:var(--kk-display);text-transform:uppercase;margin:0 0 16px}
@media(max-width:880px){.kk-checkout-grid{grid-template-columns:1fr}}

/* STEPPER */
.kk-stepper{list-style:none;display:flex;gap:0;padding:0;margin:0 0 24px;flex-wrap:wrap}
.kk-stepper li{display:flex;align-items:center;gap:8px;color:var(--kk-grey);font-size:13px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;flex:1;min-width:160px;position:relative;padding:14px 8px;border-bottom:2px solid var(--kk-line)}
.kk-stepper li span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;background:var(--kk-line);color:var(--kk-grey);font-size:13px;font-weight:900}
.kk-stepper li.is-current{color:var(--kk-red);border-bottom-color:var(--kk-red)}
.kk-stepper li.is-current span{background:var(--kk-red);color:#fff}
.kk-stepper li.is-done{color:var(--kk-green);border-bottom-color:var(--kk-green)}
.kk-stepper li.is-done span{background:var(--kk-green);color:#fff}

/* FIELDS */
.kk-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.kk-field>span{font-weight:700;color:var(--kk-ink);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.kk-field input,.kk-field select,.kk-field textarea{border:1px solid var(--kk-line);border-radius:var(--kk-radius-sm);padding:12px 14px;font-size:15px;color:var(--kk-ink);background:#fff;width:100%;font-family:inherit}
.kk-field input:focus{outline:2px solid var(--kk-red);border-color:var(--kk-red)}
.kk-field.has-error input{border-color:var(--kk-red);background:#fff4f4}
.kk-fieldrow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.kk-fieldrow{grid-template-columns:1fr}}
.kk-formerror{background:#fff4f4;border:1px solid var(--kk-red);color:var(--kk-red);padding:10px 14px;border-radius:var(--kk-radius-sm);font-weight:700}

/* TABS */
.kk-tabs{display:flex;gap:8px;margin-bottom:18px;border-bottom:1px solid var(--kk-line)}
.kk-tab{background:none;border:none;padding:12px 18px;font-weight:800;text-transform:uppercase;color:var(--kk-grey);letter-spacing:.04em;font-size:14px;border-bottom:3px solid transparent}
.kk-tab.is-active{color:var(--kk-red);border-bottom-color:var(--kk-red)}

.kk-shops{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:8px}
.kk-shops__item{border:1px solid var(--kk-line);border-radius:var(--kk-radius-sm);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;transition:border .15s,background .15s}
.kk-shops__item:hover{border-color:var(--kk-green);background:var(--kk-warm)}
.kk-shops__item.is-selected{border-color:var(--kk-green);background:#eaf3ec}
.kk-shops__item h4{font-family:var(--kk-display);font-size:14px;text-transform:uppercase;margin:0 0 2px}
.kk-shops__item p{margin:0;font-size:12px;color:var(--kk-grey)}

.kk-delivery-status{margin:8px 0 0;font-size:14px;color:var(--kk-grey)}
.kk-delivery-status.is-ok{color:var(--kk-green)}
.kk-delivery-status.is-err{color:var(--kk-red)}

.kk-slot__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-top:8px}
.kk-slot__pill{cursor:pointer}
.kk-slot__pill input{position:absolute;opacity:0;pointer-events:none}
.kk-slot__pill span{display:block;text-align:center;border:1px solid var(--kk-line);border-radius:999px;padding:10px 0;font-weight:700;color:var(--kk-ink);font-size:14px}
.kk-slot__pill input:checked + span{background:var(--kk-green);color:#fff;border-color:var(--kk-green)}

/* REVIEW */
.kk-review-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:8px}
.kk-review-item{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;padding:8px 0;border-bottom:1px dashed var(--kk-line)}
.kk-review-item:last-child{border-bottom:none}
.kk-review-item img{border-radius:var(--kk-radius-sm);background:var(--kk-glaze)}
.kk-review-item h3{font-family:var(--kk-display);font-size:15px;text-transform:uppercase;margin:0 0 2px}
.kk-review-item p{margin:0;color:var(--kk-grey);font-size:13px}
.kk-review-item__total{margin:0;font-weight:800;font-family:var(--kk-display);font-size:16px}

/* FOOTER */
.kk-footer{background:var(--kk-ink);color:#cbd0c8;padding:48px 24px 24px;margin-top:60px}
.kk-footer__band{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px}
.kk-footer__col h4{text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 12px;font-size:14px;font-weight:800}
.kk-footer__col a{display:block;color:#cbd0c8;padding:4px 0;font-size:14px}
.kk-footer__col a:hover{color:#fff;text-decoration:underline}
.kk-footer__legal{max-width:1200px;margin:32px auto 0;border-top:1px solid #333;padding-top:18px;color:#888;font-size:12px}

/* EMPTY / OUTCOME */
.kk-empty{background:#fff;border-radius:var(--kk-radius);padding:48px;text-align:center;box-shadow:var(--kk-shadow-sm);display:flex;flex-direction:column;align-items:center;gap:16px}
.kk-empty h2{font-family:var(--kk-display);text-transform:uppercase;margin:0}
.kk-empty p{margin:0;color:var(--kk-grey)}
.kk-outcome{background:#fff;border-radius:var(--kk-radius);padding:48px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:var(--kk-shadow-sm)}
.kk-outcome h1{font-family:var(--kk-display);text-transform:uppercase;margin:0;font-size:32px;color:var(--kk-green)}
.kk-outcome--fail h1{color:var(--kk-red)}

/* LOCATOR MODAL */
.kk-locator-modal{border:none;border-radius:var(--kk-radius);box-shadow:var(--kk-shadow);padding:0;max-width:480px;width:calc(100% - 32px)}
.kk-locator-modal::backdrop{background:rgba(0,0,0,.45)}
.kk-locator-modal__form{padding:24px}
.kk-locator-modal__form header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.kk-locator-modal__form h2{font-family:var(--kk-display);text-transform:uppercase;margin:0}
.kk-locator-modal__close{background:none;border:none;font-size:24px;color:var(--kk-grey)}
.kk-locator-modal__results{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}
.kk-link{color:var(--kk-green);font-weight:700;text-transform:uppercase;font-size:13px}

/* HOMEPAGE */
.kk-home-hero{background:linear-gradient(135deg,#006442 0%,#003d29 100%);color:#fff;padding:64px 24px;text-align:left;position:relative;overflow:hidden}
.kk-home-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:480px;height:480px;background:radial-gradient(circle,#E62127 0%,transparent 60%);opacity:0.25}
.kk-home-hero__wrap{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.kk-home-hero__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:800;color:#ffd400}
.kk-home-hero__title{font-family:var(--kk-display);font-size:clamp(40px,7vw,72px);font-weight:900;margin:10px 0 18px;text-transform:uppercase;line-height:1.05}
.kk-home-hero__tagline{margin:0 0 28px;font-size:18px;max-width:60ch;opacity:.92}
.kk-home-hero__cta{display:flex;gap:12px;flex-wrap:wrap}

.kk-home-strip{background:#fff;border-bottom:1px solid var(--kk-line)}
.kk-home-strip__wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;padding:20px 24px}
.kk-home-strip__item{background:var(--kk-warm);padding:18px 20px;border-radius:var(--kk-radius);display:flex;flex-direction:column;gap:4px}
.kk-home-strip__item b{font-family:var(--kk-display);text-transform:uppercase;color:var(--kk-green);font-size:15px;letter-spacing:.04em}
.kk-home-strip__item span{font-size:13px;color:var(--kk-grey)}

.kk-home-block{max-width:1200px;margin:32px auto;padding:0 24px}
.kk-home-block__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}
.kk-home-block__head h2{font-family:var(--kk-display);text-transform:uppercase;margin:0;font-size:28px}
.kk-home-block--dozens{background:#fff;padding:32px 24px;border-radius:var(--kk-radius);box-shadow:var(--kk-shadow-sm);max-width:1152px}

.kk-home-cta{max-width:1100px;margin:48px auto 16px;padding:36px 28px;background:var(--kk-red);color:#fff;border-radius:var(--kk-radius);text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.kk-home-cta h2{font-family:var(--kk-display);text-transform:uppercase;margin:0;font-size:30px}
.kk-home-cta p{margin:0;max-width:60ch}
.kk-home-cta .kk-btn{background:#fff;color:var(--kk-red)}
.kk-home-cta .kk-btn:hover{background:var(--kk-warm)}
