/* MzDocs Pro v3 — styles.css */
:root {
  --ink:#07101F; --ink2:#0F1E3B; --ink3:#1A2F52;
  --dim:#334155; --muted:#64748B; --border:#E2E8F0;
  --surface:#F8FAFD; --white:#FFFFFF;
  --blue:#3B82F6; --blue-d:#1D4ED8; --blue-s:#EFF6FF;
  --green:#009A44; --green-l:#10B981; --green-s:#ECFDF5;
  --gold:#F59E0B; --wa:#25D366; --wa-d:#128C7E;
  --r:16px; --rs:10px; --rx:7px;
  --sh:0 2px 12px rgba(7,16,31,.07),0 4px 20px rgba(7,16,31,.09);
  --shl:0 8px 40px rgba(7,16,31,.16);
  --t:all .22s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Bricolage Grotesque',sans-serif;background:var(--surface);color:var(--ink);min-height:100svh;-webkit-tap-highlight-color:transparent;overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* HEADER */
.hdr{position:sticky;top:0;z-index:60;background:var(--ink);height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.hdr-l{display:flex;align-items:center;gap:8px}
.logo-badge{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--blue),var(--green));display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.lt-name{font-family:'Instrument Serif',serif;font-size:19px;color:#fff;letter-spacing:-.3px}
.lt-pro{font-size:13px;font-weight:700;color:var(--gold);letter-spacing:.5px}
.ver-tag{font-size:10px;font-weight:700;color:var(--muted);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);padding:2px 7px;border-radius:4px}
.credit-pill{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:5px 10px;border-radius:20px;cursor:pointer;transition:var(--t)}
.credit-pill:hover{border-color:var(--gold)}
.cp-val{font-size:14px;font-weight:800;color:var(--gold)}
.cp-lbl{font-size:11px;color:var(--muted)}
.btn-topup{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;border:none;font-family:'Bricolage Grotesque',sans-serif;font-size:12px;font-weight:700;padding:7px 13px;border-radius:20px;cursor:pointer;transition:var(--t)}
.btn-topup:hover{opacity:.88;transform:translateY(-1px)}

/* HERO */
.hero{background:var(--ink);padding:36px 18px 40px;position:relative;overflow:hidden}
.hero-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 90% 70% at 95% -10%,rgba(59,130,246,.22) 0%,transparent 65%),radial-gradient(ellipse 70% 50% at -5% 110%,rgba(0,154,68,.18) 0%,transparent 60%)}
.hero-body{position:relative;z-index:1;max-width:480px}
.hero-eye{font-size:11.5px;font-weight:700;letter-spacing:.8px;color:rgba(255,255,255,.5);text-transform:uppercase;margin-bottom:14px}
.hero-h1{font-family:'Instrument Serif',serif;font-size:clamp(30px,8vw,46px);line-height:1.08;color:#fff;margin-bottom:14px}
.hero-h1 em{font-style:italic;color:#93C5FD}
.hero-p{font-size:14px;line-height:1.6;color:rgba(255,255,255,.6);margin-bottom:20px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:20px;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.75);background:rgba(255,255,255,.07)}
.chip.gr{background:var(--green);border-color:var(--green);color:#fff}

/* BARS */
.sandbox-bar{background:linear-gradient(90deg,#92400E,#B45309);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}
.sandbox-bar button{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:16px}
.free-bar{background:linear-gradient(90deg,#065F46,#047857);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}
.free-bar button{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:15px}
.queue-bar{background:var(--blue-d);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600}
.qb-spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.qb-pos{margin-left:auto;font-size:11px;opacity:.7}

/* MAIN & GRID */
.main{padding:20px 14px 100px;max-width:560px;margin:0 auto}
.grid-label{font-size:10.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sc.wide{grid-column:span 2}
.sc{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 14px;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:9px;box-shadow:var(--sh);transition:var(--t);-webkit-user-select:none;user-select:none}
.sc:hover,.sc:active{transform:translateY(-3px);box-shadow:var(--shl);border-color:var(--c,var(--blue))}
.sc-line{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--c,var(--blue));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.sc:hover .sc-line{transform:scaleX(1)}
.sc-ai{position:absolute;top:10px;right:10px;font-size:9.5px;font-weight:800;background:linear-gradient(90deg,var(--blue),var(--green-l));color:#fff;padding:2px 7px;border-radius:10px;letter-spacing:.4px}
.sc-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}
.sc-name{font-size:14px;font-weight:800;color:var(--ink);line-height:1.2}
.sc-desc{font-size:11.5px;color:var(--muted);line-height:1.5;flex:1}
.sc-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border)}
.cost{font-size:11.5px;font-weight:700;color:var(--blue);background:var(--blue-s);padding:3px 8px;border-radius:6px}
.cost.free{color:var(--green);background:var(--green-s)}
.arr{font-size:16px;color:var(--muted);transition:transform .2s}
.sc:hover .arr{transform:translateX(3px);color:var(--ink)}

/* OVERLAY & SHEET */
.overlay{display:none;position:fixed;inset:0;background:rgba(7,16,31,.65);backdrop-filter:blur(8px);z-index:100;align-items:flex-end;justify-content:center}
.overlay.open{display:flex;animation:fadeIn .18s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.sheet{background:var(--white);border-radius:24px 24px 0 0;width:100%;max-width:560px;max-height:92svh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.34,1.1,.64,1);padding-bottom:max(24px,env(safe-area-inset-bottom))}
.sheet.tall{max-height:96svh}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.pill{width:36px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 0}
.sheet-hdr{display:flex;align-items:center;gap:12px;padding:18px 18px 14px;border-bottom:1px solid var(--border)}
.sh-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.sh-title{font-family:'Instrument Serif',serif;font-size:20px;color:var(--ink)}
.sh-sub{font-size:12px;color:var(--muted);margin-top:2px}
.sh-x{margin-left:auto;width:34px;height:34px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);font-size:16px;color:var(--dim);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--t)}
.sh-x:hover{background:var(--border)}

/* OCR */
.ocr-card{display:flex;gap:10px;align-items:flex-start;background:linear-gradient(135deg,var(--blue-s),var(--green-s));border:1px solid #BFDBFE;border-radius:var(--rs);padding:12px;margin:14px 18px 10px}
.ocr-card>span{font-size:22px;flex-shrink:0;margin-top:2px}
.ocr-card strong{font-size:13.5px;font-weight:700}
.ocr-card p{font-size:11.5px;color:var(--muted);margin-top:3px}
.ocr-btns{display:flex;gap:8px;padding:0 18px 10px}
.ocr-btns button{flex:1;padding:10px;border-radius:var(--rs);border:1.5px solid var(--border);font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:700;cursor:pointer;background:var(--white);color:var(--ink);transition:var(--t)}
.ocr-btns button:hover{border-color:var(--blue);color:var(--blue)}
.bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:0 18px 6px}
.bar-fill{height:100%;width:0%;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--green-l));transition:width .3s}
#ocrStatusTxt{font-size:12px;color:var(--muted);font-weight:600;padding:0 18px;display:block;margin-bottom:8px}
#ocrResultBox{margin:0 18px 10px;background:var(--surface);border-radius:var(--rs);padding:12px}
.ocr-rhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:12px;font-weight:700;color:var(--dim)}
.conf{color:var(--green)}
#ocrTxt{width:100%;border:1.5px solid var(--border);border-radius:var(--rx);padding:10px;font-family:'Bricolage Grotesque',sans-serif;font-size:13px;color:var(--ink);resize:vertical;min-height:80px;outline:none}
#ocrTxt:focus{border-color:var(--blue)}
.ocr-rbtns{display:flex;gap:8px;margin-top:8px}
#btnUseOcr{flex:1;padding:9px;border-radius:var(--rx);background:var(--blue);color:#fff;border:none;font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:700;cursor:pointer}
#btnDiscardOcr{padding:9px 14px;border-radius:var(--rx);background:var(--surface);color:var(--muted);border:1.5px solid var(--border);font-family:'Bricolage Grotesque',sans-serif;font-size:13px;cursor:pointer}
.ocr-divider{text-align:center;position:relative;margin:10px 18px 0;font-size:11.5px;color:var(--muted);font-weight:600}
.ocr-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.ocr-divider span{background:#fff;padding:0 10px;position:relative}

/* FORM */
.form-body{padding:16px 18px;display:flex;flex-direction:column;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fl{font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--dim)}
.fi,.fs,.fta{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:15px;color:var(--ink);background:var(--white);outline:none;transition:var(--t);-webkit-appearance:none}
.fi:focus,.fs:focus,.fta:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.fta{resize:vertical;min-height:88px}
.fi::placeholder,.fta::placeholder{color:var(--muted)}
.form-foot{padding:0 18px 6px;display:flex;flex-direction:column;gap:10px}
.btn-gen{width:100%;padding:16px;background:linear-gradient(135deg,var(--ink2),var(--blue-d));color:#fff;border:none;border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 4px 18px rgba(29,78,216,.3);transition:var(--t)}
.btn-gen:hover{transform:translateY(-2px);box-shadow:0 6px 26px rgba(29,78,216,.4)}
.btn-gen:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn-wa-direct{width:100%;padding:15px;background:linear-gradient(135deg,var(--wa),var(--wa-d));color:#fff;border:none;border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:15.5px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 4px 14px rgba(37,211,102,.3);transition:var(--t)}
.btn-wa-direct:hover{transform:translateY(-2px)}
.btn-template{width:100%;padding:12px 16px;background:#f8faff;color:#1e40af;border:1.5px solid #93c5fd;border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--t)}
.btn-template:hover{background:#dbeafe;border-color:#3b82f6;transform:translateY(-1px)}
.btn-template-ocr{display:block;width:calc(100% - 36px);margin:0 18px 10px;padding:10px 14px;background:#f0f6ff;color:#1e40af;border:1.5px solid #bfdbfe;border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:700;cursor:pointer;text-align:center;transition:var(--t)}
.btn-template-ocr:hover{background:#dbeafe;border-color:#3b82f6}
#templateBanner,.template-banner-ocr{margin:0 18px 10px;padding:9px 14px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1.5px solid #93c5fd;border-radius:var(--rs);font-size:13px;color:#1e40af;font-weight:600;display:flex;align-items:center;gap:8px}

/* ============================================================
   ADIÇÕES — Estilização de formulários sem classes específicas
   (Adicionado para resolver inputs sem estilo no modal)
   ============================================================ */

/* Todos os divs filhos diretos de .form-body viram form-groups */
.form-body > div {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Estilizar inputs, selects e textareas dentro de .form-body 
   mesmo sem as classes .fi, .fs, .fta */
.form-body input[type="text"],
.form-body input[type="email"],
.form-body input[type="tel"],
.form-body input[type="number"],
.form-body input[type="date"],
.form-body select,
.form-body textarea {
  width: 100%;
  padding: 13px 15px;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 15px;
  color: var(--ink);
  background: var(--white);
  outline: none;
  transition: var(--t);
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
}

.form-body input:focus,
.form-body select:focus,
.form-body textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, .1);
}

.form-body input::placeholder,
.form-body textarea::placeholder {
  color: var(--muted);
}

/* Select com seta customizada */
.form-body select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 40px;
  cursor: pointer;
}

/* Labels dentro de .form-body */
.form-body label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .7px;
  text-transform: uppercase;
  color: var(--dim);
  display: block;
  margin-bottom: 2px;
}

/* Grid 2 colunas dentro de .form-body */
.form-body .fg-row,
.form-body .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* Input pequeno */
.form-body input[type="number"].small,
.form-body .fi-small {
  width: 80px;
  text-align: center;
}

/* Estados de erro */
.form-body input.error,
.form-body select.error,
.form-body textarea.error {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

/* LOADER STEPS */
.loader-wrap{display:none;flex-direction:column;align-items:center;padding:24px 18px;gap:14px}
.loader-wrap.show{display:flex;animation:fadeIn .2s}
.lstep{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--muted);transition:color .3s}
.lstep.active{color:var(--blue)}.lstep.done{color:var(--green)}
.lnum{width:22px;height:22px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;transition:background .3s}
.lstep.active .lnum{background:var(--blue);color:#fff;box-shadow:0 0 0 3px rgba(59,130,246,.2)}
.lstep.done .lnum{background:var(--green);color:#fff}
.l-spin{width:50px;height:50px;border:4px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.l-steps{display:flex;flex-direction:column;gap:7px;width:100%;max-width:240px}
.ls{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--muted);transition:var(--t)}
.ls.done{color:var(--green)}.ls.active{color:var(--blue)}
.ls-dot{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0;transition:var(--t)}
.ls.done .ls-dot{background:var(--green)}.ls.active .ls-dot{background:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.2);animation:pd 1s infinite}
@keyframes pd{0%,100%{transform:scale(1)}50%{transform:scale(1.5)}}

/* RESULT */
.result-hdr{display:flex;align-items:center;gap:10px;padding:18px 18px 12px;border-bottom:1px solid var(--border)}
.res-ok{font-size:15px;font-weight:800;color:var(--green)}
.res-model{font-size:10.5px;color:var(--muted);background:var(--surface);border:1px solid var(--border);padding:2px 8px;border-radius:6px;font-weight:600}
.res-meta{padding:10px 18px;font-size:12px;color:var(--muted);background:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:14px;flex-wrap:wrap}
.res-preview{padding:0;font-size:13.5px;line-height:1.75;color:var(--ink);border-bottom:1px solid var(--border);background:#d1d5db;}
/* Header das tabs do preview de resultado */
.res-preview-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#f8fafd;border-bottom:1px solid #e2e8f0;}
.res-preview-tabs{display:flex;gap:4px;}
.res-tab{padding:5px 11px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;font-size:12px;font-weight:700;cursor:pointer;color:#475569;font-family:inherit;transition:all 0.15s;}
.res-tab.active{background:#07101F;color:#fff;border-color:#07101F;}
.res-preview-stats{font-size:11px;color:#94a3b8;font-weight:600;}
/* Frame A4 no modal de resultado */
.res-a4-wrap{overflow:auto;max-height:290px;display:flex;justify-content:center;padding:16px;background:#d1d5db;}
.res-a4-frame{width:100%;min-height:220px;border:none;background:#fff;box-shadow:0 3px 16px rgba(0,0,0,0.15);display:block;}

.res-preview h1{font-size:17px;font-weight:800;margin:12px 0 6px}
.res-preview h2{font-size:15px;font-weight:700;margin:10px 0 5px}
.res-preview h3{font-size:13.5px;font-weight:700;margin:8px 0 4px}
.res-preview table{width:100%;border-collapse:collapse;margin:8px 0;font-size:12px}
.res-preview td,.res-preview th{border:1px solid var(--border);padding:6px 8px;text-align:left}
.res-preview th{background:var(--surface);font-weight:700}
.res-actions{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:8px;padding:14px 18px}
.res-actions button{padding:12px 8px;border-radius:var(--rs);border:none;font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:var(--t)}
.res-actions button:first-child,.res-actions button:nth-child(2){background:var(--surface);color:var(--dim);border:1.5px solid var(--border)}
.res-actions button:first-child:hover,.res-actions button:nth-child(2):hover{background:var(--border)}
.wa-btn{background:linear-gradient(135deg,var(--wa),var(--wa-d));color:#fff;box-shadow:0 3px 12px rgba(37,211,102,.3)}
.wa-btn:hover{transform:translateY(-2px);box-shadow:0 5px 18px rgba(37,211,102,.4)}

/* PRICING */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px;padding:16px 18px}
.pkg{border:1.5px solid var(--border);border-radius:var(--r);padding:14px 10px;cursor:pointer;position:relative;text-align:center;transition:var(--t);background:var(--white)}
.pkg:hover,.pkg.sel{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.12);background:#F8FBFF}
.pkg.popular{border-color:var(--blue);background:linear-gradient(135deg,var(--blue-s),var(--green-s))}
.pkg-badge{position:absolute;top:-9px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:9px;font-weight:800;padding:2px 8px;border-radius:10px;white-space:nowrap}
.pkg-name{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.pkg-price{font-size:16px;font-weight:900;color:var(--ink);margin-bottom:4px}
.pkg-cr{font-size:11px;font-weight:700;color:var(--blue);margin-bottom:4px}
.pkg-per{font-size:10px;color:var(--muted)}
#mpesaSection{padding:16px 18px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:14px}
.mp-hdr{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#E6F7EE,#D1FAE5);border-radius:var(--rs);padding:12px;border:1px solid #A7F3D0}
.mp-logo{width:40px;height:40px;border-radius:10px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;flex-shrink:0}
.mp-hdr strong{font-size:14px;font-weight:800}
.mp-hdr p{font-size:11.5px;color:var(--muted);margin-top:2px}
.field-lbl{font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--dim)}
.phone-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--rs);overflow:hidden;transition:var(--t)}
.phone-wrap:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,154,68,.1)}
.phone-wrap>span{padding:13px 14px;background:var(--surface);border-right:1.5px solid var(--border);font-size:14px;font-weight:700;color:var(--dim);white-space:nowrap}
.phone-wrap input{flex:1;padding:13px 14px;border:none;outline:none;font-family:'Bricolage Grotesque',sans-serif;font-size:15px;color:var(--ink)}
.pay-sum{background:var(--surface);border-radius:var(--rs);padding:12px;font-size:13px;color:var(--dim);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.pay-sum strong{font-weight:800;color:var(--ink)}
.btn-pay{width:100%;padding:16px;background:linear-gradient(135deg,var(--green),#047857);color:#fff;border:none;border-radius:var(--rs);font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:800;cursor:pointer;box-shadow:0 4px 16px rgba(0,154,68,.3);transition:var(--t)}
.btn-pay:disabled{opacity:.45;cursor:not-allowed}
.btn-pay:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,154,68,.4)}
.mp-note{font-size:11px;color:var(--muted);text-align:center;line-height:1.5}

/* NOTIFICATIONS */
.notif-stack{position:fixed;bottom:88px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:8px;z-index:300;pointer-events:none;align-items:center}
.notif{background:var(--ink);color:#fff;padding:11px 20px;border-radius:30px;font-size:13.5px;font-weight:700;white-space:nowrap;box-shadow:0 4px 20px rgba(7,16,31,.4);animation:notifIn .3s ease;pointer-events:auto}
.notif.info{background:var(--blue-d)}
.notif.warn{background:#92400E}
.notif.success{background:var(--green)}
.notif.error{background:#B91C1C}
@keyframes notifIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* FAB */
.fab{position:fixed;bottom:22px;right:18px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--wa),var(--wa-d));color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(37,211,102,.5);z-index:80;transition:var(--t)}
.fab:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.6)}
/* FAB Logout — aparece só em mobile quando autenticado */
.fab-logout{
  bottom:86px; /* acima do FAB WhatsApp */
  background:linear-gradient(135deg,#EF4444,#B91C1C);
  box-shadow:0 4px 20px rgba(239,68,68,.45);
  border:none;cursor:pointer;font-size:22px;
}
.fab-logout:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(239,68,68,.6)}
@media(min-width:520px){.fab-logout{display:none !important;}}

/* ── AVATAR COM DROPDOWN (utilizador autenticado) ────────────────────────── */
.usr-avatar-wrap {
  position: relative;
  flex-shrink: 0;
  cursor: pointer;
}
.usr-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: linear-gradient(135deg, #3B82F6, #1D4ED8);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 15px; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,.25);
  transition: border-color .2s;
}
.usr-avatar-wrap:hover .usr-avatar { border-color: rgba(255,255,255,.6); }
.usr-dropdown {
  display: none; flex-direction: column; gap: 4px;
  position: absolute; top: calc(100% + 10px); right: 0;
  background: #fff; border: 1px solid #e5e7eb; border-radius: 14px;
  box-shadow: 0 8px 32px rgba(7,16,31,.18);
  padding: 14px 16px; min-width: 200px; z-index: 200;
  animation: ddIn .18s ease;
}
.usr-dropdown.open { display: flex; }
@keyframes ddIn { from { opacity:0; transform:translateY(-6px) } to { opacity:1; transform:translateY(0) } }
.usr-dd-name { font-size: 14px; font-weight: 700; color: #07101f; }
.usr-dd-sub  { font-size: 11px; color: #94a3b8; word-break: break-all; }
.usr-dd-sep  { border: none; border-top: 1px solid #f1f5f9; margin: 8px 0 4px; }
.usr-dd-btn  {
  background: #FEF2F2; border: none; border-radius: 8px;
  color: #EF4444; font-size: 13px; font-weight: 600;
  padding: 8px 12px; cursor: pointer; text-align: left;
  transition: background .15s;
}
.usr-dd-btn:hover { background: #FEE2E2; }

/* ── HEADER RESPONSIVO ───────────────────────────────────────────────────── */

/* ── HEADER — layout completo sem inline styles ─────────────────────────────── */

/* ver-tag: sempre escondida */
.ver-tag { display: none; }

/* ── HEADER — layout responsivo ─────────────────────────────────────────── */
.hdr { flex-wrap: nowrap; width: 100%; box-sizing: border-box; }
.hdr-l { flex: 0 0 auto; display: flex; align-items: center; gap: 8px; }
.hdr-r { flex: 1 1 auto; display: flex; align-items: center; justify-content: flex-end;
          gap: 8px; min-width: 0; }

/* Botão Entrar */
.btn-auth {
  padding: 8px 16px;
  background: linear-gradient(135deg,#3B82F6,#1D4ED8);
  color: #fff; border: none; border-radius: 10px;
  font-size: 13px; font-weight: 700; cursor: pointer;
  white-space: nowrap; flex-shrink: 0;
}
.btn-auth:hover { opacity: .88; }

/* Área autenticada */
.user-area {
  display: none;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;           /* não deixar encolher: os ícones têm prioridade */
}
.user-area.visible { display: flex; }

/* user-menu: envolve o avatar + dropdown — precisa de position:relative */
.user-menu {
  display: flex; align-items: center;
  position: relative;       /* âncora do dropdown absoluto */
  flex-shrink: 0;
}

/* Botão arquivo */
.btn-icon {
  padding: 7px 10px;
  background: rgba(255,255,255,.08);
  color: #fff; border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; font-size: 15px;
  cursor: pointer; flex-shrink: 0;
  transition: var(--t); line-height: 1;
}
.btn-icon:hover { background: rgba(255,255,255,.15); }

/* Créditos — compacto */
.credit-pill { flex-shrink: 0; }
.cp-icon { font-size: 13px; }

/* ── MOBILE ≤ 520px ──────────────────────────────────────────────────────── */
@media (max-width: 520px) {
  .hdr { padding: 0 10px; height: 52px; }
  .hdr-l { gap: 5px; }
  .hdr-r { gap: 5px; }
  .user-area { gap: 5px; }

  .logo-badge { width: 28px; height: 28px; font-size: 15px; }
  .lt-name { font-size: 15px; }
  .lt-pro  { font-size: 10px; }

  .btn-auth { padding: 6px 12px; font-size: 12px; }

  .credit-pill { padding: 4px 8px; gap: 3px; }
  .cp-val { font-size: 13px; }
  .cp-lbl { display: none; }        /* esconder "cr" em mobile */

  .btn-topup { padding: 5px 10px; font-size: 11px; border-radius: 16px; }
  .btn-icon  { padding: 5px 9px; font-size: 14px; }

  .usr-dropdown { right: 0; min-width: 175px; }
}

/* ── MOBILE ≤ 400px — esconder "+ Comprar" ───────────────────────────────── */
@media (max-width: 400px) {
  .btn-topup { display: none; }
}

/* ── MOBILE ≤ 340px — esconder arquivo (Galaxy Fold, etc.) ──────────────── */
@media (max-width: 340px) {
  #btnHistory { display: none; }
  .lt-name { font-size: 13px; }
  .hdr { padding: 0 8px; }
}


/* ── PRINT / EXPORT — CSS unificado screen + print ───────────────────────────
   Resolve divergência entre preview em ecrã (Inter/Bricolage) e PDF exportado (Times/Calibri)
   Todas as variáveis de documento definidas aqui para consistência total
──────────────────────────────────────────────────────────────────────────────*/
:root {
  /* Fontes de documento — usadas em preview iframe E no export Word/PDF */
  --doc-font-serif:  'Times New Roman', Georgia, serif;
  --doc-font-sans:   'Calibri', 'Segoe UI', Arial, sans-serif;
  --doc-font-mono:   'Courier New', Courier, monospace;

  /* Tipografia de documento */
  --doc-size-base:   12pt;
  --doc-size-h1:     18pt;
  --doc-size-h2:     14pt;
  --doc-size-h3:     12pt;
  --doc-line-height: 1.5;

  /* Página A4 */
  --doc-page-w:      210mm;
  --doc-page-h:      297mm;
  --doc-margin-top:  25mm;
  --doc-margin-side: 22mm;
  --doc-margin-bot:  20mm;
  --doc-margin-left: 25mm;

  /* Cores de documento */
  --doc-color-title: #1F3864;
  --doc-color-h2:    #2E74B5;
  --doc-color-body:  #000000;
  --doc-color-muted: #555555;
  --doc-border:      #BFBFBF;
  --doc-table-head:  #D9E2F3;
}

/* Aplicar consistência ao preview A4 dentro do iframe */
@media screen {
  .ed-a4-frame { border: none; display: block; }
}

/* Estilos de impressão globais — quando o utilizador manda imprimir a página */
@media print {
  /* Esconder UI da aplicação */
  .hdr, .fab, .fab-logout, .notif-stack,
  #editorOverlay, #resultOverlay, #historyOverlay,
  #cookieBanner, #guestBar, footer { display: none !important; }

  /* A4 */
  @page {
    size: 210mm 297mm;
    margin: 25mm 22mm 20mm 25mm;
  }

  body {
    font-family: var(--doc-font-serif);
    font-size: var(--doc-size-base);
    line-height: var(--doc-line-height);
    color: var(--doc-color-body);
    background: white;
  }

  h1, h2, h3, h4 { page-break-after: avoid; break-after: avoid; }
  table { page-break-inside: avoid; break-inside: avoid; }
  p { orphans: 3; widows: 3; }

  /* Forçar cores de texto em preto para impressão */
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}
