/* ============================================================
   MASTERY.NG - Checkout (enterprise design system)
   ============================================================ */
.checkout-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--mist);font-family:var(--font-body)}

/* HEAD */
.checkout-head{padding:14px 0;border-bottom:1px solid var(--line);background:var(--paper)}
.checkout-head .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.checkout-head .meta{font-size:12.5px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.checkout-head .meta svg{color:var(--success)}

/* PROGRESS STEPS */
.checkout-steps{display:flex;align-items:center;justify-content:center;gap:8px;padding:18px 16px 0;font-size:12.5px;color:var(--muted);max-width:920px;margin:0 auto;flex-wrap:wrap}
.checkout-steps .step{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--paper);border:1px solid var(--line);border-radius:99px}
.checkout-steps .step.is-current{background:var(--teal);color:#fff;border-color:var(--teal);font-weight:600}
.checkout-steps .step.is-done{background:var(--teal-soft);color:var(--teal);border-color:var(--teal);font-weight:600}
.checkout-steps .step .n{width:18px;height:18px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.25);font-size:10.5px;font-weight:700}
.checkout-steps .step.is-current .n{background:rgba(255,255,255,.3)}
.checkout-steps .step.is-done .n{background:var(--teal);color:#fff}
.checkout-steps .sep{color:var(--line);font-size:14px}

/* MAIN */
.checkout-main{flex:1;padding:24px 16px 60px}
.checkout-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;max-width:1100px;margin:0 auto;align-items:start}
@media (max-width:920px){.checkout-grid{grid-template-columns:minmax(0,1fr)}}
.checkout-main-col{min-width:0;display:grid;gap:16px}
.checkout-side-col{min-width:0}

/* CARDS */
.checkout-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:22px}
.checkout-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.checkout-card h1{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.014em;margin:0;color:var(--ink)}
.checkout-card h2{font-family:var(--font-display);font-size:17px;font-weight:700;margin:0;color:var(--ink)}
.checkout-card h3{font-family:var(--font-display);font-size:15px;font-weight:700;margin:0;color:var(--ink)}
.checkout-card .sub{font-size:13.5px;color:var(--muted);margin:4px 0 0;line-height:1.55}
.checkout-card.is-narrow{max-width:560px;margin:0 auto}

/* CART LINE */
.checkout-items{display:grid;gap:10px}
.checkout-item{display:grid;grid-template-columns:64px minmax(0,1fr) auto;gap:14px;align-items:center;padding:12px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m)}
.checkout-item-cover{width:64px;height:64px;border-radius:var(--radius-s);background:var(--mist);display:grid;place-items:center;overflow:hidden;flex-shrink:0;border:1px solid var(--line)}
.checkout-item-cover img{width:100%;height:100%;object-fit:cover}
.checkout-item-cover .emoji{font-size:26px}
.checkout-item-info{min-width:0;display:grid;gap:4px}
.checkout-item-title{font-weight:600;color:var(--ink);font-size:14.5px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}
.checkout-item-title a{color:inherit;text-decoration:none}
.checkout-item-title a:hover{color:var(--teal)}
.checkout-item-tags{display:flex;flex-wrap:wrap;gap:5px;font-size:11px}
.checkout-item-tag{padding:2px 8px;border-radius:99px;background:var(--teal-soft);color:var(--teal);border:1px solid var(--teal);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:10px}
.checkout-item-tag.is-bundle{background:var(--gold-soft);color:#8A6E12;border-color:var(--gold)}
.checkout-item-actions{display:grid;gap:6px;justify-items:end}
.checkout-item-price{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;font-size:14.5px}
.checkout-item-price .each{display:block;font-size:11px;color:var(--muted);font-weight:500;margin-top:1px}

/* QTY STEPPER */
.checkout-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--radius-s);overflow:hidden;background:var(--paper)}
.checkout-qty button{width:26px;height:26px;border:0;background:none;cursor:pointer;color:var(--ink);font-weight:700;font-family:inherit;font-size:13px}
.checkout-qty button:hover{background:var(--mist);color:var(--teal)}
.checkout-qty button:disabled{color:var(--line);cursor:not-allowed}
.checkout-qty .val{padding:0 8px;font-weight:700;font-size:12.5px;font-variant-numeric:tabular-nums;color:var(--ink);min-width:22px;text-align:center}
.checkout-item-remove{background:none;border:0;color:var(--muted);cursor:pointer;font-size:11px;font-family:inherit;padding:2px 6px;border-radius:4px}
.checkout-item-remove:hover{color:var(--danger);background:var(--danger-soft)}

/* FORM */
.checkout-form{display:grid;gap:14px}
.checkout-field{display:grid;gap:6px}
.checkout-field label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.checkout-field input,.checkout-field select,.checkout-field textarea{padding:11px 14px;border:1.5px solid var(--line);border-radius:var(--radius-s);font-family:inherit;font-size:15px;background:var(--paper);color:var(--ink)}
.checkout-field input:focus,.checkout-field select:focus,.checkout-field textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.checkout-field input[readonly]{background:var(--mist);cursor:not-allowed;color:var(--muted)}
.checkout-field .hint{font-size:12.5px;color:var(--muted);line-height:1.5}
.checkout-field .hint a{color:var(--teal);font-weight:600}
.checkout-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){.checkout-field-row{grid-template-columns:1fr}}

/* COUPON */
.checkout-coupon{display:grid;gap:8px}
.checkout-coupon-form{display:flex;gap:6px}
.checkout-coupon-form input{flex:1;min-width:0;padding:10px 12px;border:1.5px solid var(--line);border-radius:var(--radius-s);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;background:var(--paper);text-transform:uppercase}
.checkout-coupon-form input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.checkout-coupon-form button{flex-shrink:0;padding:10px 16px;border:1px solid var(--teal);background:var(--paper);color:var(--teal);font-weight:700;font-size:13px;border-radius:var(--radius-s);cursor:pointer;font-family:inherit;letter-spacing:.04em}
.checkout-coupon-form button:hover{background:var(--teal);color:#fff}
.checkout-coupon-msg{font-size:12.5px;line-height:1.5;color:var(--muted)}
.checkout-coupon-msg.is-error{color:var(--danger)}
.checkout-coupon-msg.is-success{color:var(--success);font-weight:600}
.checkout-coupon-applied{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--success-soft);border:1px solid var(--success);border-radius:var(--radius-s);font-size:13px;color:var(--success);font-weight:600}
.checkout-coupon-applied .label{flex:1}
.checkout-coupon-applied code{background:var(--paper);padding:1px 8px;border-radius:4px;border:1px solid var(--success);font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--success);margin:0 4px}
.checkout-coupon-applied .remove{background:none;border:0;color:var(--success);cursor:pointer;font-size:13px;font-weight:600;text-decoration:underline;padding:0;font-family:inherit}

/* SUMMARY (sticky right column) */
.checkout-summary{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:20px;position:sticky;top:24px;display:grid;gap:14px}
@media (max-width:920px){.checkout-summary{position:static;top:auto}}
.checkout-summary-head{padding-bottom:12px;border-bottom:1px solid var(--line)}
.checkout-summary-head h2{font-family:var(--font-display);font-size:16px;font-weight:700;margin:0;color:var(--ink)}
.checkout-summary-head .meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.checkout-summary-lines{display:grid;gap:8px;max-height:240px;overflow-y:auto;padding-right:4px}
.checkout-summary-lines::-webkit-scrollbar{width:4px}
.checkout-summary-lines::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}
.checkout-summary-line{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;font-size:13px}
.checkout-summary-line .nm{color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}
.checkout-summary-line .nm .qty{font-size:11px;color:var(--muted);margin-left:4px;font-weight:400}
.checkout-summary-line .nm .kind{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;display:block;margin-top:2px;font-weight:600}
.checkout-summary-line .price{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;font-size:13px}
.checkout-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:4px 0}
.checkout-summary-row .lbl{color:var(--muted)}
.checkout-summary-row .val{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.checkout-summary-row.is-discount .val{color:var(--success)}
.checkout-summary-divider{height:1px;background:var(--line);margin:4px 0}
.checkout-summary-total{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--ink);padding-top:6px;border-top:1px solid var(--line)}
.checkout-summary-total .val{font-variant-numeric:tabular-nums}
.checkout-summary-cta{display:block;width:100%;background:var(--teal);color:#fff;border:0;padding:14px;border-radius:var(--radius-s);font-weight:700;font-size:14.5px;cursor:pointer;font-family:inherit;text-decoration:none;text-align:center;transition:background .15s}
.checkout-summary-cta:hover{background:var(--teal-dark);color:#fff}
.checkout-summary-cta.is-gold{background:var(--gold);color:var(--ink)}
.checkout-summary-cta.is-gold:hover{background:#B8921F}
.checkout-summary-cta:disabled{background:var(--line);color:var(--muted);cursor:not-allowed}
.checkout-summary-edit{display:block;text-align:center;font-size:12px;color:var(--muted);text-decoration:none}
.checkout-summary-edit:hover{color:var(--teal)}

/* TRUST */
.checkout-trust{display:grid;gap:8px;padding-top:10px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.checkout-trust-item{display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.checkout-trust-item svg{flex-shrink:0;color:var(--success);margin-top:1px}
.checkout-trust-item strong{color:var(--ink);font-weight:600}

/* ORDER BUMP */
.checkout-bump{display:block;border:2px dashed var(--gold);background:var(--gold-soft);padding:14px 16px;border-radius:var(--radius-m);cursor:pointer;transition:background .15s}
.checkout-bump:hover{background:#FAF0D5}
.checkout-bump-row{display:flex;gap:12px;align-items:flex-start}
.checkout-bump input[type="checkbox"]{margin-top:3px;width:18px;height:18px;accent-color:var(--gold);cursor:pointer;flex-shrink:0}
.checkout-bump-text{flex:1;min-width:0}
.checkout-bump-text strong{display:block;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14px;margin-bottom:4px}
.checkout-bump-text p{margin:0 0 6px;font-size:13px;color:var(--ink);line-height:1.5}
.checkout-bump-text .price{font-size:13px;font-weight:700;color:#8A6E12;background:var(--paper);padding:3px 10px;border-radius:99px;border:1px solid var(--gold);display:inline-block}

/* CROSS-SELL ON CART */
.checkout-recommend{margin-top:8px}
.checkout-recommend h2{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);margin:0 0 10px}
.checkout-recommend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.checkout-recommend-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:12px;display:grid;gap:6px;text-decoration:none;color:inherit;transition:border-color .15s}
.checkout-recommend-card:hover{border-color:var(--teal)}
.checkout-recommend-card .tag{font-size:10px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.06em}
.checkout-recommend-card .title{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}
.checkout-recommend-card .price{font-weight:700;font-size:13px;color:var(--teal);font-variant-numeric:tabular-nums}

/* AUTH STRIP */
.checkout-auth-strip{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--teal-soft);border:1px solid var(--teal);border-radius:var(--radius-s);font-size:13px;color:var(--ink);line-height:1.5}
.checkout-auth-strip svg{flex-shrink:0;color:var(--teal)}
.checkout-auth-strip a{color:var(--teal);font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* EMPTY STATE */
.checkout-empty{text-align:center;padding:60px 20px;display:grid;gap:14px;justify-items:center}
.checkout-empty .icon{width:72px;height:72px;border-radius:50%;background:var(--mist);display:grid;place-items:center;color:var(--muted);font-size:32px}
.checkout-empty h1{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--ink);margin:0}
.checkout-empty p{font-size:14.5px;color:var(--muted);margin:0;max-width:420px;line-height:1.55}

/* FLASH MESSAGES */
.checkout-flash{padding:12px 16px;border-radius:var(--radius-s);font-size:14px;margin-bottom:14px;display:flex;gap:10px;align-items:flex-start}
.checkout-flash.success{background:var(--success-soft);border:1px solid var(--success);color:var(--success)}
.checkout-flash.error{background:var(--danger-soft);border:1px solid var(--danger);color:var(--danger)}

/* SUCCESS PAGE */
.checkout-success{display:grid;gap:18px;text-align:center}
.checkout-success-icon{width:80px;height:80px;border-radius:50%;background:var(--success-soft);color:var(--success);display:grid;place-items:center;margin:0 auto;border:3px solid var(--success)}
.checkout-success h1{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--ink);margin:0;letter-spacing:-.02em}
.checkout-success .ref{display:inline-flex;align-items:center;gap:8px;background:var(--mist);padding:6px 12px;border-radius:99px;font-size:12.5px;color:var(--muted);margin:0 auto;border:1px solid var(--line)}
.checkout-success .ref code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--ink);background:var(--paper);padding:1px 6px;border-radius:4px;border:1px solid var(--line);user-select:all}
.checkout-success p.summary{font-size:15px;color:var(--ink);max-width:520px;margin:0 auto;line-height:1.6}
.checkout-success p.summary b{color:var(--teal)}
.checkout-success-actions{display:grid;gap:10px;max-width:380px;margin:0 auto;width:100%}
.checkout-success-actions .btn{padding:13px 16px;font-size:14.5px;font-weight:700;display:block;text-align:center}
.checkout-success-next{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:24px;text-align:left}
.checkout-success-next-card{padding:18px 20px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);display:grid;gap:6px}
.checkout-success-next-card .ico{width:36px;height:36px;border-radius:50%;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;margin-bottom:4px}
.checkout-success-next-card h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);margin:0}
.checkout-success-next-card p{font-size:13px;color:var(--muted);margin:0;line-height:1.5}
.checkout-success-next-card a{color:var(--teal);font-weight:600;font-size:13px;text-decoration:none;margin-top:4px;display:inline-flex;align-items:center;gap:4px}
.checkout-success-files{display:grid;gap:8px;margin-top:20px;text-align:left;background:var(--mist);border-radius:var(--radius-l);padding:18px 20px;border:1px solid var(--line)}
.checkout-success-files h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);margin:0 0 4px}
.checkout-success-files-list{display:grid;gap:6px}
.checkout-success-file{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);padding:10px 12px;border-radius:var(--radius-s);font-size:13.5px;text-decoration:none;color:var(--ink)}
.checkout-success-file:hover{border-color:var(--teal);color:var(--teal)}
.checkout-success-file .ext{font-size:10.5px;font-weight:700;background:var(--teal-soft);color:var(--teal);border:1px solid var(--teal);padding:2px 8px;border-radius:6px;letter-spacing:.04em}
.checkout-success-file .lbl{flex:1;font-weight:600}
.checkout-success-file .size{font-size:12px;color:var(--muted)}

.success-icon{width:64px;height:64px;border-radius:50%;background:var(--success-soft);color:var(--success);display:grid;place-items:center;margin:0 auto 16px}

/* ---------- Course player ---------- */
.player-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--mist)}
.player-head{padding:12px 18px;border-bottom:1px solid var(--line);background:var(--paper);display:flex;align-items:center;justify-content:space-between;gap:14px}
.player-head .exit{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:6px}
.player-head .exit:hover{color:var(--teal)}
.player-layout{flex:1;display:grid;grid-template-columns:1fr 360px;gap:18px;padding:18px;max-width:1400px;width:100%;margin:0 auto}
@media (max-width:980px){.player-layout{grid-template-columns:1fr}}
.player-stage{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden}
.player-video{aspect-ratio:16/9;background:var(--ink);position:relative;display:grid;place-items:center;color:#fff}
.player-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.player-video .lock-overlay{text-align:center;padding:24px}
.player-video .lock-overlay svg{margin:0 auto 12px;color:#fff}
.player-notes{padding:24px}
.player-notes h1{font-size:22px;margin-bottom:14px}
.player-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:16px 0 22px}
.player-assets{display:grid;gap:8px;margin-top:24px}
.player-assets a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-s);background:var(--mist);font-size:14px;font-weight:600}

.player-side{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:14px;align-self:flex-start;position:sticky;top:74px;max-height:calc(100vh - 90px);overflow-y:auto}
.player-side .progress-bar{height:6px;background:var(--mist);border-radius:99px;overflow:hidden;margin:6px 0 14px}
.player-side .progress-bar > div{height:100%;background:var(--teal);border-radius:99px}
.player-side .module{margin-bottom:14px}
.player-side .module h4{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;padding:0 6px}
.player-side .lesson{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-s);font-size:14px;color:var(--ink)}
.player-side .lesson:hover{background:var(--mist)}
.player-side .lesson.is-current{background:var(--teal-soft);color:var(--teal-dark);font-weight:600}
.player-side .lesson.is-locked{color:var(--muted);cursor:not-allowed}
.player-side .lesson .tick{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;flex-shrink:0}
.player-side .lesson.done .tick{background:var(--success);border-color:var(--success);color:#fff}
.player-side .lesson .dur{margin-left:auto;font-size:12px;color:var(--muted)}
