/* public/css/estlo/checkout.css */
:root{
  /* Paleta do livro */
  --navy:#13172e;
  --navy2:#191e38;
  --gold:#e2aa28;
  --gold2:#c69a37;
  --sand:#ead6a5;

  /* Neutros */
  --text:#f4f4f4;
  --muted:rgba(244,244,244,.78);
  --border:rgba(234,214,165,.18);

  --radius:14px;
  --shadow: 0 18px 55px rgba(0,0,0,.35);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  font-family: Arial, sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 650px at 20% 0%, var(--navy2) 0%, var(--navy) 52%, #0d1122 100%);
  line-height:1.5;
}

.container{
  max-width: 1180px;
  margin: 28px auto;
  padding: 0 18px;
}

a{ color:inherit; }

/* Topbar */
.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
}
.brand{
  font-weight:900;
  letter-spacing:.6px;
  color: var(--sand);
}
.link{
  color: var(--sand);
  text-decoration: underline;
  font-size:13px;
}

/* Grid */
.grid{ display:flex; gap:22px; align-items:flex-start; flex-wrap:wrap; }
.left{ flex:1 1 640px; min-width:320px; }
.right{ flex:0 0 380px; min-width:320px; }

/* Card */
.card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card + .card{ margin-top:14px; }

.pad{ padding:16px; }

/* Form */
.row{ display:flex; gap:12px; flex-wrap:wrap; }
.col{ flex:1 1 240px; min-width:220px; }

/* ✅ travar larguras no flex (melhor responsivo) */
.col-btn{ max-width:220px; flex:0 0 220px; }
.col-small{ max-width:220px; flex:0 0 220px; }
.col-uf{ max-width:160px; flex:0 0 160px; }

label{
  display:block;
  font-size:13px;
  color: var(--sand);
  margin:10px 0 6px;
}

input, select, textarea{
  width:100%;
  padding:11px 10px;
  border:1px solid rgba(234,214,165,.25);
  border-radius:10px;
  outline:none;
  font-size:14px;
  background: rgba(0,0,0,.18);
  color: var(--text);
}

input::placeholder, textarea::placeholder{ color: rgba(244,244,244,.55); }
input:focus, select:focus, textarea:focus{ border-color: rgba(226,170,40,.6); }

/* ✅ select bonito no tema escuro */
select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(234,214,165,.85) 50%),
    linear-gradient(135deg, rgba(234,214,165,.85) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}

textarea{ min-height:90px; resize:vertical; }

.h2{ margin:0 0 6px; }
.h3{ margin:0 0 6px; }

.muted{ color: var(--muted); }
.mini{ font-size:12px; }

.hr{ border-top:1px solid rgba(234,214,165,.18); margin:14px 0; }

.ok{ color: #7CFFB2; font-size:13px; }
.error{ color: #ff8a8a; font-size:13px; }

/* ✅ espaço do bloco de escolha do frete */
#shippingRow{ margin-top: 6px; }

/* Buttons */
.btn-full{
  display:inline-block;
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  cursor:pointer;
  font-weight:800;
  font-size:14px;
  background: rgba(255,255,255,.08);
  color: var(--text);
  border:1px solid rgba(234,214,165,.22);
}
.btn-full:disabled{ opacity:.55; cursor:not-allowed; }
.btn-green{
  background: linear-gradient(180deg, var(--gold) 0%, var(--gold2) 100%);
  color:#1a1a1a;
  border:0;
}

/* Coupon toggle */
.toggle{
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
  user-select:none;
  padding:14px 16px;
  border-bottom:1px solid rgba(234,214,165,.18);
  font-size:14px;
  color: var(--sand);
  background: rgba(0,0,0,.18);
}
.toggle small{ color: rgba(234,214,165,.75); }
.toggle-body{ padding:14px 16px; display:none; }
.toggle-body.open{ display:block; }

/* Right summary */
.product{ display:flex; gap:12px; align-items:center; }
.thumb{
  width:44px; height:58px;
  border:1px solid rgba(234,214,165,.22);
  border-radius:10px;
  object-fit:cover;
  background: rgba(255,255,255,.06);
}
.prodinfo{ flex:1; }
.prodtop{ display:flex; gap:8px; align-items:center; }
.prodtitle{ font-weight:800; }
.prodprice{ font-weight:800; }

.pill{
  font-size:12px;
  color:#1a1a1a;
  background: var(--gold);
  padding:2px 7px;
  border-radius:999px;
  font-weight:900;
}

.sumline{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  font-size:14px;
}
.total{
  font-size:18px;
  font-weight:900;
  color: var(--sand);
}

/* Payment box */
.paybox{
  border:1px solid rgba(234,214,165,.18);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.04);
}
.payopt{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px 12px;
  border-top:1px solid rgba(234,214,165,.15);
}
.payopt:first-child{ border-top:0; }
.payopt input{ width:auto; margin-top:2px; }
.payopt .title{ font-weight:900; font-size:14px; color: var(--sand); }
.payopt .desc{ font-size:12px; color: var(--muted); margin-top:3px; }

/* Terms */
.terms{ display:flex; gap:10px; align-items:flex-start; margin-top:12px; }
.terms input{ width:auto; margin-top:2px; }
.terms-label{
  margin:0;
  color: var(--muted);
  font-size:13px;
}

/* Footer igual ao index */
.footer{
  margin-top: 26px;
  padding: 18px 0 26px;
  border-top: 1px solid rgba(234,214,165,.15);
  color: rgba(234,214,165,.78);
  font-size: 13px;
}
.footer strong{ color: var(--sand); }
.footer a{ color: var(--sand); text-decoration: underline; }

/* ====== Select / Options (melhor legibilidade no dropdown) ====== */

/* Diz pro navegador que a página é "dark" (ajuda a escolher cores do sistema) */
:root { color-scheme: dark; }

/* Campo select em si */
select#shippingSelect,
select {
  background-color: rgba(0,0,0,.35) !important;
  color: #f4f4f4 !important;
  border: 1px solid rgba(226,170,40,.55) !important;
}

/* Itens do dropdown (funciona bem no Chrome/Edge; no Firefox pode variar) */
select#shippingSelect option,
select option,
select optgroup {
  background-color: #13172e !important; /* navy */
  color: #f4f4f4 !important;
}

/* Placeholder (primeira opção) mais “muted” */
select#shippingSelect option[value=""],
select option[value=""] {
  color: rgba(244,244,244,.65) !important;
}

/* Destaque ao focar */
select#shippingSelect:focus,
select:focus {
  border-color: rgba(226,170,40,.85) !important;
  box-shadow: 0 0 0 3px rgba(226,170,40,.18);
}

/* (Opcional) Aumenta altura e fonte pra ficar mais “confortável” */
select#shippingSelect {
  padding: 12px 12px !important;
  font-size: 15px !important;
  font-weight: 700;
}

.cupom-container {
    background: #fdf2f2;
    border: 2px dashed #e53e3e;
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    margin-bottom: 15px;
  }
  .cupom-codigo {
    display: block;
    font-size: 1.2rem;
    font-weight: bold;
    color: #e53e3e;
    margin: 8px 0;
    cursor: pointer;
    background: #fff;
    border: 1px solid #ddd;
    padding: 5px;
  }
  .cupom-aviso {
    font-size: 0.4rem;
    color: #666;
  }
