/* Omne English Lab — UI inspirado no FileDrop (Open Sans + paleta/variáveis equivalentes) */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#eff1f3;--card:#ffffff;--input:#f7f8fa;
  --accent:#1e3250;--accent-l:#2d4a6f;--accent-bg:rgba(30,50,80,.06);--accent-dk:#0f1a2e;
  --ink:#111111;--ink-l:#333333;--muted:#6b7280;--muted-l:#94a3b8;
  --line:#cbd5e1;--line-s:rgba(15,23,42,.05);--focus:rgba(30,50,80,.15);
  --ok:#16a34a;--ok-bg:#dcfce7;--warn:#f59e0b;--warn-bg:#fef3c7;
  --err:#ef4444;--err-bg:#fee2e2;--info:#0ea5e9;--info-bg:#e0f2fe;
  --purple:#3b5998;--purple-bg:rgba(59,89,152,.07);
  --r:14px;--rs:8px;--rp:24px;
  --sh-s:0 1px 2px rgba(0,0,0,.03);
  --sh:0 3px 5px -1px rgba(0,0,0,.06),0 1px 3px -1px rgba(0,0,0,.04);
  --sh-m:0 6px 10px -2px rgba(0,0,0,.07),0 3px 5px -3px rgba(0,0,0,.04);
  --sh-l:0 12px 18px -4px rgba(0,0,0,.08),0 5px 8px -4px rgba(0,0,0,.04);
  --t:.2s ease;
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
}
html,body{height:100%}
body{font-family:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:15px;line-height:1.5;color:var(--ink);background:var(--bg);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;padding-top:var(--safe-t);padding-bottom:var(--safe-b)}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}

/* Layout */
.container{max-width:1150px;margin:0 auto;padding:20px 20px 26px}
.top-bar{max-width:1150px;margin:0 auto;padding:22px 20px 0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;color:var(--accent-dk);user-select:none;letter-spacing:-.01em}
.brand .dots{display:flex;gap:6px;align-items:center}
.dot{background:var(--accent);border-radius:999px}
.dot.l{width:12px;height:12px}.dot.s{width:10px;height:10px}
.subbrand{font-size:.72rem;color:var(--muted-l);font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.top-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* Buttons */
.btn{font-family:inherit;font-size:.82rem;font-weight:700;padding:8px 18px;border:none;border-radius:var(--rp);cursor:pointer;transition:all var(--t);display:inline-flex;align-items:center;gap:8px;text-decoration:none;line-height:1;white-space:nowrap}
.btn.primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(30,50,80,.25)}
.btn.primary:hover{background:var(--accent-l);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--input);color:var(--ink);border-color:var(--accent)}
.btn.danger{background:var(--err);color:#fff}
.btn.danger:hover{background:#dc2626}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Pills / tags */
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.02em;border:1px solid var(--line);background:var(--input);color:var(--muted)}
.tag.ok{background:var(--ok-bg);border-color:#86efac;color:var(--ok)}
.tag.warn{background:var(--warn-bg);border-color:#fcd34d;color:var(--warn)}
.tag.err{background:var(--err-bg);border-color:#fecaca;color:var(--err)}
.tag.info{background:var(--info-bg);border-color:#93c5fd;color:var(--info)}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-s);overflow:hidden}
.card.hov{transition:all var(--t)}
.card.hov:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--sh-m)}
.card-head{padding:14px 18px;border-bottom:1px solid var(--line);background:var(--input);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-size:.85rem;font-weight:800;color:var(--ink-l)}
.card-sub{font-size:.78rem;color:var(--muted);font-weight:600}
.card-body{padding:18px}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.col-12{grid-column:span 12}
.col-8{grid-column:span 8}
.col-6{grid-column:span 6}
.col-4{grid-column:span 4}
.col-3{grid-column:span 3}

@media (max-width:980px){
  .col-8,.col-6,.col-4,.col-3{grid-column:span 12}
}

/* Tabs */
.tabs{display:flex;gap:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s)}
.tab{flex:1;padding:14px 12px;font-family:inherit;font-size:.84rem;font-weight:800;background:none;border:none;border-bottom:3px solid transparent;color:var(--muted);cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;gap:8px}
.tab:hover{color:var(--ink);background:var(--input)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-bg)}

/* Inputs */
.input,.select,.textarea{width:100%;padding:10px 12px;font-family:inherit;font-size:.86rem;background:var(--input);border:1px solid var(--line);border-radius:var(--rs);color:var(--ink);outline:none;transition:all var(--t)}
.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus)}
.textarea{min-height:92px;resize:vertical}
.label{font-size:.78rem;font-weight:800;color:var(--muted);letter-spacing:.01em;margin-bottom:6px;display:block}
.help{font-size:.78rem;color:var(--muted);margin-top:6px}

/* Lists */
.list{display:flex;flex-direction:column;gap:10px}
.item{border:1px solid var(--line);border-radius:var(--rs);background:var(--card);padding:12px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.item:hover{border-color:var(--accent)}
.item .meta{min-width:0}
.item .name{font-weight:800;font-size:.88rem;color:var(--ink-l)}
.item .desc{font-size:.78rem;color:var(--muted);margin-top:2px}
.item .actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

/* Pronunciation */
.pron-target{font-size:1.05rem;font-weight:800;color:var(--ink-l);letter-spacing:-.01em}
.pron-target.small{font-size:.98rem}
.wordline{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.word{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:var(--input);font-size:.82rem;font-weight:800;color:var(--muted);cursor:pointer;user-select:none}
.word.ok{background:var(--ok-bg);border-color:#86efac;color:var(--ok)}
.word.err{background:var(--err-bg);border-color:#fecaca;color:var(--err)}
.word.warn{background:var(--warn-bg);border-color:#fcd34d;color:var(--warn)}
.word.active{outline:3px solid var(--focus);border-color:var(--accent)}

.score{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.score .big{font-size:1.35rem;font-weight:900;color:var(--accent)}
.score .small{font-size:.78rem;color:var(--muted);font-weight:700}

.kpi{display:flex;align-items:flex-end;gap:10px}
.kpi .n{font-size:1.35rem;font-weight:900;color:var(--accent)}
.kpi .t{font-size:.72rem;font-weight:800;color:var(--muted);letter-spacing:.02em}

.hr{height:1px;background:var(--line);margin:14px 0}

/* Modal */
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:22px;z-index:50}
.modal-back.on{display:flex}
.modal{width:min(720px,100%);background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-l);overflow:hidden}
.modal-head{padding:14px 18px;border-bottom:1px solid var(--line);background:var(--input);display:flex;align-items:center;justify-content:space-between;gap:10px}
.modal-title{font-size:.86rem;font-weight:900;color:var(--ink-l)}
.modal-body{padding:18px}

/* Toast */
.toast{position:fixed;right:16px;bottom:16px;z-index:60;display:flex;flex-direction:column;gap:10px}
.toast .t{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--r);box-shadow:var(--sh-m);padding:12px 12px;max-width:420px}
.toast .t .h{font-weight:900;font-size:.84rem;color:var(--ink-l)}
.toast .t .p{font-size:.78rem;color:var(--muted);margin-top:2px}

/* Footer note */
.note{font-size:.78rem;color:var(--muted)}
.note b{color:var(--ink-l)}

/* Small utility */
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.row > .grow{flex:1;min-width:180px}
.m0{margin:0}.mt6{margin-top:6px}.mt10{margin-top:10px}.mt14{margin-top:14px}.mt18{margin-top:18px}



/* Icons */
.ico{width:18px;height:18px;display:inline-block;flex:0 0 auto;color:currentColor}
.ico.sm{width:16px;height:16px}

/* Input with icon (wrapper div styled like input) */
.input.with-ico{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--input);border:1px solid var(--line);border-radius:var(--rs);transition:all var(--t)}
.input.with-ico:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus)}
.input.with-ico input{border:none;outline:none;background:transparent;width:100%;font:inherit;font-size:.86rem;color:var(--ink)}
.input.with-ico input::placeholder{color:var(--muted-l);font-weight:600}

/* Lessons UI */
.filters .field{margin-bottom:10px}
.scroll{max-height:560px;overflow:auto;padding-right:4px}
.lesson-row.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus)}
.lesson-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.02em;border:1px solid var(--line);background:var(--input);color:var(--muted)}
.pill.ghost{background:transparent}
.pill.ok{background:var(--ok-bg);border-color:#86efac;color:var(--ok)}
.lesson-content h3{font-size:1.05rem;font-weight:900;color:var(--ink-l);margin:10px 0 8px}
.lesson-content h4{font-size:.95rem;font-weight:900;color:var(--ink-l);margin:10px 0 8px}
.lesson-content p{margin:8px 0;color:var(--ink-l)}
.lesson-content ul{margin:8px 0 10px 18px}
.lesson-content li{margin:6px 0;color:var(--ink-l)}
