/* EduPremium LMS — Design Tokens
   Mapeamento WordPress (futuro):
   - index.html          -> page-home.php / front-page.php
   - planos.html         -> page-planos.php
   - aluno/dashboard.html -> page-dashboard.php
   - aluno/curso.html    -> single-sfwd-courses.php (LearnDash) / single-courses.php (Tutor)
   - aluno/aula.html     -> single-sfwd-lessons.php / single-lesson.php
   - aluno/questionario.html -> single-sfwd-quiz.php / single-tutor_quiz.php
*/

:root{
  --surface:#faf8ff; --surface-low:#f2f3ff; --surface-container:#eaedff;
  --on-surface:#131b2e; --on-surface-variant:#464555;
  --outline:#777587; --outline-variant:#c7c4d8;
  --primary:#4f46e5; --primary-dark:#3525cd; --on-primary:#ffffff;
  --primary-fixed:#e2dfff; --on-primary-fixed-variant:#3323cc;
  --secondary:#10b981; --secondary-dark:#006c49; --secondary-container:#6cf8bb;
  --tertiary:#7e3000; --tertiary-fixed:#ffdbcc;
  --error:#ba1a1a; --error-container:#ffdad6;
  --sidebar:#0f172a;
  --radius-sm:.25rem; --radius:.5rem; --radius-md:.75rem; --radius-lg:1rem; --radius-xl:1.5rem;
  --shadow-1:0 4px 6px -1px rgba(15,23,42,.1);
  --shadow-2:0 10px 20px -5px rgba(15,23,42,.15);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--surface);color:var(--on-surface);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none}
img{max-width:100%;display:block}

.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;vertical-align:middle}

/* Certificado — visual moderno */
.cert-page{
  background:#0f172a;
  color:#e2e8f0;
  width:100%;
  aspect-ratio:297/210;
  position:relative;
  overflow:hidden;
  border-radius:16px;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;
}
.cert-inner{
  position:relative;height:100%;display:flex;flex-direction:column;
  padding:56px 72px 40px 88px;
}
.cert-head{display:flex;align-items:center;justify-content:space-between;gap:24px}
.cert-head .meta{text-align:right}
.cert-head .meta .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#94a3b8}
.cert-head .meta .code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:14px;font-weight:700;color:#e2e8f0;letter-spacing:.1em}
.cert-body{flex:1;display:flex;flex-direction:column;justify-content:center;margin-top:8px}
.cert-body .pretitle{font-size:13px;color:#94a3b8;margin:0 0 10px}
.cert-body .course-pre{font-size:13px;color:#94a3b8;margin:24px 0 6px}
.cert-name{font-size:64px;font-weight:800;line-height:1;letter-spacing:-.02em;margin:0 0 20px;
  background:linear-gradient(90deg,#a5b4fc,#fff 45%,#6ee7b7);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cert-course{font-size:26px;font-weight:700;color:#fff;margin:0;line-height:1.25;max-width:760px}
.cert-foot-text{font-size:11px;color:#64748b;max-width:680px;margin:18px 0 0;line-height:1.6}
.cert-foot-text strong{color:#cbd5e1;font-weight:600}
.cert-chip{
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;width:auto;
  background:rgba(79,70,229,.18);border:1px solid rgba(129,140,248,.4);
  color:#c7d2fe;font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:700;
  margin-bottom:28px;
}
.cert-chip::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 10px #10b981;
}
.cert-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-top:20px}
.cert-foot .col{flex:1;min-width:0}
.cert-foot .col.right{text-align:right}
.cert-foot .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#64748b;margin-bottom:4px}
.cert-foot .value{font-size:16px;font-weight:700;color:#fff}
.cert-foot .rule{height:1px;margin-top:10px;max-width:200px;
  background:linear-gradient(90deg,rgba(148,163,184,.5),transparent)}
.cert-foot .col.right .rule{margin-left:auto;background:linear-gradient(90deg,transparent,rgba(148,163,184,.5))}
.cert-verify{
  position:absolute;bottom:14px;left:0;right:0;text-align:center;
  font-size:10px;color:#64748b;letter-spacing:.05em;
}
.cert-verify .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#94a3b8}
.cert-page::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at -10% -20%, rgba(79,70,229,.35), transparent 60%),
    radial-gradient(700px 400px at 110% 120%, rgba(16,185,129,.28), transparent 60%);
  pointer-events:none;
}
.cert-page::after{
  content:"";position:absolute;inset:18px;border:1px solid rgba(148,163,184,.18);
  border-radius:10px;pointer-events:none;
}
.cert-grid{
  position:absolute;inset:0;opacity:.06;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:48px 48px;
}
.cert-accent{
  position:absolute;left:0;top:0;bottom:0;width:8px;
  background:linear-gradient(180deg,#4f46e5,#10b981);
}
.cert-name{
  background:linear-gradient(90deg,#a5b4fc,#fff 40%,#6ee7b7);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-weight:800;letter-spacing:-0.02em;
}
.cert-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:rgba(79,70,229,.15);border:1px solid rgba(129,140,248,.35);
  color:#c7d2fe;font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:600;
}
.cert-chip::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 10px #10b981;
}
.cert-seal{
  position:relative;width:96px;height:96px;border-radius:50%;
  background:conic-gradient(from 0deg,#4f46e5,#10b981,#4f46e5);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -10px rgba(79,70,229,.6);
}
.cert-seal>div{
  width:80px;height:80px;border-radius:50%;background:#0f172a;
  display:flex;align-items:center;justify-content:center;
  color:#e2e8f0;font-weight:800;font-size:11px;letter-spacing:.2em;text-align:center;flex-direction:column;
}
.cert-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(148,163,184,.5),transparent)}
/* Cert root oculto na tela; só aparece ao imprimir */
.cert-print-root{display:none}

@media print{
  @page{size:A4 landscape;margin:0}
  html,body{background:#0f172a !important;margin:0 !important;padding:0 !important;
    width:297mm !important;height:210mm !important;overflow:hidden !important;
    -webkit-print-color-adjust:exact;print-color-adjust:exact;color-adjust:exact}
  *{-webkit-print-color-adjust:exact !important;print-color-adjust:exact !important}
  body>*{display:none !important}
  body>.cert-print-root{display:block !important;
    position:fixed !important;left:0 !important;top:0 !important;
    width:297mm !important;height:210mm !important;max-width:none !important;
    margin:0 !important;padding:0 !important;background:#0f172a;z-index:9999;
    overflow:hidden !important;page-break-after:avoid;break-after:avoid}
  .cert-page{box-shadow:none !important;margin:0 !important;border-radius:0 !important;
    width:297mm !important;height:210mm !important;aspect-ratio:auto !important;
    page-break-inside:avoid;break-inside:avoid;overflow:hidden !important}
  .cert-inner{padding:18mm 22mm 14mm 26mm !important;height:210mm !important;box-sizing:border-box}
}

/* ===== WooCommerce my-account: Login + Register branded ===== */
.woocommerce-account .woocommerce{
  max-width:1100px;
  margin:0 auto;
  padding:48px 20px 64px;
}
.woocommerce-account:not(.logged-in) .woocommerce > .u-columns,
.woocommerce-account:not(.logged-in) .woocommerce > div.u-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
}
@media (max-width:860px){
  .woocommerce-account:not(.logged-in) .woocommerce > .u-columns,
  .woocommerce-account:not(.logged-in) .woocommerce > div.u-columns{grid-template-columns:1fr}
}
.woocommerce-account .u-column1,
.woocommerce-account .u-column2{
  background:#fff;
  border:1px solid var(--outline-variant);
  border-radius:var(--radius-lg);
  padding:36px 32px;
  box-shadow:var(--shadow-1);
  width:auto !important;
  float:none !important;
}
.woocommerce-account .u-column1 h2,
.woocommerce-account .u-column2 h2{
  font-family:'Playfair Display',serif;
  font-size:28px;
  font-weight:700;
  margin:0 0 6px;
  color:var(--on-surface);
  letter-spacing:-.01em;
}
.woocommerce-account .u-column1 h2::after,
.woocommerce-account .u-column2 h2::after{
  content:'';display:block;width:48px;height:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  margin:10px 0 22px;
}
.woocommerce form.login,
.woocommerce form.register{
  border:none !important;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
}
.woocommerce form .form-row{
  display:flex;flex-direction:column;
  margin-bottom:14px;
  padding:0;
}
.woocommerce form .form-row label{
  font-size:13px;font-weight:600;color:var(--on-surface-variant);
  margin-bottom:6px;letter-spacing:.01em;
}
.woocommerce form .form-row label .required{color:var(--error);text-decoration:none;margin-left:2px}
.woocommerce form .form-row input.input-text,
.woocommerce-account form .woocommerce-Input{
  font-family:'Inter',sans-serif;
  font-size:15px;
  padding:12px 14px;
  border:1px solid var(--outline-variant);
  border-radius:10px;
  background:var(--surface);
  color:var(--on-surface);
  width:100%;
  box-shadow:none;
  transition:border-color .15s,box-shadow .15s;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce-account form .woocommerce-Input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(79,70,229,.18);
  outline:none;
}
.woocommerce-form-login__rememberme,
.woocommerce-privacy-policy-text{
  font-size:13px;color:var(--on-surface-variant);
  margin:6px 0 14px;
}
.woocommerce-form-login__rememberme input,
.woocommerce-form-register__rememberme input{margin-right:6px;accent-color:var(--primary)}
.woocommerce-form-login__submit,
.woocommerce-form-register__submit,
.woocommerce form .button[type=submit]{
  background:var(--primary) !important;
  color:#fff !important;
  border:none !important;
  font-weight:600 !important;
  font-size:15px !important;
  padding:12px 22px !important;
  border-radius:10px !important;
  width:100%;
  box-shadow:0 4px 12px -2px rgba(79,70,229,.45) !important;
  transition:background .15s !important;
  text-transform:none !important;
  letter-spacing:.01em;
  cursor:pointer;
}
.woocommerce-form-login__submit:hover,
.woocommerce-form-register__submit:hover,
.woocommerce form .button[type=submit]:hover{background:var(--primary-dark) !important}
.woocommerce-LostPassword{margin-top:14px;font-size:13px;text-align:center}
.woocommerce-LostPassword a{color:var(--primary);font-weight:500}
.woocommerce-LostPassword a:hover{text-decoration:underline}
.woocommerce-password-strength{
  font-size:12px;padding:6px 10px;border-radius:6px;margin-top:6px;
}
.woocommerce-password-hint{font-size:12px;color:var(--outline);margin-top:4px}
/* Notices on the my-account page */
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-info{
  border-radius:10px;
  padding:14px 18px;
  border-left:4px solid var(--primary);
  background:#fff;
  box-shadow:var(--shadow-1);
  font-size:14px;
  margin-bottom:18px;
}
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-error{border-left-color:var(--error)}
.woocommerce-account .woocommerce-notices-wrapper .woocommerce-message{border-left-color:var(--secondary)}

/* Lost-password standalone form */
.woocommerce form.lost_reset_password{
  max-width:480px;margin:48px auto;padding:36px 32px;
  background:#fff;border:1px solid var(--outline-variant);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-1);
}

/* ============================================================
   Classic checkout — dark theme, side-aligned summary
   ============================================================ */
body.woocommerce-checkout{
  background:#0f172a;
  color:#e2e8f0;
}
body.woocommerce-checkout .woocommerce{
  max-width:1180px;
  margin:0 auto;
  padding:32px 24px 32px;
  font-family:'Inter',system-ui,sans-serif;
}
body.woocommerce-checkout .woocommerce *{font-family:inherit}

/* hide noise */
body.woocommerce-checkout .woocommerce-form-coupon-toggle,
body.woocommerce-checkout .checkout_coupon,
body.woocommerce-checkout p.return-to-shop,
body.woocommerce-checkout .wc-backward,
body.woocommerce-checkout .woocommerce-form-login-toggle{display:none !important}

/* Page heading */
body.woocommerce-checkout h1.entry-title,
body.woocommerce-checkout .woocommerce > h1{
  font-family:'Playfair Display',serif;
  font-size:34px;font-weight:800;
  margin:0 0 28px;letter-spacing:-.01em;
  color:#fff;
}

/* ---------- Grid: form (left) | summary (right, sticky on top) ---------- */
body.woocommerce-checkout form.checkout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  column-gap:28px;row-gap:0;
  align-items:start;
}
body.woocommerce-checkout form.checkout > .col2-set,
body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
body.woocommerce-checkout form.checkout > #payment{margin-bottom:20px}
body.woocommerce-checkout form.checkout > #payment:last-child{margin-bottom:0}
body.woocommerce-checkout form.checkout > .col2-set,
body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
body.woocommerce-checkout form.checkout > #payment{
  grid-column:1;min-width:0;
}
body.woocommerce-checkout form.checkout > h3#order_review_heading{display:none}
body.woocommerce-checkout form.checkout > #order_review{
  grid-column:2;grid-row:1 / span 8;
  height:fit-content;
  position:sticky;top:24px;align-self:start;
}
body.woocommerce-checkout #order_review .edu-order-review-title{
  font-family:'Inter',sans-serif;
  font-size:17px;font-weight:700;color:#f8fafc;
  margin:0 0 18px;letter-spacing:-.005em;
}
@media (max-width:960px){
  body.woocommerce-checkout form.checkout{grid-template-columns:1fr}
  body.woocommerce-checkout form.checkout > #order_review{grid-column:1;grid-row:auto;position:static}
}

/* ---------- Cards ---------- */
body.woocommerce-checkout form.checkout > .col2-set,
body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
body.woocommerce-checkout form.checkout > #payment,
body.woocommerce-checkout form.checkout > #order_review{
  background:#1e293b;
  border:1px solid #334155;
  border-radius:16px;
  padding:28px;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.45);
}
body.woocommerce-checkout form.checkout > #order_review{padding:22px}

/* Section headings */
body.woocommerce-checkout form.checkout h3{
  font-size:17px;font-weight:700;
  margin:0 0 18px;color:#f8fafc;letter-spacing:-.005em;
}

/* Stack billing/additional cols */
body.woocommerce-checkout form.checkout .col2-set{display:block}
body.woocommerce-checkout form.checkout .col2-set .col-1,
body.woocommerce-checkout form.checkout .col2-set .col-2{
  width:100%;float:none;padding:0;margin:0;
}
body.woocommerce-checkout form.checkout .col2-set .col-2{margin-top:24px}

/* ---------- Form rows ---------- */
body.woocommerce-checkout form .form-row{
  display:flex !important;flex-direction:column;
  margin:0 0 14px !important;padding:0 !important;width:100% !important;
}
body.woocommerce-checkout form .form-row label{
  font-size:13px;font-weight:600;color:#cbd5e1;
  margin-bottom:6px;letter-spacing:.01em;
}
body.woocommerce-checkout form .form-row label .required{
  color:#fca5a5;text-decoration:none;margin-left:2px;
}
body.woocommerce-checkout form .form-row label .optional{color:#64748b;font-weight:500}

/* Inputs */
body.woocommerce-checkout form .input-text,
body.woocommerce-checkout form input[type=text],
body.woocommerce-checkout form input[type=email],
body.woocommerce-checkout form input[type=tel],
body.woocommerce-checkout form input[type=password],
body.woocommerce-checkout form input[type=number],
body.woocommerce-checkout form textarea,
body.woocommerce-checkout form select,
body.woocommerce-checkout .select2-container--default .select2-selection--single{
  font-family:'Inter',sans-serif !important;
  font-size:15px !important;
  padding:11px 14px !important;
  height:auto !important;
  min-height:46px !important;
  border:1px solid #334155 !important;
  border-radius:10px !important;
  background:#0f172a !important;
  color:#f8fafc !important;
  width:100% !important;
  box-shadow:none !important;
  line-height:1.4 !important;
  transition:border-color .15s,box-shadow .15s !important;
}
body.woocommerce-checkout form .input-text::placeholder,
body.woocommerce-checkout form textarea::placeholder{color:#64748b}
body.woocommerce-checkout form .input-text:focus,
body.woocommerce-checkout form input:focus,
body.woocommerce-checkout form textarea:focus,
body.woocommerce-checkout form select:focus,
body.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single,
body.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single{
  border-color:#818cf8 !important;
  box-shadow:0 0 0 3px rgba(99,102,241,.25) !important;
  outline:none !important;
}
body.woocommerce-checkout form textarea{min-height:90px;resize:vertical}

/* Select2 dropdown */
body.woocommerce-checkout .select2-container--default .select2-selection--single{display:flex;align-items:center}
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{
  line-height:1.4 !important;padding:0 !important;color:#f8fafc !important;
}
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{
  height:100% !important;right:10px !important;
}
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b{border-color:#94a3b8 transparent transparent}
.select2-dropdown{background:#1e293b !important;border-color:#334155 !important;color:#f8fafc !important}
.select2-results__option{color:#f8fafc !important}
.select2-results__option--highlighted{background:#4f46e5 !important;color:#fff !important}
.select2-search--dropdown .select2-search__field{background:#0f172a !important;color:#f8fafc !important;border-color:#334155 !important;border-radius:8px !important;padding:8px 10px !important}

/* ---------- Order review (right) ---------- */
body.woocommerce-checkout #order_review .shop_table,
body.woocommerce-checkout #order_review table.shop_table{
  width:100%;border-collapse:collapse;border:none;margin:0;
  background:transparent;
  font-family:'Inter',sans-serif;color:#e2e8f0;
  box-shadow:none;
}
body.woocommerce-checkout #order_review .shop_table thead{display:none}
body.woocommerce-checkout #order_review .shop_table tbody tr,
body.woocommerce-checkout #order_review .shop_table tfoot tr{border:none;background:transparent}
body.woocommerce-checkout #order_review .shop_table th,
body.woocommerce-checkout #order_review .shop_table td{
  padding:10px 0;border:none;font-size:14px;color:#e2e8f0;
  background:transparent;vertical-align:top;
}

/* Cart line item */
body.woocommerce-checkout #order_review .shop_table tbody tr.cart_item td.product-name{
  font-weight:600;color:#f8fafc;
}
body.woocommerce-checkout #order_review .shop_table .product-quantity{
  display:inline-block;margin-left:8px;color:#94a3b8;font-weight:500;font-size:13px;
}
body.woocommerce-checkout #order_review .shop_table td.product-total{
  text-align:right;white-space:nowrap;color:#e2e8f0;font-variant-numeric:tabular-nums;
}

/* Divider between items and totals */
body.woocommerce-checkout #order_review .shop_table tfoot{
  border-top:1px solid #334155;
}

/* Subtotal / fees */
body.woocommerce-checkout #order_review .shop_table tfoot tr th,
body.woocommerce-checkout #order_review .shop_table tfoot tr td{
  padding:8px 0;font-size:13px;color:#94a3b8;font-weight:500;
}
body.woocommerce-checkout #order_review .shop_table tfoot tr td{
  text-align:right;color:#cbd5e1;font-variant-numeric:tabular-nums;
}
body.woocommerce-checkout #order_review .shop_table tfoot tr:first-child th,
body.woocommerce-checkout #order_review .shop_table tfoot tr:first-child td{padding-top:14px}

/* Total row — strongest visual */
body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total{
  border-top:1px solid #334155;
}
body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total th,
body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total td{
  padding:14px 0 4px;font-size:18px;font-weight:700;color:#f8fafc;
}
body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total .woocommerce-Price-amount{
  color:#a5b4fc;font-weight:700;
}
body.woocommerce-checkout #order_review .shop_table .woocommerce-Price-amount{color:inherit}
body.woocommerce-checkout #order_review .shop_table .woocommerce-Price-currencySymbol{
  margin-right:2px;color:inherit;
}

/* ---------- Payment block (left, under form) ---------- */
body.woocommerce-checkout #payment{margin-top:0}
body.woocommerce-checkout #payment ul.payment_methods{
  list-style:none;margin:0;padding:0;border:none;background:transparent;
}
body.woocommerce-checkout #payment ul.payment_methods > li{
  border:1px solid #334155;border-radius:12px;
  padding:14px 16px;margin:0 0 10px;background:#0f172a;
  transition:border-color .15s,background .15s,box-shadow .15s;
}
body.woocommerce-checkout #payment ul.payment_methods > li:has(input:checked){
  border-color:#818cf8;background:#1e1b4b;
  box-shadow:0 0 0 3px rgba(99,102,241,.18);
}
body.woocommerce-checkout #payment ul.payment_methods > li label{
  display:flex;align-items:center;gap:10px;cursor:pointer;
  font-weight:600;font-size:15px;color:#f8fafc;margin:0;
}
body.woocommerce-checkout #payment ul.payment_methods > li label img{max-height:28px;width:auto;margin-left:auto}
body.woocommerce-checkout #payment ul.payment_methods > li input[type=radio]{accent-color:#818cf8;width:18px;height:18px}
body.woocommerce-checkout #payment div.payment_box{
  background:transparent;border:none;
  padding:12px 0 0 28px;margin:8px 0 0;
  font-size:13px;line-height:1.5;color:#cbd5e1;
}
body.woocommerce-checkout #payment div.payment_box::before{display:none !important}
body.woocommerce-checkout #payment div.payment_box p,
body.woocommerce-checkout #payment div.payment_box strong{color:#e2e8f0}
body.woocommerce-checkout #payment div.payment_box a{color:#a5b4fc}

/* MP custom notice (Checkout Pro em Modo Teste) */
body.woocommerce-checkout #payment .mp-checkout-test-mode,
body.woocommerce-checkout #payment .mp-test-notice{
  background:rgba(245,158,11,.15);border-left:3px solid #f59e0b;
  border-radius:8px;padding:10px 12px;margin:10px 0;color:#fde68a;font-size:13px;
}

/* Place order */
body.woocommerce-checkout #payment .form-row.place-order,
body.woocommerce-checkout .place-order{margin:18px 0 0;padding:0;text-align:left}
body.woocommerce-checkout #place_order{
  background:#4f46e5 !important;color:#fff !important;border:none !important;
  width:100%;padding:14px 22px !important;border-radius:10px !important;
  font-weight:700 !important;font-size:16px !important;letter-spacing:.01em;
  cursor:pointer;text-transform:none !important;
  box-shadow:0 6px 18px -4px rgba(79,70,229,.55) !important;
  transition:background .15s,transform .05s;
}
body.woocommerce-checkout #place_order:hover{background:#3525cd !important}

/* Privacy / terms */
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper,
body.woocommerce-checkout .woocommerce-privacy-policy-text{
  font-size:13px;color:#94a3b8;margin:14px 0 0;line-height:1.5;
}
body.woocommerce-checkout .woocommerce-privacy-policy-text a,
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a{color:#a5b4fc;font-weight:500}

/* ---------- Notices (success / error / info) ---------- */
body.woocommerce-checkout .woocommerce-notices-wrapper,
body.woocommerce-cart .woocommerce-notices-wrapper{margin:0 0 24px}
body.woocommerce-checkout ul.woocommerce-error,
body.woocommerce-checkout .woocommerce-message,
body.woocommerce-checkout .woocommerce-error,
body.woocommerce-checkout .woocommerce-info,
body.woocommerce-checkout .woocommerce-NoticeGroup,
body.woocommerce-cart ul.woocommerce-error,
body.woocommerce-cart .woocommerce-message,
body.woocommerce-cart .woocommerce-error,
body.woocommerce-cart .woocommerce-info{
  background:#1e293b !important;color:#f8fafc !important;
  border:1px solid #334155 !important;border-radius:12px !important;
  padding:16px 20px 16px 56px !important;margin:0 0 14px !important;
  font-size:14px !important;line-height:1.5 !important;
  list-style:none !important;position:relative !important;
  box-shadow:0 8px 24px -10px rgba(0,0,0,.5) !important;
}
body.woocommerce-checkout ul.woocommerce-error,
body.woocommerce-checkout .woocommerce-error,
body.woocommerce-cart ul.woocommerce-error,
body.woocommerce-cart .woocommerce-error{border-left:4px solid #ef4444 !important}
body.woocommerce-checkout .woocommerce-message,
body.woocommerce-cart .woocommerce-message{border-left:4px solid #10b981 !important}
body.woocommerce-checkout .woocommerce-info,
body.woocommerce-cart .woocommerce-info{border-left:4px solid #4f46e5 !important}

/* Icon (✕ for error, ✓ for success, i for info) */
body.woocommerce-checkout ul.woocommerce-error::before,
body.woocommerce-checkout .woocommerce-error::before,
body.woocommerce-cart ul.woocommerce-error::before,
body.woocommerce-cart .woocommerce-error::before{
  content:"!";
  position:absolute;left:14px;top:18px;
  width:26px;height:26px;border-radius:50%;
  background:#ef4444;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;font-family:'Inter',sans-serif;line-height:1;
}
body.woocommerce-checkout .woocommerce-message::before,
body.woocommerce-cart .woocommerce-message::before{
  content:"¹3";
  position:absolute;left:14px;top:18px;
  width:26px;height:26px;border-radius:50%;
  background:#10b981;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;line-height:1;
}
body.woocommerce-checkout .woocommerce-info::before,
body.woocommerce-cart .woocommerce-info::before{
  content:"i";
  position:absolute;left:14px;top:18px;
  width:26px;height:26px;border-radius:50%;
  background:#4f46e5;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:15px;font-family:'Inter',sans-serif;line-height:1;
  font-style:italic;
}

/* List items inside notices */
body.woocommerce-checkout ul.woocommerce-error li,
body.woocommerce-checkout .woocommerce-error li,
body.woocommerce-cart ul.woocommerce-error li,
body.woocommerce-cart .woocommerce-error li{
  background:transparent !important;color:inherit !important;
  border:none !important;padding:0 !important;margin:0 0 4px !important;
  list-style:none !important;
}
body.woocommerce-checkout ul.woocommerce-error li:last-child,
body.woocommerce-cart ul.woocommerce-error li:last-child{margin-bottom:0 !important}
body.woocommerce-checkout ul.woocommerce-error li::before,
body.woocommerce-cart ul.woocommerce-error li::before{display:none !important}

/* Strong (title) inside notice text */
body.woocommerce-checkout .woocommerce-error strong,
body.woocommerce-checkout .woocommerce-message strong,
body.woocommerce-checkout .woocommerce-info strong,
body.woocommerce-cart .woocommerce-error strong,
body.woocommerce-cart .woocommerce-message strong,
body.woocommerce-cart .woocommerce-info strong{
  color:#fff !important;font-weight:700;
  display:block;margin-bottom:2px;
}

/* Hide "View cart" / "Continue shopping" buttons inside notices */
body.woocommerce-checkout .woocommerce-message .button,
body.woocommerce-checkout .woocommerce-notices-wrapper a.button,
body.woocommerce-cart .woocommerce-notices-wrapper a.button{display:none !important}

/* ============================================================
   Checkout wizard — 2 steps (data → payment)
   ============================================================ */
.edu-steps{
  list-style:none;display:flex;gap:0;margin:0 0 28px;padding:0;
  font-family:'Inter',sans-serif;
}
.edu-steps .edu-step{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px;flex:1;
  background:#1e293b;border:1px solid #334155;
  color:#94a3b8;font-weight:600;font-size:14px;
  position:relative;
}
.edu-steps .edu-step:first-child{border-top-left-radius:10px;border-bottom-left-radius:10px}
.edu-steps .edu-step:last-child{border-top-right-radius:10px;border-bottom-right-radius:10px;border-left:none}
.edu-steps .edu-step span{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:#0f172a;color:#94a3b8;font-size:13px;font-weight:700;
  border:1px solid #334155;
}
.edu-steps .edu-step.is-active{
  background:rgba(79,70,229,.15);border-color:#818cf8;color:#f8fafc;
}
.edu-steps .edu-step.is-active span{background:#4f46e5;color:#fff;border-color:#4f46e5}

/* Continue button (step 1 -> 2) */
.edu-continue-row{margin-top:22px}
.edu-btn-primary{
  background:#4f46e5;color:#fff;border:none;
  width:100%;padding:14px 22px;border-radius:10px;
  font-weight:700;font-size:16px;font-family:'Inter',sans-serif;
  cursor:pointer;letter-spacing:.01em;
  box-shadow:0 6px 18px -4px rgba(79,70,229,.55);
  transition:background .15s,transform .05s;
}
.edu-btn-primary:hover{background:#3525cd}
.edu-btn-primary:active{transform:translateY(1px)}

/* Back button (step 2 -> 1) */
.edu-btn-back{
  background:transparent;color:#a5b4fc;border:none;
  font-size:13px;font-weight:500;cursor:pointer;
  padding:0 0 14px;font-family:'Inter',sans-serif;
}
.edu-btn-back:hover{color:#c7d2fe;text-decoration:underline}

/* Hide #payment until step 2 (CSS default — survives WC Ajax) */
body.woocommerce-checkout form.checkout #payment{display:none}
body.woocommerce-checkout form.checkout[data-edu-step="2"] #payment{display:block;margin-top:0}
/* Hide form fields when step 2 */
body.woocommerce-checkout form.checkout[data-edu-step="2"] > .col2-set,
body.woocommerce-checkout form.checkout[data-edu-step="2"] > .woocommerce-additional-fields,
body.woocommerce-checkout form.checkout[data-edu-step="2"] > .edu-continue-row{display:none}

/* Hide invalid field highlight conflict */
body.woocommerce-checkout form .form-row.woocommerce-invalid input.input-text,
body.woocommerce-checkout form .form-row.woocommerce-invalid input,
body.woocommerce-checkout form .form-row.woocommerce-invalid select,
body.woocommerce-checkout form .form-row.woocommerce-invalid .select2-selection{
  border-color:#ef4444 !important;
  box-shadow:0 0 0 3px rgba(239,68,68,.18) !important;
}

/* Collapse outer wrappers on checkout/cart pages */
body.woocommerce-checkout,body.woocommerce-cart,
body.woocommerce-checkout #page,body.woocommerce-cart #page,
body.woocommerce-checkout .site-content,body.woocommerce-cart .site-content{min-height:0 !important}
body.woocommerce-checkout main,body.woocommerce-cart main{
  max-width:none !important;padding:0 !important;margin:0 !important;
}
body.woocommerce-checkout main > article,
body.woocommerce-cart main > article{
  background:transparent !important;padding:0 !important;margin:0 !important;
  box-shadow:none !important;border-radius:0 !important;
}
body.woocommerce-checkout main > article > h1,
body.woocommerce-cart main > article > h1{display:none !important}
body.woocommerce-checkout .prose,
body.woocommerce-cart .prose{
  max-width:none !important;color:inherit !important;
}
body.woocommerce-checkout .prose *,
body.woocommerce-cart .prose *{color:inherit}
/* Footer top margin trim on these pages */
body.woocommerce-checkout footer,body.woocommerce-cart footer{margin-top:0 !important}

/* ============================================================
   Checkout — mobile/responsive polish
   ============================================================ */
html,body{overflow-x:hidden}
body.woocommerce-checkout,body.woocommerce-cart{
  background:#0f172a !important;
  overflow-x:hidden;
}

/* tablet (≤960px): single column, summary on top, reduce padding */
@media (max-width:960px){
  body.woocommerce-checkout form.checkout{row-gap:14px}
  body.woocommerce-checkout form.checkout > .col2-set,
  body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
  body.woocommerce-checkout form.checkout > #payment,
  body.woocommerce-checkout form.checkout > #order_review{margin-bottom:0}
  body.woocommerce-checkout .woocommerce{padding:20px 14px}
  body.woocommerce-checkout h1.entry-title,
  body.woocommerce-checkout .woocommerce > h1{font-size:26px;margin-bottom:18px}
  body.woocommerce-checkout form.checkout > .col2-set,
  body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
  body.woocommerce-checkout form.checkout > #payment,
  body.woocommerce-checkout form.checkout > #order_review{
    padding:18px;border-radius:12px;
  }
  body.woocommerce-checkout form.checkout > #order_review{
    order:-1;position:static;margin-bottom:6px;
  }
  body.woocommerce-checkout form.checkout > h3#order_review_heading{display:none}
  /* steps tighter */
  .edu-steps .edu-step{padding:8px 12px;font-size:13px}
  .edu-steps .edu-step span{width:22px;height:22px;font-size:12px}
}

/* phone (≤640px) */
@media (max-width:640px){
  body.woocommerce-checkout .woocommerce{padding:16px 10px}
  body.woocommerce-checkout h1.entry-title,
  body.woocommerce-checkout .woocommerce > h1{font-size:22px;margin-bottom:14px}
  body.woocommerce-checkout form.checkout{column-gap:0;row-gap:14px}
  body.woocommerce-checkout form.checkout > .col2-set,
  body.woocommerce-checkout form.checkout > .woocommerce-additional-fields,
  body.woocommerce-checkout form.checkout > #payment,
  body.woocommerce-checkout form.checkout > #order_review{
    padding:16px;border-radius:10px;
  }
  body.woocommerce-checkout form.checkout h3{font-size:15px;margin-bottom:14px}
  body.woocommerce-checkout #order_review .edu-order-review-title{font-size:15px;margin-bottom:12px}
  body.woocommerce-checkout form .form-row{margin-bottom:12px !important}
  body.woocommerce-checkout form .form-row label{font-size:12px;margin-bottom:4px}
  body.woocommerce-checkout form .input-text,
  body.woocommerce-checkout form input[type=text],
  body.woocommerce-checkout form input[type=email],
  body.woocommerce-checkout form input[type=tel],
  body.woocommerce-checkout form input[type=password],
  body.woocommerce-checkout form input[type=number],
  body.woocommerce-checkout form textarea,
  body.woocommerce-checkout form select,
  body.woocommerce-checkout .select2-container--default .select2-selection--single{
    font-size:14px !important;padding:10px 12px !important;min-height:42px !important;
  }
  body.woocommerce-checkout #payment ul.payment_methods > li{padding:12px 14px}
  body.woocommerce-checkout #payment ul.payment_methods > li label{font-size:14px;gap:8px}
  body.woocommerce-checkout #payment ul.payment_methods > li label img{max-height:24px}
  body.woocommerce-checkout #payment div.payment_box{padding:10px 0 0 26px;font-size:12px}
  body.woocommerce-checkout #place_order,
  body.woocommerce-checkout .edu-btn-primary{padding:12px 18px;font-size:15px}
  /* order summary tighter */
  body.woocommerce-checkout #order_review .shop_table th,
  body.woocommerce-checkout #order_review .shop_table td{padding:8px 0;font-size:13px}
  body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total th,
  body.woocommerce-checkout #order_review .shop_table tfoot tr.order-total td{font-size:16px;padding-top:12px}
  /* steps as compact pill */
  .edu-steps{margin-bottom:18px}
  .edu-steps .edu-step{padding:7px 10px;font-size:12px;gap:6px}
  .edu-steps .edu-step span{width:20px;height:20px;font-size:11px}
  /* notices */
  body.woocommerce-checkout ul.woocommerce-error,
  body.woocommerce-checkout .woocommerce-message,
  body.woocommerce-checkout .woocommerce-error,
  body.woocommerce-checkout .woocommerce-info{padding:14px 14px 14px 50px !important;font-size:13px !important}
  body.woocommerce-checkout ul.woocommerce-error::before,
  body.woocommerce-checkout .woocommerce-error::before,
  body.woocommerce-checkout .woocommerce-message::before,
  body.woocommerce-checkout .woocommerce-info::before{left:12px;top:14px;width:22px;height:22px;font-size:13px}
}

/* very small (≤380px): hide step labels, keep numbers */
@media (max-width:380px){
  .edu-steps .edu-step{padding:6px;justify-content:center}
}
