/* kiosk.vek.dk — base styles (scaffold). Kiosk is a touch/self-service UI,
   so defaults lean large-tap-target; refine when functionality lands. */

:root {
    --kiosk-accent: #198754;
    --kiosk-ink: #222;
}

body {
    font-family: 'Rubik', system-ui, sans-serif;
    color: var(--kiosk-ink);
}

.kiosk-header {
    border-bottom: 1px solid #e6e6e6;
    background: #fff;
}

.kiosk-brand {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--kiosk-accent);
}

.kiosk-footer {
    border-top: 1px solid #e6e6e6;
    margin-top: 2rem;
}

.kiosk-placeholder-dl {
    max-width: 360px;
}

/* ── Welcome ───────────────────────────────────────────────── */
.kiosk-welcome {
    max-width: 1100px;
    margin: 0 auto;
    padding: 2rem 1rem 4rem;
    text-align: center;
}
.kiosk-welcome-title { font-size: 3rem; font-weight: 700; margin-bottom: 1rem; }
.kiosk-welcome-text  { font-size: 1.5rem; line-height: 1.5; color: #444; max-width: 760px; margin: 0 auto 2.5rem; }

.kiosk-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 1rem;
}
.kiosk-action {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 1rem;
    min-height: 240px;
    border: 3px solid var(--kiosk-accent);
    border-radius: 1.25rem;
    background: #fff;
    color: var(--kiosk-ink);
    text-decoration: none;
    font-weight: 600;
    cursor: pointer;
    transition: transform .05s ease, background .15s ease;
}
.kiosk-action:active { transform: scale(.98); }
.kiosk-action-pay { background: var(--kiosk-accent); color: #fff; }
.kiosk-action-icon  { font-size: 4rem; line-height: 1; }
.kiosk-action-label { font-size: 1.75rem; }

.kiosk-foot {
    display: flex; align-items: center; justify-content: center; gap: 1rem;
    margin-top: 2.5rem;
}
.kiosk-loc-badge {
    font-size: 1rem; color: #555; background: #f0f0f0;
    padding: .35rem .9rem; border-radius: 999px;
}
.kiosk-loc-badge-unset { background: #fde2e1; color: #b02a37; }
.kiosk-gear { font-size: 1.5rem; text-decoration: none; color: #aaa; }
.kiosk-gear:hover { color: #555; }

/* Floating instream attract panel */
.kiosk-instream {
    position: fixed; top: 12px; right: 12px;
    width: 16vw; min-width: 200px; aspect-ratio: 16/10;
    border-radius: .75rem; overflow: hidden;
    box-shadow: 0 4px 18px rgba(0,0,0,.15);
    z-index: 10; background: #000;
}
.kiosk-instream iframe { width: 100%; height: 100%; border: 0; display: block; }

/* ── Generic screen ────────────────────────────────────────── */
.kiosk-screen { max-width: 900px; margin: 0 auto; padding: 4rem 1rem; }
.kiosk-h1   { font-size: 2.5rem; font-weight: 700; }
.kiosk-lead { font-size: 1.4rem; }

/* ── Setup + keypad ────────────────────────────────────────── */
.kiosk-setup { max-width: 560px; margin: 0 auto; padding: 2.5rem 1rem; text-align: center; }
.kiosk-setup-title { font-size: 2.25rem; font-weight: 700; margin-bottom: 1rem; }
.kiosk-setup-lead  { font-size: 1.25rem; color: #444; margin-bottom: 1.5rem; }
.kiosk-setup-alert { font-size: 1.1rem; }
.kiosk-setup-back  { display: inline-block; margin-top: 2rem; font-size: 1.1rem; color: #777; text-decoration: none; }

.kiosk-pin-display {
    width: 100%; max-width: 320px; margin: 0 auto 1.25rem; display: block;
    font-size: 2.5rem; text-align: center; letter-spacing: .5rem;
    border: 2px solid #ccc; border-radius: .5rem; padding: .5rem;
}
.kiosk-keypad {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem;
    max-width: 320px; margin: 0 auto;
}
.kiosk-key {
    font-size: 1.75rem; font-weight: 600; padding: 1rem 0;
    border: 2px solid #ddd; border-radius: .5rem; background: #fff; cursor: pointer;
}
.kiosk-key:active { background: #eee; }
.kiosk-key-ok    { background: var(--kiosk-accent); color: #fff; border-color: var(--kiosk-accent); }
.kiosk-key-clear { background: #f5f5f5; }

.kiosk-loc-grid { display: grid; gap: 1rem; max-width: 480px; margin: 0 auto; }
.kiosk-loc-btn {
    font-size: 1.5rem; font-weight: 600; padding: 1.5rem;
    border: 3px solid var(--kiosk-accent); border-radius: 1rem;
    background: #fff; color: var(--kiosk-ink); cursor: pointer;
}
.kiosk-loc-btn:active { background: #eef7f1; }

@media (max-width: 720px) {
    .kiosk-actions { grid-template-columns: 1fr; }
    .kiosk-instream { display: none; }
}

/* ── Søg varer (search + browse) ───────────────────────────── */
.kiosk-sog { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1rem 4rem; }
.kiosk-sog-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.kiosk-back {
    flex: 0 0 auto; width: 64px; height: 64px; border-radius: .75rem;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; text-decoration: none; color: var(--kiosk-ink);
    border: 2px solid #ddd; background: #fff;
}
.kiosk-sog-title { font-size: 1.75rem; font-weight: 700; margin-bottom: 1.25rem; }
.kiosk-subhead { font-size: 1.25rem; font-weight: 600; margin: 1rem 0; }
.kiosk-empty { font-size: 1.25rem; color: #777; padding: 2rem 0; }

.kiosk-searchbar { display: flex; flex: 1 1 auto; gap: .75rem; }
.kiosk-search-input {
    flex: 1 1 auto; font-size: 1.5rem; padding: .85rem 1.25rem;
    border: 2px solid #ccc; border-radius: .75rem;
}
.kiosk-search-btn {
    font-size: 1.4rem; font-weight: 600; padding: 0 2rem;
    border: 0; border-radius: .75rem; background: var(--kiosk-accent); color: #fff; cursor: pointer;
}

/* Category cards */
.kiosk-cat-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem;
}
.kiosk-cat-card {
    display: flex; flex-direction: column; align-items: center; gap: .75rem;
    padding: 1.25rem 1rem; border: 2px solid #e2e2e2; border-radius: 1rem;
    background: #fff; color: var(--kiosk-ink); text-decoration: none; text-align: center;
}
.kiosk-cat-card:active { background: #f3f7f4; }
.kiosk-cat-img { width: 110px; height: 110px; display: flex; align-items: center; justify-content: center; }
.kiosk-cat-img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.kiosk-cat-img-placeholder { font-size: 3rem; }
.kiosk-cat-name { font-size: 1.15rem; font-weight: 600; }

/* Product grid */
.kiosk-prod-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem;
}
.kiosk-prod-card {                 /* the Ajxform wrapper = the visual card */
    margin: 0; border: 2px solid #e2e2e2; border-radius: 1rem; background: #fff; overflow: hidden;
}
.kiosk-prod-card:active { background: #f3f7f4; }
.kiosk-prod-card-btn {             /* the actual tap target fills the card */
    display: flex; flex-direction: column; gap: .5rem; width: 100%; padding: 1rem;
    border: 0; background: none; text-align: left; cursor: pointer;
}
.kiosk-prod-img { width: 100%; aspect-ratio: 1/1; display: flex; align-items: center; justify-content: center; }
.kiosk-prod-img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.kiosk-prod-img-placeholder { font-size: 3rem; color: #bbb; }
.kiosk-prod-name { font-size: 1.05rem; font-weight: 500; line-height: 1.25; min-height: 2.6em; }
.kiosk-prod-loc  { font-size: .95rem; color: #2057b6; font-weight: 600; }
.kiosk-prod-price { font-size: 1.35rem; font-weight: 700; color: var(--kiosk-accent); margin-top: auto; }

/* Product modal (XL) */
.kiosk-modal-header { align-items: flex-start; }
.kiosk-modal-title { font-size: 1.6rem; font-weight: 700; }
.btn-close-lg { transform: scale(1.6); margin: .5rem; }
.kiosk-modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.kiosk-modal-img { display: flex; align-items: center; justify-content: center; min-height: 280px; }
.kiosk-modal-img img { max-width: 100%; max-height: 360px; object-fit: contain; }
.kiosk-modal-price { font-size: 2.25rem; font-weight: 800; color: var(--kiosk-accent); margin-bottom: 1rem; }
.kiosk-modal-meta { display: grid; grid-template-columns: max-content 1fr; column-gap: 1rem; row-gap: .35rem; font-size: 1.1rem; }
.kiosk-modal-meta dt { color: #777; font-weight: 500; }
.kiosk-modal-meta dd { margin: 0; font-weight: 600; }
.kiosk-modal-loc { color: #2057b6; }
.kiosk-modal-desc { margin-top: 1rem; font-size: 1.05rem; color: #444; }
.kiosk-modal-foot { margin-top: 1.5rem; text-align: right; }
@media (max-width: 720px) { .kiosk-modal-grid { grid-template-columns: 1fr; } }

/* ── Scan screen ───────────────────────────────────────────── */
.kiosk-scan { max-width: 900px; margin: 0 auto; padding: 1.5rem 1rem 4rem; }
.kiosk-scan-title { font-size: 1.9rem; font-weight: 700; margin: 0; }
.kiosk-scanbar { margin: 1rem 0 1.5rem; }
.kiosk-scan-input {
    width: 100%; font-size: 1.6rem; padding: 1rem 1.25rem;
    border: 3px solid var(--kiosk-accent); border-radius: .75rem; text-align: center;
}

/* Cart */
.kiosk-cart-box { border: 2px solid #e2e2e2; border-radius: 1rem; background: #fff; overflow: hidden; }
.kiosk-cart-head { display: flex; align-items: baseline; justify-content: space-between; padding: 1rem 1.25rem; border-bottom: 1px solid #eee; }
.kiosk-cart-title { font-size: 1.4rem; font-weight: 700; margin: 0; }
.kiosk-cart-count { color: #777; font-size: 1.05rem; }
.kiosk-cart-empty { padding: 2rem 1.25rem; color: #888; font-size: 1.15rem; text-align: center; }
.kiosk-cart-list { list-style: none; margin: 0; padding: 0; }
.kiosk-cart-row { display: flex; align-items: center; gap: 1rem; padding: .85rem 1.25rem; border-bottom: 1px solid #f0f0f0; }
.kiosk-cart-thumb { flex: 0 0 56px; width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.kiosk-cart-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.kiosk-cart-main { flex: 1 1 auto; min-width: 0; }
.kiosk-cart-name { font-size: 1.1rem; font-weight: 600; }
.kiosk-cart-sub { font-size: .95rem; color: #777; }
.kiosk-cart-line { font-size: 1.15rem; font-weight: 700; white-space: nowrap; }
.kiosk-cart-delform { flex: 0 0 auto; margin: 0; }
.kiosk-cart-del {
    width: 44px; height: 44px; border-radius: .5rem; border: 1px solid #e2b6b6;
    background: #fff; color: #b02a37; font-size: 1.2rem; cursor: pointer;
}
.kiosk-cart-foot { padding: 1.25rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.kiosk-cart-total { font-size: 1.4rem; font-weight: 700; display: flex; gap: 1rem; align-items: baseline; }
.kiosk-cart-total-amt { color: var(--kiosk-accent); }
.kiosk-pay-btn {
    font-size: 1.4rem; font-weight: 700; padding: 1rem 2rem; border-radius: .75rem;
    background: var(--kiosk-accent); color: #fff; text-decoration: none;
}
.kiosk-pay-btn.is-disabled { background: #ccc; pointer-events: none; }

/* Scan modal qty keypad + actions */
.kiosk-qty-label { display: block; font-size: 1.05rem; color: #555; margin-top: 1rem; }
.kiosk-qty-display { width: 140px; font-size: 2rem; text-align: center; border: 2px solid #ccc; border-radius: .5rem; padding: .35rem; margin: .35rem 0 .75rem; }
.kiosk-keypad-qty { max-width: 240px; margin: 0; }
.kiosk-scan-actions { display: flex; gap: .75rem; flex-wrap: wrap; justify-content: flex-end; }
.kiosk-btn-add, .kiosk-btn-pay {
    font-size: 1.25rem; font-weight: 700; padding: .9rem 1.5rem; border-radius: .75rem; border: 0; cursor: pointer;
}
.kiosk-btn-add { background: #e8f3ec; color: #176c43; border: 2px solid var(--kiosk-accent); }
.kiosk-btn-pay { background: var(--kiosk-accent); color: #fff; }
.kiosk-btn-add:disabled, .kiosk-btn-pay:disabled { opacity: .5; }

/* ── Betaling ──────────────────────────────────────────────── */
.kiosk-betaling { max-width: 760px; margin: 0 auto; padding: 1.5rem 1rem 4rem; }
.kiosk-betaling-total { display: flex; justify-content: space-between; align-items: baseline; font-size: 1.6rem; font-weight: 700; margin-top: 1rem; }
.kiosk-betaling-pick { font-size: 1.25rem; margin-top: 2rem; }
.kiosk-betaling-hint { margin-top: 1rem; }
.kiosk-pay-methods { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: .5rem; }
.kiosk-paymethod { margin: 0; }
.kiosk-paymethod-btn {
    width: 100%; min-height: 200px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem;
    border: 3px solid var(--kiosk-accent); border-radius: 1.25rem; background: #fff; cursor: pointer; font-weight: 700;
}
.kiosk-paymethod-mobilepay .kiosk-paymethod-btn { background: var(--kiosk-accent); color: #fff; }
.kiosk-paymethod-icon  { font-size: 4rem; line-height: 1; }
.kiosk-paymethod-label { font-size: 1.75rem; }

/* ── Return / receipt ──────────────────────────────────────── */
.kiosk-return { max-width: 640px; margin: 0 auto; padding: 1.5rem 1rem 4rem; }
.kiosk-return-check { font-size: 4rem; color: #198754; line-height: 1; }
.kiosk-return-txn { font-size: 1rem; color: #777; margin-top: .25rem; }
.kiosk-return-list { list-style: none; margin: 1.5rem 0; padding: 0; border-top: 1px solid #eee; }
.kiosk-return-list li { display: flex; justify-content: space-between; padding: .6rem 0; border-bottom: 1px solid #f0f0f0; font-size: 1.1rem; }
.kiosk-return-email { margin-top: 2rem; text-align: center; }
.kiosk-email-form { display: flex; gap: .75rem; max-width: 480px; margin: 1rem auto 0; }
.kiosk-email-input { flex: 1 1 auto; font-size: 1.4rem; padding: .85rem 1rem; border: 2px solid #ccc; border-radius: .75rem; }
.kiosk-email-btn { font-size: 1.2rem; font-weight: 700; padding: 0 1.5rem; border: 0; border-radius: .75rem; background: var(--kiosk-accent); color: #fff; cursor: pointer; }
