/* ===== ShellBuddy styles — mobile-first, terminal-inspired, friendly ===== */
:root {
  --bg: #0b0f17;
  --bg-soft: #121826;
  --bg-card: #161e2e;
  --bg-elev: #1c2638;
  --border: #263247;
  --text: #e7edf6;
  --text-dim: #9fb0c7;
  --text-faint: #6c7d96;
  --accent: #4ade80;     /* friendly green */
  --accent-2: #38bdf8;   /* sky */
  --accent-3: #a78bfa;   /* violet */
  --warn: #fbbf24;
  --danger: #fb7185;
  --mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --radius: 16px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: var(--sans);
  background: radial-gradient(1200px 800px at 80% -10%, #16203a 0%, var(--bg) 55%);
  color: var(--text);
  overscroll-behavior-y: none;
  -webkit-font-smoothing: antialiased;
}
.hidden { display: none !important; }
button { font-family: inherit; cursor: pointer; }
a { color: var(--accent-2); }

/* ===== App shell ===== */
.app { display: flex; flex-direction: column; min-height: 100vh; min-height: 100dvh; }

.topbar {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between;
  padding: calc(var(--safe-top) + 12px) 16px 12px;
  background: rgba(11,15,23,.82);
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--border);
}
.brand { display: flex; align-items: center; gap: 9px; font-weight: 700; }
.brand-logo {
  font-family: var(--mono); color: var(--bg); background: var(--accent);
  padding: 3px 7px; border-radius: 7px; font-size: 14px; font-weight: 800;
}
.brand-name { letter-spacing: .2px; }
.brand-turtle { border-radius: 5px; image-rendering: pixelated; display: block; }
.js-syncchip {
  font-size: 12.5px; font-weight: 700; background: var(--bg-card);
  border: 1px solid var(--border); padding: 5px 11px; border-radius: 999px;
  color: var(--text-dim); cursor: pointer;
}
.js-syncchip:hover { border-color: var(--accent); color: var(--text); }
.js-syncchip.synced { color: var(--accent); border-color: rgba(74,222,128,.4); }
.js-syncchip.mobile-sync { padding: 5px 9px; font-size: 13px; }
.stats { display: flex; align-items: center; gap: 8px; }
.stat {
  font-size: 13px; font-weight: 700; background: var(--bg-card);
  border: 1px solid var(--border); padding: 5px 9px; border-radius: 999px;
  color: var(--text-dim);
}
.stat.level { color: var(--bg); background: var(--accent-3); border-color: transparent; }

.view { flex: 1; padding: 18px 16px calc(96px + var(--safe-bottom)); max-width: 760px; width: 100%; margin: 0 auto; }

/* ===== Tab bar ===== */
.tabbar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 30;
  display: grid; grid-template-columns: repeat(5, 1fr);
  background: rgba(13,18,28,.92);
  backdrop-filter: saturate(140%) blur(14px);
  border-top: 1px solid var(--border);
  padding: 6px 6px calc(6px + var(--safe-bottom));
}
.tab {
  background: none; border: none; color: var(--text-faint);
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px 4px; font-size: 11px; font-weight: 600; border-radius: 12px;
  position: relative; transition: color .15s;
}
.tab .tab-ico { font-size: 19px; line-height: 1; font-family: var(--mono); }
.tab.active { color: var(--accent); }
.badge {
  position: absolute; top: 2px; right: calc(50% - 30px);
  background: var(--danger); color: #1a0a0e; font-style: normal;
  font-size: 10px; font-weight: 800; min-width: 16px; height: 16px;
  border-radius: 999px; display: flex; align-items: center; justify-content: center; padding: 0 4px;
}

/* ===== Headings / sections ===== */
.h-title { font-size: 24px; font-weight: 800; margin: 4px 0 4px; letter-spacing: -.3px; }
.h-sub { color: var(--text-dim); font-size: 14px; margin: 0 0 18px; line-height: 1.5; }
.section-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--text-faint); margin: 22px 2px 10px; }

/* ===== Cards ===== */
.card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px; margin-bottom: 12px;
}
.card-row { display: flex; align-items: center; gap: 14px; }

/* Module + lesson list */
.module { margin-bottom: 26px; }
.module-head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.module-ico {
  width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  font-size: 22px; background: var(--bg-elev); border: 1px solid var(--border); flex: none;
}
.module-meta h3 { margin: 0; font-size: 16px; font-weight: 700; }
.module-meta p { margin: 2px 0 0; font-size: 12.5px; color: var(--text-dim); }
.module-bar { height: 5px; background: var(--bg-elev); border-radius: 999px; overflow: hidden; margin-top: 8px; }
.module-bar > i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); border-radius: 999px; transition: width .4s; }

.lesson {
  display: flex; align-items: center; gap: 13px; width: 100%; text-align: left;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 13px 14px; margin-bottom: 9px; color: var(--text);
  transition: transform .08s, border-color .15s;
}
.lesson:active { transform: scale(.99); }
.lesson.done { border-color: rgba(74,222,128,.35); }
.lesson.locked { opacity: .5; }
.lesson-state {
  width: 30px; height: 30px; border-radius: 50%; flex: none; display: grid; place-items: center;
  font-size: 14px; font-weight: 800; border: 2px solid var(--border); color: var(--text-faint);
}
.lesson.done .lesson-state { background: var(--accent); color: var(--bg); border-color: transparent; }
.lesson-body { flex: 1; min-width: 0; }
.lesson-body h4 { margin: 0; font-size: 15px; font-weight: 650; }
.lesson-body p { margin: 2px 0 0; font-size: 12.5px; color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lesson-xp { font-size: 11px; font-weight: 700; color: var(--text-faint); flex: none; }
.chev { color: var(--text-faint); font-size: 18px; }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--accent); color: #06210f; border: none; font-weight: 750;
  padding: 13px 18px; border-radius: 13px; font-size: 15px; width: 100%;
  transition: transform .08s, filter .15s;
}
.btn:active { transform: scale(.98); }
.btn:disabled { filter: grayscale(.5) brightness(.7); cursor: not-allowed; }
.btn.secondary { background: var(--bg-elev); color: var(--text); border: 1px solid var(--border); }
.btn.ghost { background: transparent; color: var(--text-dim); border: 1px solid var(--border); }
.btn.small { width: auto; padding: 9px 14px; font-size: 13px; border-radius: 10px; }
.btn-row { display: flex; gap: 10px; margin-top: 8px; }

/* ===== Lesson player ===== */
.player-top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.icon-btn {
  width: 38px; height: 38px; border-radius: 11px; flex: none;
  background: var(--bg-card); border: 1px solid var(--border); color: var(--text);
  font-size: 18px; display: grid; place-items: center;
}
.progress-track { flex: 1; height: 7px; background: var(--bg-elev); border-radius: 999px; overflow: hidden; }
.progress-track > i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); border-radius: 999px; transition: width .35s; }

.step-card { animation: rise .28s ease; }
@keyframes rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.step-kicker { font-size: 12px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--accent-2); margin-bottom: 8px; }
.step-h { font-size: 22px; font-weight: 800; margin: 0 0 12px; letter-spacing: -.3px; line-height: 1.2; }
.prose { font-size: 15.5px; line-height: 1.62; color: var(--text); }
.prose p { margin: 0 0 13px; }
.prose strong { color: #fff; }
.prose code {
  font-family: var(--mono); background: var(--bg); border: 1px solid var(--border);
  padding: 1.5px 6px; border-radius: 6px; font-size: .86em; color: var(--accent);
}
.prose ul { margin: 0 0 13px; padding-left: 20px; }
.prose li { margin-bottom: 7px; }

.callout {
  border-radius: 13px; padding: 13px 15px; margin: 14px 0; font-size: 14px; line-height: 1.55;
  border: 1px solid; display: flex; gap: 11px; align-items: flex-start;
}
.callout .c-ico { font-size: 18px; flex: none; line-height: 1.3; }
.callout.tip { background: rgba(56,189,248,.08); border-color: rgba(56,189,248,.32); }
.callout.warn { background: rgba(251,191,36,.08); border-color: rgba(251,191,36,.34); }
.callout.danger { background: rgba(251,113,133,.09); border-color: rgba(251,113,133,.4); }
.callout.zen { background: rgba(167,139,250,.09); border-color: rgba(167,139,250,.34); }

/* code block */
.codeblock {
  font-family: var(--mono); background: #060a12; border: 1px solid var(--border);
  border-radius: 12px; padding: 13px 14px; font-size: 13.5px; line-height: 1.6;
  overflow-x: auto; margin: 14px 0; color: #cbd5e1; white-space: pre;
}
.codeblock .cm { color: var(--accent); }
.codeblock .cmt { color: var(--text-faint); }

/* try-it task */
.taskbox { border: 1px dashed rgba(74,222,128,.45); border-radius: 14px; padding: 14px; margin: 16px 0; background: rgba(74,222,128,.04); }
.taskbox h5 { margin: 0 0 4px; font-size: 13px; text-transform: uppercase; letter-spacing: .6px; color: var(--accent); }
.taskbox .goal { font-size: 14.5px; margin: 0 0 12px; line-height: 1.5; }

/* mini terminal */
.miniterm {
  font-family: var(--mono); background: #060a12; border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
}
.miniterm-head { display: flex; align-items: center; gap: 6px; padding: 8px 12px; border-bottom: 1px solid var(--border); }
.dot { width: 11px; height: 11px; border-radius: 50%; }
.dot.r { background: #ff5f57; } .dot.y { background: #febc2e; } .dot.g { background: #28c840; }
.miniterm-title { margin-left: 8px; font-size: 11px; color: var(--text-faint); }
.term-out { padding: 12px 13px; font-size: 13px; line-height: 1.55; max-height: 240px; overflow-y: auto; white-space: pre-wrap; word-break: break-word; }
.term-out .ln { display: block; }
.term-out .prompt-ln { color: var(--text-dim); }
.term-out .prompt-ln .u { color: var(--accent); }
.term-out .prompt-ln .p { color: var(--accent-2); }
.term-out .err { color: var(--danger); }
.term-out .ok { color: var(--accent); }
.term-out .sys { color: var(--accent-3); }
.term-inrow { display: flex; align-items: center; gap: 8px; padding: 9px 12px; border-top: 1px solid var(--border); }
.term-inrow .ps { color: var(--accent); font-size: 13px; }
.term-input {
  flex: 1; background: none; border: none; outline: none; color: var(--text);
  font-family: var(--mono); font-size: 13.5px; padding: 4px 0;
}
.term-run { background: var(--bg-elev); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 6px 11px; font-size: 12px; font-weight: 700; }

.task-done-banner { display: flex; align-items: center; gap: 9px; color: var(--accent); font-weight: 700; font-size: 14px; margin-top: 12px; animation: rise .3s; }

/* quiz */
.quiz-opt {
  display: block; width: 100%; text-align: left; background: var(--bg-card);
  border: 1.5px solid var(--border); color: var(--text); border-radius: 12px;
  padding: 14px 15px; margin-bottom: 10px; font-size: 15px; transition: border-color .15s, background .15s;
}
.quiz-opt:active { transform: scale(.99); }
.quiz-opt.correct { border-color: var(--accent); background: rgba(74,222,128,.12); }
.quiz-opt.wrong { border-color: var(--danger); background: rgba(251,113,133,.1); }
.quiz-opt.dim { opacity: .55; }
.quiz-feedback { font-size: 14px; line-height: 1.55; padding: 12px 14px; border-radius: 12px; margin-top: 6px; }
.quiz-feedback.good { background: rgba(74,222,128,.1); border: 1px solid rgba(74,222,128,.35); }
.quiz-feedback.bad { background: rgba(251,113,133,.1); border: 1px solid rgba(251,113,133,.35); }

/* completion */
.celebrate { text-align: center; padding: 30px 10px; animation: rise .4s; }
.celebrate .big { font-size: 64px; }
.celebrate h2 { font-size: 26px; margin: 12px 0 6px; }
.celebrate p { color: var(--text-dim); margin: 0 0 8px; }
.xp-pop { display: inline-block; background: var(--accent-3); color: var(--bg); font-weight: 800; padding: 6px 14px; border-radius: 999px; margin: 10px 0 24px; }

/* ===== Sandbox (full) ===== */
.sandbox-head { margin-bottom: 12px; }
.fullterm { font-family: var(--mono); background: #060a12; border: 1px solid var(--border); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; height: 60vh; min-height: 380px; }
.fullterm .term-out { flex: 1; max-height: none; }
.chips { display: flex; flex-wrap: wrap; gap: 7px; margin: 12px 0; }
.chip { background: var(--bg-card); border: 1px solid var(--border); color: var(--text-dim); font-family: var(--mono); font-size: 12px; padding: 6px 10px; border-radius: 8px; }
.chip:active { border-color: var(--accent); color: var(--accent); }

/* ===== Review / flashcards ===== */
.flashcard {
  background: linear-gradient(160deg, var(--bg-elev), var(--bg-card));
  border: 1px solid var(--border); border-radius: 18px; padding: 26px 20px;
  min-height: 220px; display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; margin-bottom: 16px;
}
.flashcard .q { font-size: 20px; font-weight: 700; line-height: 1.4; }
.flashcard .a { font-size: 16px; color: var(--text-dim); margin-top: 16px; line-height: 1.5; animation: rise .25s; }
.flashcard .a code { font-family: var(--mono); color: var(--accent); background: var(--bg); padding: 2px 7px; border-radius: 6px; }
.grade-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.grade { padding: 13px 6px; border-radius: 12px; font-weight: 700; font-size: 13px; border: 1px solid var(--border); }
.grade.again { background: rgba(251,113,133,.12); border-color: rgba(251,113,133,.4); color: var(--danger); }
.grade.good { background: rgba(56,189,248,.12); border-color: rgba(56,189,248,.4); color: var(--accent-2); }
.grade.easy { background: rgba(74,222,128,.12); border-color: rgba(74,222,128,.4); color: var(--accent); }

/* empty state */
.empty { text-align: center; padding: 50px 20px; color: var(--text-dim); }
.empty .e-ico { font-size: 50px; }
.empty h3 { color: var(--text); margin: 14px 0 6px; }

/* ===== Profile ===== */
.statgrid { display: grid; grid-template-columns: repeat(2,1fr); gap: 11px; margin-bottom: 8px; }
.bigstat { background: var(--bg-card); border: 1px solid var(--border); border-radius: 15px; padding: 16px; }
.bigstat .v { font-size: 28px; font-weight: 800; }
.bigstat .l { font-size: 12.5px; color: var(--text-dim); margin-top: 2px; }
.levelbar { height: 9px; background: var(--bg-elev); border-radius: 999px; overflow: hidden; margin: 8px 0; }
.levelbar > i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-3), var(--accent-2)); }

/* ===== Onboarding ===== */
.onboarding {
  position: fixed; inset: 0; z-index: 100; background: var(--bg);
  display: flex; flex-direction: column; padding: calc(var(--safe-top) + 24px) 22px calc(var(--safe-bottom) + 22px);
  max-width: 560px; margin: 0 auto;
}
.ob-slide { flex: 1; display: flex; flex-direction: column; justify-content: center; animation: rise .35s; }
.ob-emoji { font-size: 70px; }
.ob-h { font-size: 30px; font-weight: 850; letter-spacing: -.5px; margin: 18px 0 12px; line-height: 1.12; }
.ob-p { font-size: 16.5px; line-height: 1.6; color: var(--text-dim); }
.ob-p strong { color: var(--text); }
.ob-dots { display: flex; gap: 8px; justify-content: center; margin: 18px 0; }
.ob-dots i { width: 8px; height: 8px; border-radius: 50%; background: var(--border); }
.ob-dots i.on { background: var(--accent); width: 22px; border-radius: 999px; }
.ob-input {
  width: 100%; margin-top: 18px; background: var(--bg-card); border: 1.5px solid var(--border);
  color: var(--text); border-radius: 14px; padding: 15px; font-size: 17px; outline: none;
}
.ob-input:focus { border-color: var(--accent); }
.greeting { color: var(--accent); font-weight: 700; font-size: 15px; margin: 0 0 2px; }
.ob-choices { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
.ob-choice { text-align: left; background: var(--bg-card); border: 1.5px solid var(--border); color: var(--text); border-radius: 14px; padding: 15px; font-size: 15px; }
.ob-choice.sel { border-color: var(--accent); background: rgba(74,222,128,.08); }
.ob-choice .ec { font-size: 22px; margin-right: 10px; }

@media (min-width: 620px) {
  .h-title { font-size: 28px; }
  .statgrid { grid-template-columns: repeat(4,1fr); }
}

/* ===== "Try it for real" callout — the bridge to real machines ===== */
.callout.real { background: rgba(74,222,128,.07); border-color: rgba(74,222,128,.4); }
.callout.real .c-ico { color: var(--accent); }
.callout.real code { background:#060a12; }

/* ===== Desktop chrome is OFF by default (mobile-first). ===== */
.menubar, .winbar { display: none; }
.mb-clock { font-variant-numeric: tabular-nums; }

/* ===== Model Picker ===== */
.seg { display: flex; gap: 8px; flex-wrap: wrap; margin: 6px 0 4px; }
.seg button {
  flex: 1; min-width: 64px; background: var(--bg-card); border: 1.5px solid var(--border);
  color: var(--text); border-radius: 11px; padding: 11px 8px; font-weight: 700; font-size: 14px;
}
.seg button.on { border-color: var(--accent); background: rgba(74,222,128,.1); color: var(--accent); }
.picker-note { font-size: 12.5px; color: var(--text-faint); margin: 4px 2px 0; }
.verdict { border-radius: 13px; padding: 13px 15px; margin: 14px 0 4px; font-size: 14px; line-height: 1.5; border: 1px solid var(--border); background: var(--bg-card); }
.model-card { display:flex; align-items:center; gap:12px; background: var(--bg-card); border:1px solid var(--border); border-radius: 13px; padding: 12px 14px; margin-bottom: 9px; }
.model-fit { width: 38px; height: 38px; border-radius: 10px; flex:none; display:grid; place-items:center; font-size:18px; }
.model-fit.great { background: rgba(74,222,128,.16); }
.model-fit.ok { background: rgba(251,191,36,.16); }
.model-fit.no { background: rgba(251,113,133,.16); }
.model-body { flex:1; min-width:0; }
.model-body h4 { margin:0; font-size: 15px; }
.model-body .cmd { font-family: var(--mono); font-size: 12px; color: var(--accent); margin-top:3px; display:block; }
.model-body p { margin: 3px 0 0; font-size: 12.5px; color: var(--text-dim); }
.model-size { font-family: var(--mono); font-size: 12px; color: var(--text-faint); flex:none; }

/* cheat-sheet table */
.cheat { width:100%; border-collapse: collapse; font-size: 13.5px; }
.cheat td { padding: 9px 8px; border-bottom: 1px solid var(--border); vertical-align: top; }
.cheat td.c { font-family: var(--mono); color: var(--accent); white-space: nowrap; width: 38%; }

/* ===== Companion / command decoder ===== */
.decoder-row { display: flex; gap: 8px; align-items: center; }
.decoder-input {
  flex: 1; background: #060a12; border: 1px solid var(--border); color: var(--text);
  font-family: var(--mono); font-size: 14px; padding: 11px 12px; border-radius: 11px; outline: none;
}
.decoder-input:focus { border-color: var(--accent); }
.pieces { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0 4px; }
.piece { font-family: var(--mono); font-size: 13px; padding: 4px 9px; border-radius: 8px; border: 1px solid; }
.piece-desc { font-size: 13.5px; line-height: 1.5; color: var(--text-dim); margin: 8px 0; display: flex; gap: 9px; align-items: baseline; }
.piece-desc .piece { flex: none; }
.sev-safe { color: var(--accent); border-color: rgba(74,222,128,.45); background: rgba(74,222,128,.08); }
.sev-caution { color: var(--warn); border-color: rgba(251,191,36,.45); background: rgba(251,191,36,.08); }
.sev-danger { color: var(--danger); border-color: rgba(251,113,133,.5); background: rgba(251,113,133,.1); }
.verdict.sev-safe { border-color: rgba(74,222,128,.45); }
.verdict.sev-caution { border-color: rgba(251,191,36,.45); }
.verdict.sev-danger { border-color: rgba(251,113,133,.5); background: rgba(251,113,133,.06); }

/* ===== Wide screens: become a desktop "computer workspace" ===== */
/* ===== Wide screens: a normal website layout (header + centered content) ===== */
@media (min-width: 900px) {
  .app { min-height: 100vh; min-height: 100dvh; }

  /* hide mobile-only chrome + the old "OS window" chrome */
  .topbar { display: none; }
  .tabbar { display: none; }
  .winbar { display: none; }
  .mb-clock { display: none; }

  /* Header — a clean, normal site nav bar */
  .menubar {
    display: flex; align-items: center; gap: 18px; height: 60px; padding: 0 32px;
    background: rgba(11,15,23,.9); backdrop-filter: saturate(140%) blur(14px);
    border-bottom: 1px solid var(--border);
    position: sticky; top: 0; z-index: 40;
  }
  .mb-brand { font-weight: 800; font-size: 17px; display: flex; align-items: center; gap: 8px; }
  .mb-brand .brand-logo { font-size: 13px; padding: 3px 7px; }
  .mb-nav { display: flex; gap: 3px; margin-left: 8px; }
  .mb-nav .navbtn { background: none; border: none; color: var(--text-dim); font-weight: 600; font-size: 14.5px; padding: 8px 13px; border-radius: 9px; transition: background .15s, color .15s; }
  .mb-nav .navbtn:hover { background: var(--bg-elev); color: var(--text); }
  .mb-nav .navbtn.active { color: var(--accent); background: rgba(74,222,128,.1); }
  .mb-spacer { flex: 1; }
  .mb-stats { display: flex; align-items: center; gap: 10px; color: var(--text-dim); font-weight: 700; font-size: 14px; }
  .mb-stats .mb-stat { background: var(--bg-card); border: 1px solid var(--border); padding: 5px 11px; border-radius: 999px; }
  .mb-stats .mb-stat.level { background: var(--accent-3); border-color: transparent; color: var(--bg); }
  .mb-stats .mb-stat.level b { color: var(--bg); }

  /* Content — a centered reading column on the plain page background */
  .workspace { padding: 0; background: none; display: block; }
  .window { max-width: 880px; margin: 0 auto; background: none; border: none; box-shadow: none; border-radius: 0; overflow: visible; }
  .view { padding: 40px 28px 90px; max-width: none; margin: 0; }

  .h-title { font-size: 32px; }
  .fullterm { height: 62vh; }
}

