/* MasterInMinutes™ v9.0 — Premium White Theme */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-tap-highlight-color: transparent; }
body { font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif; background: #f8f8f6; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, textarea, select { font-family: inherit; -webkit-appearance: none; appearance: none; outline: none; }
a { text-decoration: none; color: inherit; }

:root {
  --white:     #ffffff;
  --black:     #111111;
  --text:      #1a1a1a;
  --text-sub:  #6b7280;
  --text-muted:#9ca3af;
  --bg:        #f8f8f6;
  --bg2:       #f3f3f0;
  --border:    #e5e7eb;
  --border-soft:#eeede9;

  /* Orange accent — primary brand colour */
  --orange:    #f97316;
  --orange2:   #ea580c;
  --orange-light:#fff7ed;
  --orange-mid:#fed7aa;

  /* Green — success / done */
  --green:     #16a34a;
  --green-bg:  #f0fdf4;
  --green-border:#bbf7d0;

  /* Red — error / warning */
  --red:       #dc2626;
  --red-bg:    #fef2f2;

  /* Blue — info */
  --blue:      #2563eb;
  --blue-bg:   #eff6ff;

  /* Gradients */
  --grad-orange: linear-gradient(135deg,#f97316,#ea580c);
  --grad-hero:   linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);

  --shadow:    0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --shadow-md: 0 4px 12px rgba(0,0,0,.08);
  --shadow-lg: 0 10px 30px rgba(0,0,0,.1);

  --radius:    12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
}

/* ═══════════════════════════════
   GATE (login wall)
═══════════════════════════════ */
#mim-app { min-height: 100vh; }
.mim-gate {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:100vh; padding:40px 24px; text-align:center; background:var(--white);
}
.mim-gate-icon { font-size:56px; margin-bottom:16px; }
.mim-gate-title { font-family:'Syne',sans-serif; font-size:28px; font-weight:800; color:var(--black); margin-bottom:6px; }
.mim-gate-sub { font-size:14px; color:var(--text-sub); margin-bottom:24px; }
.mim-gate-btns { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }

/* ═══════════════════════════════
   APP SHELL
═══════════════════════════════ */
.mim-app { display:flex; min-height:100vh; background:var(--bg); }

/* ═══════════════════════════════
   SIDEBAR (desktop only)
═══════════════════════════════ */
.mim-sidebar {
  width:240px; flex-shrink:0;
  background:var(--white);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  height:100vh; position:sticky; top:0;
  overflow-y:auto; z-index:300;
  transition:transform .25s ease;
}
.mim-sb-header { padding:0; border-bottom:1px solid var(--border); }
.mim-sb-brand { display:flex; align-items:center; gap:10px; padding:20px 18px 16px; }
.mim-sb-brand > span { font-size:24px; flex-shrink:0; }
.mim-sb-brand-name { font-family:'Syne',sans-serif; font-size:13px; font-weight:800; color:var(--black); letter-spacing:-.01em; }
.mim-sb-brand-tag { font-size:10px; color:var(--text-muted); margin-top:1px; }

.mim-sb-user {
  display:flex; align-items:center; gap:10px;
  padding:12px 18px; border-top:1px solid var(--border-soft);
}
.mim-avatar {
  width:36px; height:36px; border-radius:50%;
  background:var(--grad-orange); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:800; flex-shrink:0;
}
.mim-sb-uname { font-size:13px; font-weight:700; color:var(--text); }
.mim-sb-plan { font-size:11px; color:var(--text-muted); margin-top:1px; }

.mim-xp-block { padding:12px 18px; border-top:1px solid var(--border-soft); }
.mim-xp-row { display:flex; justify-content:space-between; align-items:center; font-size:11px; font-weight:700; color:var(--text-sub); margin-bottom:6px; }
.mim-orange { color:var(--orange); }
.mim-xpbar { height:5px; background:var(--bg2); border-radius:99px; overflow:hidden; margin-bottom:4px; }
.mim-xpbar > div { height:100%; border-radius:99px; background:var(--grad-orange); transition:width .7s ease; }
.mim-xp-next { font-size:10px; color:var(--text-muted); }

.mim-sb-nav { flex:1; padding:10px 10px; }
.mim-sb-sep { height:1px; background:var(--border-soft); margin:6px 0; }
.mim-sb-btn {
  display:flex; align-items:center; gap:9px;
  padding:9px 10px; border-radius:9px;
  font-size:13px; font-weight:500; color:var(--text-sub);
  cursor:pointer; width:100%; text-align:left; margin-bottom:2px;
  transition:all .15s;
}
.mim-sb-btn:hover { background:var(--bg2); color:var(--text); }
.mim-sb-btn.active { background:var(--orange-light); color:var(--orange2); font-weight:700; }

.mim-sb-footer { padding:14px 18px; border-top:1px solid var(--border); }
.mim-credits {
  background:var(--bg2); border-radius:10px;
  padding:10px 12px; margin-bottom:10px;
  border:1px solid var(--border);
}
.mim-credits-lbl { font-size:10px; font-weight:800; color:var(--orange); text-transform:uppercase; letter-spacing:.06em; display:block; margin-bottom:3px; }
.mim-credits-val { font-size:24px; font-weight:900; color:var(--black); line-height:1; }
.mim-credits-sub { font-size:10px; color:var(--text-muted); margin-top:2px; }
.mim-upgrade-btn {
  display:flex; align-items:center; justify-content:center;
  background:var(--grad-orange); color:#fff;
  padding:10px; border-radius:9px; font-size:13px; font-weight:700;
  box-shadow:0 2px 8px rgba(249,115,22,.3);
}

/* ═══════════════════════════════
   MAIN AREA
═══════════════════════════════ */
.mim-main { flex:1; display:flex; flex-direction:column; min-width:0; overflow:hidden; }
.mim-topbar {
  background:var(--white); border-bottom:1px solid var(--border);
  height:56px; display:flex; align-items:center;
  padding:0 20px; gap:12px;
  position:sticky; top:0; z-index:200; flex-shrink:0;
  box-shadow:var(--shadow);
}
.mim-hamburger {
  width:36px; height:36px; border-radius:8px;
  border:1px solid var(--border);
  display:none; align-items:center; justify-content:center;
  font-size:18px; color:var(--text); flex-shrink:0;
}
.mim-topbar-title { font-family:'Syne',sans-serif; font-size:15px; font-weight:800; flex:1; color:var(--black); }
.mim-topbar-right { margin-left:auto; }
.mim-streak-pill {
  display:inline-flex; align-items:center; gap:5px;
  background:#fff7ed; border:1px solid var(--orange-mid);
  border-radius:99px; padding:5px 12px;
  font-size:13px; font-weight:700; color:#c2410c;
}
.mim-content { flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; }

/* ═══════════════════════════════
   PAGES
═══════════════════════════════ */
.mim-page { display:none; padding:22px; padding-bottom:100px; animation:mimIn .2s ease; }
.mim-page.active { display:block; }
.mim-page-chat { display:none; padding:0; }
.mim-page-chat.active { display:flex; flex-direction:column; height:calc(100vh - 56px); }
@keyframes mimIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.mim-page-title { font-family:'Syne',sans-serif; font-size:22px; font-weight:800; color:var(--black); margin-bottom:4px; }
.mim-page-sub { font-size:13px; color:var(--text-sub); margin-bottom:18px; }

/* ═══════════════════════════════
   HOME HERO
═══════════════════════════════ */
.mim-hero {
  background:var(--grad-hero); color:#fff;
  border-radius:var(--radius-xl); padding:22px;
  margin-bottom:18px;
}
.mim-hero-greeting { font-family:'Syne',sans-serif; font-size:21px; font-weight:800; margin-bottom:4px; }
.mim-hero-sub { font-size:13px; color:rgba(255,255,255,.65); margin-bottom:16px; }
.mim-hero-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.mim-hstat { background:rgba(255,255,255,.08); border-radius:10px; padding:10px 8px; text-align:center; }
.mim-hstat-val { font-size:20px; font-weight:800; line-height:1; margin-bottom:3px; }
.mim-hstat-lbl { font-size:10px; color:rgba(255,255,255,.5); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }

/* Ask AI quick box on home */
.mim-home-ask {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--radius-lg); padding:16px;
  margin-bottom:18px; box-shadow:var(--shadow);
}
.mim-home-ask-label { font-size:11px; font-weight:800; color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.mim-home-ask-row { display:flex; gap:8px; }
.mim-home-ask-inp {
  flex:1; background:var(--bg); border:1.5px solid var(--border);
  border-radius:9px; padding:10px 13px; font-size:14px;
  color:var(--text); font-family:inherit;
}
.mim-home-ask-inp:focus { border-color:var(--orange); }
.mim-home-ask-btn {
  width:42px; height:42px; border-radius:9px;
  background:var(--grad-orange); color:#fff;
  font-size:18px; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; box-shadow:0 2px 6px rgba(249,115,22,.3);
}

/* Goal + streak row */
.mim-goal-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:18px; }
.mim-goal-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius); padding:14px;
  box-shadow:var(--shadow);
}
.mim-goal-card-icon { font-size:22px; margin-bottom:6px; }
.mim-goal-card-val { font-size:22px; font-weight:800; color:var(--black); line-height:1; }
.mim-goal-card-lbl { font-size:11px; color:var(--text-sub); margin-top:3px; }

/* ═══════════════════════════════
   QUICK GRID (home actions)
═══════════════════════════════ */
.mim-quick-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:18px; }
.mim-quick-grid-3 { grid-template-columns:1fr 1fr 1fr; }
.mim-quick-card {
  border-radius:var(--radius-lg); padding:18px 14px;
  text-align:left; cursor:pointer; transition:all .2s;
  box-shadow:var(--shadow);
}
.mim-quick-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.mim-qc-icon { font-size:26px; display:block; margin-bottom:8px; }
.mim-qc-title { font-size:14px; font-weight:700; margin-bottom:2px; }
.mim-qc-sub { font-size:11px; opacity:.75; }
.mim-qc-orange { background:var(--orange-light); color:var(--orange2); border:1px solid var(--orange-mid); }
.mim-qc-dark { background:var(--black); color:#fff; }
.mim-qc-green { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.mim-qc-blue { background:var(--blue-bg); color:var(--blue); border:1px solid #bfdbfe; }

/* ═══════════════════════════════
   SECTION HEADERS
═══════════════════════════════ */
.mim-section-hdr {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:10px;
}
.mim-section-hdr > span { font-size:14px; font-weight:700; color:var(--black); }
.mim-link-btn { font-size:12px; font-weight:600; color:var(--orange); background:none; border:none; cursor:pointer; }

/* ═══════════════════════════════
   CARDS
═══════════════════════════════ */
.mim-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px;
  box-shadow:var(--shadow);
}

/* Plan badge card */
.mim-plan-badge {
  background:var(--white); border:1.5px solid var(--orange-mid);
  border-radius:var(--radius); padding:14px 16px;
  display:flex; align-items:center; gap:12px;
  margin-bottom:18px;
}
.mim-plan-badge-icon { font-size:28px; flex-shrink:0; }
.mim-plan-badge-name { font-size:16px; font-weight:800; color:var(--black); }
.mim-plan-badge-sub { font-size:12px; color:var(--text-sub); margin-top:2px; }

/* ═══════════════════════════════
   COURSE / CHAPTER ROWS
═══════════════════════════════ */
.mim-ch-row {
  display:flex; align-items:center; gap:12px;
  padding:13px 14px;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius); cursor:pointer;
  transition:all .15s; margin-bottom:8px;
  box-shadow:var(--shadow);
}
.mim-ch-row:hover { border-color:var(--orange-mid); box-shadow:var(--shadow-md); }
.mim-ch-num {
  width:38px; height:38px; border-radius:10px;
  background:var(--bg2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:800; color:var(--text-sub); flex-shrink:0;
}
.mim-ch-num.done { background:var(--green-bg); border-color:var(--green-border); color:var(--green); }
.mim-ch-title { font-size:14px; font-weight:600; color:var(--text); margin-bottom:2px; }
.mim-ch-meta { font-size:11px; color:var(--text-sub); display:flex; gap:8px; }
.mim-ch-meta span::after { content:'·'; margin-left:8px; }
.mim-ch-meta span:last-child::after { content:''; }
.mim-ch-arrow { color:var(--text-muted); font-size:18px; flex-shrink:0; }

/* Course card (board/curriculum cards) */
.mim-board-card {
  display:flex; align-items:center; gap:14px;
  padding:16px; background:var(--white);
  border:1px solid var(--border); border-radius:var(--radius-lg);
  cursor:pointer; transition:all .2s; margin-bottom:10px;
  box-shadow:var(--shadow);
}
.mim-board-card:hover { border-color:var(--orange-mid); box-shadow:var(--shadow-md); transform:translateY(-1px); }
.mim-board-icon {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; color:#fff; flex-shrink:0;
  letter-spacing:.02em;
}
.mim-board-name { font-size:15px; font-weight:700; color:var(--text); }
.mim-board-sub { font-size:12px; color:var(--text-sub); margin-top:2px; }

/* Subject chips grid */
.mim-subjects-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mim-subj-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--radius-lg); padding:18px 14px;
  cursor:pointer; transition:all .2s; text-align:center;
  box-shadow:var(--shadow);
}
.mim-subj-card:hover { border-color:var(--orange); box-shadow:var(--shadow-md); }
.mim-subj-icon { font-size:28px; margin-bottom:8px; display:block; }
.mim-subj-name { font-size:14px; font-weight:700; color:var(--text); }
.mim-subj-count { font-size:11px; color:var(--text-sub); margin-top:3px; }

/* ═══════════════════════════════
   TABS (chapter view)
═══════════════════════════════ */
.mim-tabs {
  display:flex; overflow-x:auto; -webkit-overflow-scrolling:touch;
  gap:4px; padding:0 0 12px;
  scrollbar-width:none;
}
.mim-tabs::-webkit-scrollbar { display:none; }
.mim-tab {
  padding:8px 14px; border-radius:8px; font-size:12px;
  font-weight:700; white-space:nowrap; flex-shrink:0;
  background:var(--bg2); border:1px solid var(--border);
  color:var(--text-sub); transition:all .15s;
}
.mim-tab:hover { border-color:var(--orange-mid); color:var(--text); }
.mim-tab.active { background:var(--orange); color:#fff; border-color:var(--orange); }

/* Tab panels */
.mim-tp { display:none; }
.mim-tp.active { display:block; }

/* ═══════════════════════════════
   FLASHCARD
═══════════════════════════════ */
.mim-fc {
  height:220px; perspective:1000px; cursor:pointer;
  margin-bottom:14px;
}
.mim-fc-inner {
  position:relative; width:100%; height:100%;
  transform-style:preserve-3d; transition:transform .5s ease;
}
.mim-fc.flipped .mim-fc-inner { transform:rotateY(180deg); }
.mim-fc-front, .mim-fc-back {
  position:absolute; inset:0; border-radius:var(--radius-lg);
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:24px; text-align:center;
  box-shadow:var(--shadow-md);
}
.mim-fc-front { color:#fff; }
.mim-fc-back {
  background:var(--white); color:var(--text);
  transform:rotateY(180deg);
  border:1.5px solid var(--border);
}

/* ═══════════════════════════════
   QUIZ
═══════════════════════════════ */
.mim-qopt {
  display:flex; align-items:center; gap:12px;
  padding:13px 15px; background:var(--white);
  border:1.5px solid var(--border); border-radius:10px;
  cursor:pointer; text-align:left; width:100%;
  font-size:14px; color:var(--text); font-weight:500;
  transition:all .15s; margin-bottom:9px;
  font-family:inherit; box-shadow:var(--shadow);
}
.mim-qopt:hover:not(:disabled) { border-color:var(--orange); box-shadow:var(--shadow-md); }
.mim-qopt.correct { background:var(--green-bg); border-color:var(--green-border); }
.mim-qopt.wrong { background:var(--red-bg); border-color:#fca5a5; }
.mim-qopt:disabled { cursor:not-allowed; }
.mim-qdot {
  width:28px; height:28px; border-radius:50%;
  border:2px solid var(--border); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; transition:all .2s;
}
.mim-qopt.correct .mim-qdot { background:#dcfce7; border-color:#86efac; color:var(--green); }
.mim-qopt.wrong .mim-qdot { background:#fee2e2; border-color:#fca5a5; color:var(--red); }

/* ═══════════════════════════════
   PROGRESS BARS
═══════════════════════════════ */
.mim-prog { height:6px; background:var(--bg2); border-radius:99px; overflow:hidden; }
.mim-prog > div { height:100%; border-radius:99px; background:var(--grad-orange); transition:width .6s ease; }

/* Chapter XP bar */
.mim-xp-card { background:var(--white); }

/* ═══════════════════════════════
   AI OUTPUT
═══════════════════════════════ */
.mim-ai-out {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px;
  font-size:14px; line-height:1.75; color:var(--text);
  box-shadow:var(--shadow);
}
.mim-ai-out h3, .mim-ai-out h4, .mim-ai-out h5 { color:var(--black); margin:14px 0 6px; font-weight:700; }
.mim-ai-out h3:first-child, .mim-ai-out h4:first-child { margin-top:0; }
.mim-ai-out h3 { font-size:16px; padding-bottom:5px; border-bottom:1px solid var(--border); }
.mim-ai-out h4 { font-size:14px; color:var(--orange2); }
.mim-ai-out h5 { font-size:13px; color:var(--blue); }
.mim-ai-out ul, .mim-ai-out ol { padding-left:18px; margin:6px 0; }
.mim-ai-out li { margin-bottom:5px; }
.mim-ai-out ul li { list-style:disc; }
.mim-ai-out ol li { list-style:decimal; }
.mim-ai-out strong { font-weight:700; }
.mim-ai-out p { margin-bottom:9px; }
.mim-ai-out p:last-child { margin-bottom:0; }
.mim-ai-out blockquote {
  border-left:3px solid var(--orange);
  padding-left:12px; color:var(--text-sub);
  margin:8px 0; background:var(--orange-light);
  border-radius:0 8px 8px 0;
}

/* ═══════════════════════════════
   CHAT (Ask AI + Tutor)
═══════════════════════════════ */
.mim-chat-msgs {
  flex:1; overflow-y:auto; padding:16px;
  display:flex; flex-direction:column; gap:12px;
  background:var(--bg);
}
.mim-msg { display:flex; gap:8px; animation:mimIn .2s ease; }
.mim-msg-user { flex-direction:row-reverse; }
.mim-bubble {
  padding:11px 14px; border-radius:14px;
  font-size:14px; line-height:1.65; max-width:86%;
  border:1px solid var(--border); background:var(--white);
}
.mim-msg-user .mim-bubble {
  background:var(--black); color:#fff;
  border-color:var(--black); border-radius:14px 14px 4px 14px;
}
.mim-msg .mim-bubble { border-radius:14px 14px 14px 4px; }
.mim-av {
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:15px; flex-shrink:0; margin-top:2px;
  background:var(--bg2); border:1px solid var(--border);
}
.mim-av-user { background:var(--black); color:var(--orange); font-size:12px; font-weight:800; }

/* Sticky chat bar */
.mim-chat-bar {
  padding:12px 14px; background:var(--white);
  border-top:1px solid var(--border);
  display:flex; gap:8px; flex-shrink:0;
}
.mim-chat-inp {
  flex:1; background:var(--bg); border:1.5px solid var(--border);
  border-radius:10px; padding:10px 13px; color:var(--text);
  font-size:14px; font-family:inherit; resize:none;
}
.mim-chat-inp:focus { border-color:var(--orange); }
.mim-chat-send {
  width:44px; height:44px; flex-shrink:0; border-radius:10px;
  background:var(--grad-orange); border:none; color:#fff;
  font-size:18px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; box-shadow:0 2px 6px rgba(249,115,22,.35);
}

/* Chat suggestions */
.mim-ask-suggestions { padding:0 16px 8px; }
.mim-suggest-chip {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--white); border:1px solid var(--border);
  border-radius:99px; padding:6px 12px;
  font-size:12px; font-weight:500; color:var(--text);
  cursor:pointer; margin:0 4px 6px 0;
  transition:all .15s;
}
.mim-suggest-chip:hover { border-color:var(--orange); color:var(--orange2); }

/* ═══════════════════════════════
   STATS GRID (progress page)
═══════════════════════════════ */
.mim-stats-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:10px; margin-bottom:20px;
}
.mim-stat {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius); padding:14px 10px;
  text-align:center; box-shadow:var(--shadow);
}
.mim-stat-val { font-size:26px; font-weight:800; line-height:1; margin-bottom:4px; color:var(--black); }
.mim-stat-lbl { font-size:10px; color:var(--text-sub); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }

/* ═══════════════════════════════
   FORMS
═══════════════════════════════ */
.mim-form-g { margin-bottom:12px; }
.mim-label { font-size:12px; font-weight:700; color:var(--text-sub); display:block; margin-bottom:5px; text-transform:uppercase; letter-spacing:.04em; }
.mim-inp {
  width:100%; background:var(--bg); border:1.5px solid var(--border);
  border-radius:9px; padding:10px 12px; font-size:14px;
  color:var(--text); transition:border-color .15s;
}
.mim-inp:focus { border-color:var(--orange); background:var(--white); }
.mim-form-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mim-divider { height:1px; background:var(--border); margin:14px 0; }

/* ═══════════════════════════════
   BUTTONS
═══════════════════════════════ */
.mim-btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:7px; padding:11px 18px; border-radius:9px;
  font-size:14px; font-weight:700; cursor:pointer;
  font-family:inherit; transition:all .15s; border:none;
}
.mim-btn-primary {
  background:var(--grad-orange); color:#fff;
  box-shadow:0 2px 8px rgba(249,115,22,.3);
}
.mim-btn-primary:hover { opacity:.92; transform:translateY(-1px); box-shadow:0 4px 12px rgba(249,115,22,.4); }
.mim-btn-outline {
  background:var(--white); color:var(--text);
  border:1.5px solid var(--border);
}
.mim-btn-outline:hover { border-color:var(--orange-mid); }
.mim-btn-dark { background:var(--black); color:#fff; }
.mim-btn-green { background:var(--green); color:#fff; }
.mim-btn-upgrade { background:var(--grad-orange); color:#fff; box-shadow:0 2px 8px rgba(249,115,22,.3); }
.mim-back {
  display:inline-flex; align-items:center; gap:5px;
  font-size:13px; font-weight:600; color:var(--text-sub);
  margin-bottom:14px; cursor:pointer; padding:6px 0;
}
.mim-back:hover { color:var(--orange2); }

/* ═══════════════════════════════
   MODAL
═══════════════════════════════ */
.mim-modal-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,.35); display:none;
  align-items:flex-end; justify-content:center;
  backdrop-filter:blur(4px);
}
.mim-modal-overlay.open { display:flex; }
.mim-modal-box {
  background:var(--white); border-radius:22px 22px 0 0;
  padding:24px; width:100%; max-width:520px;
  max-height:92vh; overflow-y:auto; position:relative;
  box-shadow:var(--shadow-lg);
}
.mim-modal-title { font-family:'Syne',sans-serif; font-size:18px; font-weight:800; color:var(--black); margin-bottom:16px; }
.mim-modal-x {
  position:absolute; top:14px; right:14px;
  width:30px; height:30px; border-radius:50%;
  background:var(--bg2); border:1px solid var(--border);
  font-size:14px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-sub);
}

/* ═══════════════════════════════
   BADGES
═══════════════════════════════ */
.mim-badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 9px; border-radius:99px;
  font-size:11px; font-weight:700;
}
.mim-badge-green { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.mim-badge-orange { background:var(--orange-light); color:var(--orange2); border:1px solid var(--orange-mid); }
.mim-badge-blue { background:var(--blue-bg); color:var(--blue); border:1px solid #bfdbfe; }
.mim-badge-red { background:var(--red-bg); color:var(--red); border:1px solid #fecaca; }

/* ═══════════════════════════════
   TOAST
═══════════════════════════════ */
#mim-toast {
  position:fixed; bottom:90px; left:50%; transform:translateX(-50%) translateY(16px);
  background:var(--black); color:#fff; border-radius:12px;
  padding:11px 20px; font-size:13px; font-weight:600;
  opacity:0; transition:all .28s; z-index:9999;
  pointer-events:none; white-space:nowrap; max-width:90vw;
  text-align:center; box-shadow:var(--shadow-lg);
}
#mim-toast.on { opacity:1; transform:translateX(-50%) translateY(0); }

/* ═══════════════════════════════
   LOADING / EMPTY
═══════════════════════════════ */
.mim-loading { display:flex; align-items:center; gap:12px; padding:32px 16px; color:var(--text-sub); font-size:14px; }
.mim-spin {
  width:20px; height:20px; border:2.5px solid var(--border);
  border-top-color:var(--orange); border-radius:50%;
  animation:mimSpin .7s linear infinite; flex-shrink:0;
}
@keyframes mimSpin { to { transform:rotate(360deg); } }
.mim-pulse { animation:mimPulse 1.5s ease infinite; }
@keyframes mimPulse { 0%,100% { opacity:1; } 50% { opacity:.4; } }
.mim-empty { text-align:center; padding:40px 16px; color:var(--text-muted); font-size:14px; }
.mim-empty-icon { font-size:36px; margin-bottom:10px; }
.mim-empty-text { font-size:14px; color:var(--text-sub); }

/* ═══════════════════════════════
   BOTTOM NAV (mobile)
═══════════════════════════════ */
.mim-bnav {
  position:fixed; bottom:0; left:0; right:0; z-index:250;
  background:var(--white); border-top:1px solid var(--border);
  display:none; padding-bottom:env(safe-area-inset-bottom,0);
  box-shadow:0 -4px 16px rgba(0,0,0,.06);
}
.mim-bnav-btn {
  display:flex; flex-direction:column; align-items:center;
  padding:9px 4px 7px; gap:2px;
  color:var(--text-muted); font-size:10px; font-weight:600;
  font-family:inherit; flex:1; transition:color .15s;
}
.mim-bnav-btn span:first-child { font-size:21px; line-height:1; display:block; }
.mim-bnav-btn.active { color:var(--orange2); }

/* ═══════════════════════════════
   OVERLAY
═══════════════════════════════ */
.mim-overlay {
  display:none; position:fixed; inset:0; z-index:280;
  background:rgba(0,0,0,.3);
}
.mim-overlay.open { display:block; }

/* ═══════════════════════════════
   PLAN CARDS (modal)
═══════════════════════════════ */
.mim-plan-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--radius); padding:16px;
  cursor:pointer; transition:all .2s; margin-bottom:10px;
}
.mim-plan-card:hover, .mim-plan-card.selected { border-color:var(--orange); }
.mim-plan-popular {
  background:var(--orange); color:#fff;
  border-radius:99px; padding:2px 10px;
  font-size:10px; font-weight:800;
  display:inline-block; margin-bottom:6px;
}

/* ═══════════════════════════════
   SCROLLBAR
═══════════════════════════════ */
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:99px; }

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media (max-width: 768px) {
  .mim-sidebar {
    position:fixed; top:0; left:0; height:100vh;
    transform:translateX(-100%); z-index:300;
    width:270px; box-shadow:4px 0 24px rgba(0,0,0,.12);
  }
  .mim-sidebar.open { transform:translateX(0); }
  .mim-hamburger { display:flex; }
  .mim-bnav { display:grid; }
  .mim-page { padding:14px; padding-bottom:100px; }
  .mim-page-chat.active { height:calc(100vh - 56px - env(safe-area-inset-bottom,0px)); }
  .mim-quick-grid-3 { grid-template-columns:1fr 1fr; }
  .mim-stats-grid { grid-template-columns:repeat(2,1fr); }
  .mim-hero-stats { grid-template-columns:repeat(2,1fr); }
}
@media (min-width: 769px) {
  .mim-hamburger { display:none; }
  .mim-bnav { display:none; }
  .mim-sidebar { transform:none !important; }
  .mim-overlay { display:none !important; }
  #mim-toast { bottom:30px; }
}
@media (min-width: 1200px) {
  .mim-content > .mim-page { max-width:880px; }
}
